- LiFePO4 Speicher Test         
Ergebnis 1 bis 5 von 5

Thema: TWI Slave mit avr-gcc

  1. #1

    TWI Slave mit avr-gcc

    Anzeige

    Powerstation Test
    Hi RN Community

    Ich bin über das Thema TWI_Slave_mit_avr-gcc von euch gestolpert.
    Dies habe ich natürlich gleich ausprobiert.
    Ich benutze 2 Atmega128. Soweit funktioniert auch alles.
    Ich kann von dem einen atmega128 im mastermodus die daten zum Slave schicken. Dieser ändert auch seine "Register".
    Doch das Auslesen funktioniert irgendwie bei mir nicht wie es in der Doku beschrieben ist.
    Also : Start(Slave+write) -> write (register ) -> Repstart (Slave+read) -> readack -> readack -> readnack -> stop.

    Ich habe aber herausgefunden (da in der Slaveimplementierung beim Stop && || beim Start-ST-Modus das Register nicht wieder auf 0xFF gesetzt wird) dass ich so trotzdem meine Daten bekomme, da der Slave auch bei erneutem Start noch die alte angefragte Registeradresse kennt.
    Also : Start(Slave+write) -> write (register ) ->STOP -> Start (Slave+read) -> readack -> readack -> readnack -> stop.

    Wie bekomme ich aber nun den Repstart zum laufen !?
    Sobald der Repstart kommt wird die SCL Leitung auf LOW gezogen und der BUS hängt.
    Ich habe beim Slave die Switch Case anweisungen debuggt und im Falle des REpstarts geht der Slave in den DEFAULT CASE was ich nicht verstehe wieso er das tut.

    Ich hoffe es hat jemand eine idee zur Lösung meines Problems.

    Vielen Dank schoneinmal im Voraus

    mfg
    nfs2k

  2. #2
    Erfahrener Benutzer Begeisterter Techniker Avatar von Chypsylon
    Registriert seit
    02.02.2011
    Ort
    Graz/Österreich
    Beiträge
    256
    Das gleiche Problem ist schon öfters mit dem Beipsiel aus RN-Wissen aufgetaucht (z.B. bei mir und oberallgeier hier).

    Es wäre vermutlich am einfachsten wenn du auf eine andere Library wie z.B. die von Jtronics zurückgreifst die eigentlich gleich aufgebaut ist...

  3. #3
    Erfahrener Benutzer Robotik Visionär Avatar von oberallgeier
    Registriert seit
    01.09.2007
    Ort
    Oberallgäu
    Beiträge
    8.686
    Zitat Zitat von Chypsylon Beitrag anzeigen
    Das gleiche Problem ist schon öfters mit dem Beipsiel aus RN-Wissen aufgetaucht ...
    Wie schon erwähnt (klick hier) läuft bei mir die fleury-Lib hervorragend. Probier mal vor dem repstart bzw. nach dem Schreiben der Buffer-Startadresse ein i2c_stop . . .
    Ciao sagt der JoeamBerg

  4. #4
    Benutzer Stammmitglied Avatar von KR-500
    Registriert seit
    26.12.2007
    Alter
    29
    Beiträge
    91

    Beitrag

    Hallo zusammen,

    dieser Thread ist zwar schon etwas älter, aber ich bin jetzt letztens auch auf das Problem mit dem nicht funktionierenden repeated start gestoßen. Ich bin auf zwei Fehler gestoßen, nach dem beheben dieser Fehler läuft der Slave auch mit dem repeated start bzw. überhaupt. Es wäre schön wenn dies jemand auch im Wiki ändern könnte.

    1.Fehler:
    Code:
    TWAR= (adr << 1); //Adresse setzen um 1 bitshiften wegen TWAR register (siehe Datenblatt!)
    Dies ist so Falsch, wenn man die Adresse um eins nach links shiftet schneidet man ein Bit der Adresse ab, richtig wäre:

    Code:
    TWAR= adr; //Adresse setzen

    2. Fehler:
    Code:
    switch (TW_STATUS) //TWI-Statusregister prüfen und nötige Aktion bestimmen 
        {
    
            ...
    
            case TW_ST_DATA_NACK: // 0xC0 Keine Daten mehr gefordert 
            case TW_SR_DATA_NACK: // 0x88 
            case TW_ST_LAST_DATA: // 0xC8  Last data byte in TWDR has been transmitted (TWEA = “0”); ACK has been received
            case TW_SR_STOP:      // 0xA0 STOP empfangen
            default:     
                TWCR_RESET;
            break;
        } //end.switch (TW_STATUS)
    Laut Datenblatt ist dies der Code für den Empfang einer Stop, bzw einer Repeated Start Bedingung, jetzt bin ich mir nicht mehr so sicher, aber mit dieser Lösung funktioniert es:

    Code:
    switch (TW_STATUS) //TWI-Statusregister prüfen und nötige Aktion bestimmen 
        {
            case TW_SR_STOP:
                TWCR_ACK;
            break;
            ...
    
            case TW_ST_DATA_NACK: // 0xC0 Keine Daten mehr gefordert 
            case TW_SR_DATA_NACK: // 0x88 
            case TW_ST_LAST_DATA: // 0xC8  Last data byte in TWDR has been transmitted (TWEA = “0”); ACK has been received
            default:     
                TWCR_RESET;
            break;
        } //end.switch (TW_STATUS)
    Viele Grüße
    KR-500

  5. #5
    Erfahrener Benutzer Begeisterter Techniker Avatar von Chypsylon
    Registriert seit
    02.02.2011
    Ort
    Graz/Österreich
    Beiträge
    256
    @KR-500: Ist gemacht. Danke für die Lösung

Ähnliche Themen

  1. Slave Transmitter und Slave Receiver Mode
    Von masasibe im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 1
    Letzter Beitrag: 26.02.2011, 20:55
  2. I2C Slave
    Von Jada im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 1
    Letzter Beitrag: 19.06.2010, 12:47
  3. Slave-Master-Slave übertragung geht nicht
    Von Dämmi im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 16
    Letzter Beitrag: 26.11.2008, 01:08
  4. I2C-Slave
    Von liggi im Forum C - Programmierung (GCC u.a.)
    Antworten: 1
    Letzter Beitrag: 02.01.2008, 17:02
  5. AVR als I²C Slave?
    Von Schokohoernl im Forum Elektronik
    Antworten: 4
    Letzter Beitrag: 28.05.2006, 20:58

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

Solar Speicher und Akkus Tests