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