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, > > > > im Modul eeprom befindet sich ein ziemlich heftiger Fehler. > > Mich wundert eigentlich, dass er noch nicht aufgefallen ist, > > da er den Umgang mit Longarrays praktisch unbenutzbar macht. > > Mich wunderts auch. :-) > > > > Konkret enthält das Modul eeprom folgende Funktion: > > ...<code> > > i2c.write((data[i]) shr (8*(3-i%4))); <---- hier ist der Fehler > > </code> > > ... > > Die markierte Zeile sollte daher durch folgende ersetzt > > werden: > > > > <code> i2c.write((data[i/4]) shr (8*(3-i%4)));</code> > > Danke für den Hinweis. > Ich werde in kürze eine neue Version von eeprom.c2 hochladen. > Allerdings habe ich u.a. die Funktion gleich etwas optimiert: > <code>const lrshift[]=24,16,8,0; > function writelongarray(byte eepromaddr,int addr, long data[], long len) returns int > // Für "addr" sollten nur geradzahlige Werte übergeben werden! > {long i; > if len < 1 return 0; > if write(eepromaddr,addr) > { > len=len*4; > for i=0 ... <len > { > if ((addr+i) % Pagewrite[eepromaddr])==0 and i > {i2c.stop(); > if not write(eepromaddr,addr+i) {lasterr=0xB0000 or (i shr 2);return 0;} > } > i2c.write((data[i shr 2]) shr lrshift[i and 3]); > } > i2c.stop(); > return -1; > } > lasterr=0xB0000; > return 0; > }</code> > > Es waren noch ein paar weitere kleine versteckte Bugs im Modul, welche > erst bei 512kBit EEProms auffallen. > > Bei der Version 2.5, die ich hochladen werde gibt, es auch die neue Funktion init(), > wodurch die Pagegröße für jedes EEProm an unterschiedlichen Adressen > einzeln festgelegt werden. > Diese Funktion muß dann zwingend aufgerufen werden. Der Parameter 0 für Pagesize > bewirkt dann ein Festlegen auf den Wert, welcher in der Konstante DefaultPagewrite > hinterlegt ist. (Bis V2.41 "Pagewrite") > > MfG André H.
Dateianhang: (.gif, .png., .jpg, .zip, .rar)
max. 256kB
max. 256kB