Forum: Mikrocontroller und Digitale Elektronik Protokoll v. Bootloader AVR109 / Butterfly


von Εrnst B. (ernst)


Lesenswert?

Hallo,

Ich schreib gerade einen Bootloader für einen Tiny2313.
Auf RS232 Seite spricht er das Butterfly / Avr109 Protokoll.

Klappt soweit auch alles, lässt sich problemlos mit avrdude
ansprechen.

Problem ist jetzt:
mit avrdude im Konsolenmodus stimmt die "dump flash" ausgabe exakt
mit der über ISP gelesenen überein, ein Verify-Lauf mit dem Hex file
geht aber nur über ISP, über den bootloader ist schon das erste byte
falsch.

Der einzige Unterschied, den ich gefunden hab ist, das avrdude beim
dump-Befehl über die Konsole das Flash in 2 Byte Stückchen ausliest,
beim Verify aber immer eine ganze Page (32 Byte) auf einmal.

Implementiert war das Auslesen bei mir zuerst wie folgt:
1
  while (size--) {
2
       boot_sendchar(pgm_read_byte(address++));
3
  }
Damit war allerdings die dump-ausgabe "falschherum", habs also
geändert in:
1
    while (size) {
2
            boot_sendchar(pgm_read_byte(address+1));
3
            boot_sendchar(pgm_read_byte(address));
4
      address += 2;
5
      size -= 2;
6
          }

Ich verdreh also immer je zwei Bytes, danach stimmt die Byteorder beim
"dump flash".

Der AVR-Butterfly Bootcode macht das so:
1
do {
2
  data = read_program_memory(address,0x00);
3
  sendchar((char)data);  //send LSB
4
  sendchar((char)(data >> 8));  //send MSB  
5
  address += 2;  
6
  size -= 2;
7
} while (size);

Soo falsch kann da meine Version doch nicht sein, oder?
Hat da vielleicht der avrdude einen dreher drinnen?

Hat vielleicht jemand einen Butterfly + avrdude und könnte mal testen,
ob bei ihm sowohl verify als auch der direkte dump in der konsole
geht?

Ich hab avrdude 5.1 laufen, das Problem tritt mit "-c avr109" als
auch mit "-c butterfly" auf.

Vielleicht hat ja jemand nen Tipp für mich...

Danke,
/Ernst

von Klaus Leidinger (Gast)


Lesenswert?

Hallo Ernst,

ja, sieht nach einem Bug im avrdude Terminalmodus aus. Er
berücksichtigt nicht, das im avr109 (butterfly) Mode die Bytes
vertauscht sind.

wenn ich mit -c avr910 aufrufe, stimmt die Reihenfolge (ich habe beide
Protokolle implementiert).

HTH,
Klaus

von Εrnst B. (ernst)


Lesenswert?

Danke, Klaus.

Gut zu wissen, nur schade um die halbe Nacht die ich daran gedebugged
hab.

Den 910er Modus kann ich leider nicht direkt verwenden, da fehlt mir
die  Initialisierung mit ESC-S mit der ich von der normalen Seriellen
Verarbeitung in den bootloader springe.

Aber solang nur der konsolen-modus kaputt ist, ist das ja kein größeres
Problem.

/Ernst

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
Noch kein Account? Hier anmelden.