N'Abend! Ich habe mehrere ICs am TWI (Atmega32) hängen. die meisten funktionieren nur mit SCK < 100kHz. Problem: Es kommt n neuer IC dazu, der n SCK > 500kHz braucht. Ist es möglich im Programmablauf zwischen 100 und 500kHz einfach zu wechseln? Je nachdem mit welchem Slave ich kommunizieren will? Danke mal! Freddy0815
>Problem: Es kommt n neuer IC dazu, der n SCK > 500kHz braucht. Du meinst wohl eher 400Khz Den Takt mittendrinn (ok,nicht unbedingt mitten in einer Aktion obwohl das Theoretisch kein Akt wäre) zu ändern ist kein Problem aber wenn du ihn deutlich über die Grenzen der anderen Slaves anhebst dann kann es passieren das die dir plötzlich wirr dazwischenfunken denn es hängen ja Alle an einem Bus. Ansonsten mußte dir was einfallen lassen. -die anderen durch schnellere Modelle ersetzen. -2. Eigneständigen Bus aufmachen -Den bus über einen Extender bzw. Hub aufteilen. Schau dir mal zb. den PCA9540 an. Der geht bis 400 und du brauchst keine Extraleitungen. Nur für jedes Segment die eigene Terminierung. Die 400er Steine an den einen Kanal und die 100er an den anderen bzw. den 400er ins erste Segment und die 100er Zuschaltbar hinter den 9540. Obendrein kannst du Adressen doppelt vergeben wenn du immer nur einen Kanal online hast (Is ja hier erwünscht um zu trennen). Es gibt natürlich noch andere Bausteine. Dieser ist einer davon.
Der I2C-Master muß sich immer nach dem langsamsten Baustein am Bus richten, d.h. 100kHz sind dann das Maximum. Die I2C-Spezifikation kennt nur Minimalzeiten, d.h. der I2C-Bus kann nie zu langsam sein. Ein IC mit Taktfrequenz > 500kHz ist demzufolge kein I2C-IC. Der Name SCK ist bei SPI üblich, bei I2C heißt das Taktsignal SCL. Schau Dir also den IC nochmal genau an. Peter
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.