Hab das ganze mal nach deinen Vorgaben umgestrickt und es funktioniert wunderbar. Werden den Source evtl. ins Download-Verzeichnis stellen, da vieleicht noch der eine oder andere sich sonst den kopf darüber zerbricht....man muß das Rad ja nich immer neu erfinden![]()
Code:Config Scl = Portc.0 'PIN für I2C Bus Config Sda = Portc.1 I2cinit Dim Eehead(2) As Byte Dim Eebyte(4) As Byte Dim Eesingle As Single At Eebyte Overlay Dim Eeword(2) As Word At Eebyte Overlay Dim Eebanz As Byte Dim Ee_adresse As Word Const 24c64w = &B10100000 Const 24c64r = &B10100001 'Definition der Funktionen ++++++++++++++++++++++++++++++++++++++++++++++++++++ Declare Function Loadbyte(byval Ee_adresse As Word) As Byte Declare Function Loadword(byval Ee_adresse As Word) As Word Declare Function Loadsingle(byval Ee_adresse As Word) As Single Declare Sub Savebyte(byval Ee_daten As Byte , Byval Ee_adresse As Word) Declare Sub Saveword(byval Ee_daten As Word , Byval Ee_adresse As Word) Declare Sub Savesingle(byval Ee_daten As Single , Byval Ee_adresse As Word ) Goto 001 Sub Savebyte(byval Ee_daten As Byte , Byval Ee_adresse As Word) Eebyte(3) = Ee_daten Ee_adresse = Ee_adresse Eebanz = 1 + 2 : Gosub Write_ee End Sub Sub Saveword(byval Ee_daten As Word , Byval Ee_adresse As Word) Eeword(2) = Ee_daten Ee_adresse = Ee_adresse Eebanz = 2 + 2 : Gosub Write_ee End Sub Sub Savesingle(byval Ee_daten As Single , Byval Ee_adresse As Word ) Eesingle = Ee_daten Ee_adresse = Ee_adresse Eebanz = 4 + 2 : Gosub Write_ee End Sub Function Loadbyte(byval Ee_adresse As Word) As Byte Ee_adresse = Ee_adresse Eebanz = 1 : Gosub Read_ee Loadbyte = Eebyte(3) End Function Function Loadword(byval Ee_adresse As Word) As Word Ee_adresse = Ee_adresse Eebanz = 2 : Gosub Read_ee Loadword = Eeword(2) End Function Function Loadsingle(byval Ee_adresse As Word) As Single Ee_adresse = Ee_adresse Eebanz = 4 : Gosub Read_ee Loadsingle = Eesingle End Function 'Routine zum schreiben von Daten in das EEPROM ++++++++++++++++++++++++++++++++ Write_ee: Eehead(1) = High(ee_adresse) Eehead(2) = Low(ee_adresse) I2csend 24c64w , Eehead(1) , Eebanz Waitus 40000 Return 'Routine zum lesen von Daten aus dem EEPROM ++++++++++++++++++++++++++++++++++++ Read_ee: Eehead(1) = High(ee_adresse) Eehead(2) = Low(ee_adresse) I2csend 24c64w , Eehead(1) , 2 Waitus 20000 I2creceive 24c64r , Eebyte(1) , 0 , Eebanz Waitus 40000 Return 001: Dim Ins As Single Dim Inw As Word Dim Inb As Byte Do Input "Single: " , Ins Call Savesingle(ins , 100) Print "gespeicherter Wert: ";ins Ins = Loadsingle(100) Print "geladener Wert: " ; Ins Input "Word: " , Inw Call Saveword(inw , 100) Print "gespeicherter Wert: " ; Inw Inw = Loadword(100) Print "geladener Wert: " ; Inw Input "Byte: " , Inb Call Savebyte(inb , 100) Print "gespeicherter Wert: " ; Inb Inb = Loadbyte(100) Print "geladener Wert: " ; Inb Loop







Zitieren

Lesezeichen