Re: I2C-Terminal friert ein Kategorie: I²C-Bus (von Mexx - 13.08.2008 12:36) | ||
Als Antwort auf Re: I2C-Terminal friert ein von André H. - 24.07.2008 12:01 | ||
| ||
Hallo Andre ! > > ich habe meine Steuerung derzeit im Versuchsaufbau und benutze den i2C Bus mit CCTools-Reglerboard > > zur Ansteuerung von > > a.) 1 x i2c Tranceiver und dahinter 2 x i2C Transceiver mit 2x i2C Terminal auf LCDs > > b.) 1 x i2C Terminal auf LCD > > c.) 1 x i2C RAM-Device > > d.) 2 x i2C Relaisplatine > > e.) 2 x i2C 1-Wire Bridge (mit insgesamt 15 Sensoren) > > > > Thread 1 bedient a.) und b.) > > Thread 2 bedient c.) und e.) > > Thread 3 bedient d.) > > Wenn die Thread die überwiegende Zeit auf dem I²C-Bus arbeiten(d.h. mehr als 2/3) > und gleichzeitig die Threads (oder zumindest einer) nicht sehr lang sind, > kann es sein, da� der Threadwechsel innerhalb eines I²C-Captures erfolgen soll. > Da aber die anderen Threads dann auf die Freigabe warten, wirt die Rechenzeit von diesen > sofort wieder abgegeben, so da� der erste Thread wieder die Rechenzeit bekommt, und > im ungünstigsten Fall wieder zu einem I²C-Capture kommt, bvor die Rechenzeit wieder > abgegeben wird. > Ein solcher Kandidat wäre bei Dir Thread 1, da ich vermute, da� dieser, au�er Ausgaben > auf den Terminals und das Einlesen der Tasten, nicht viel au�erhalb von I²C betreffenden > Routinen macht. Ist korrekt, aktualisiert mit sleep-Anweisung alle 4 Sekunden. > Wenn das der Fall ist, wäre ein Abbremsen mit sleep oder zumindest ein paar verteilte > yields sinnvoll. > Displayausgaben mu� man nicht ständig durchführen. Je nach Anwendung reicht > eine Ausgabe im Halb-oder Einsekundenintervall bzw. sogar nur bei �nderung. > Tastaturen an den Terminals sollten nicht per Polling abgefragt werden. > Besser ist es, alle Interruptleitungen der Terminals auf einen I/O-Port zu legen > (Pull-Up nicht vergessen), und nur bei einem Low-Pegel alle Terminals abzufragen, > solange das auslösende Terminal gefunden wurde. Mache ich auch so. > > Dein Thread 2, denke ich, wird bereits sleeps enthalten? Ja. > Ich gehe davon aus, da� auf das RAM-Device in einem bestimmten Intervall, und > auf die 1W-Sensoren max. im Sekundentakt zugegriffenwird. Korrekt. 1W-Sensoren alle 4 Sekunden, RAM-Device zyklsich alle 15 Minuten bzw. unter bestimmten Umständen auch spontan. > > �hnliches wird wahrscheinlich beim Thread 3 für die Relaisplatinen sein. Ja. > > Welcher Thread übernimmt eigentlich die Regelungsaufgaben? > Ich gehe mal davon aus, da� es Thread 3 ist. So ist es. Probleme habe ich mir vor allem auch damit eingefangen dass ich zu Beginn die 3 LCD nicht via Interrupt sondern zyklsich alle Sekunde abgefragt habe, dadurch kam es dann in Summe zu vielen Zugriffen am i2C mit den entsprechenden Folgen ... Schöne Grü�e Mexx | ||
Antwort schreiben Antworten: |