Zur Übersicht - INFO - Neueste 50 Beiträge - Neuer Beitrag - Suchen - FAQ - Zum CC1-Forum - Zum CC-Pro-Forum

Wichtig: Bevor Du wegen einem Problem mit der CC2 postest, stelle sicher, daß Du
die neueste OS-Version, die neuseste Compiler-DLL und die neuesten Modulversionen benutzt!
Beachte, daß sich auf der CD zur CC2-Unit/Station auch jetzt noch die ältesten Dateien befinden!
Es gelten folgende Anleitung und Regeln: Regeln CC2Net.de-Forum
Zurück zum Artikel  (Blaue Felder sind Pflichtfelder)


Name:   UserID: 
 E-Mail:
Kategorie
Betreff
Homepage:
Link-Titel:
Link-URL:
Cookie für Name, UserID, E-Mail, Homepage-URL setzen
(Erspart die Neueingabe bei Beiträgen und Antworten)
(Zum Löschen des Cookies hier klicken)
Ich nutze:
C-Control II Unit
C164CI-Controllerboard
C-Control II Station
CCRP5 mit CC2-Unit (Conrad Roboter)
CC2-Application-Board
CC2-StarterBoard
CC2-ReglerBoard
eigenes Board
original OS     OSOPT_V2     OSOPT V3.0 OSOPT V3.1

Kommentar:
Einfügen von HTML im Kommentar:

Link einfügen: <a href="LINKURL" target="_blank">LINKTITEL</a>
Bild einfügen: <img src="BILDURL">
Text formatieren: <b>fetter Text</b>  <i>kursiver Text</i> <u>unterstrichener Text</u>
Kombinationen sind auch möglich z.B.: <b><i>fetter & kursiver Text</i></b>
C2 Quellcode formatieren: <code>Quellcode</code>
ASM Quellcode formatieren: <asm>Quellcode</asm>
(Innerhalb eines Quellcodeabschnitts ist kein html möglich.)
Wichtig: Bitte mache Zeilenumbrüche, bevor Du am rechten Rand des Eingabefeldes ankommst !  

> Hallo Hansi, hallo Jörg, > > > Im Modul pcf8583.c2 läuft ein thread watchdog, und hier gibt's m.E. ein Problem mit dem Überlauf > > der long Variable tm. > > Das war es in der Tat. > Ich dachte ich hätte diesen kleinen Bug schon längst behoben. Aber scheinbar war > diese Änderung einem meiner 2005er Festplattencrashes zum Opfer gefallen, > und wurde dann von mir schlicht vergessen. > Ich habe mittlerweile eine neue Version von pcf8583.c2 hochgeladen. > > > Ich habe bei mir folgenden Code am Laufen (seit dem ohne die von Dir erwähnten Reboots): > > > > <code> > > // - patched version - 12.12.06 JC -- > > ... > > { > > if (system.timer()-tm)>=(timeout*500) ...</code> > > Naja, hier kann es aber auch zu einem Überlauf kommen. ;-) > Denn die Multiplikation des Timeoutwerts mit 500 läuft in Integer ab. > Ab einem Wert von 66 kommt es daher zwar nicht zu ungewollten Neustarts > seitens des Watchdogs, jedoch zu einem Non-Stop-Zurücksetzen des Watchdogs, > da das Ergebnis negativ wird. ;-) > Daher ist es besser, die Differenz der Timerstände duch 500 zu teilen. > Alternativ könnte man auch ein explizites Cast anwenden: > <code> > if (system.timer()-tm)>=cast.intLong(timeout)*500 ... > </code> > > MfG André H.
Dateianhang: (.gif, .png., .jpg, .zip, .rar)
max. 256kB
max. 256kB