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

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
Ich nutze:
CC2-ReglerBoard
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: