Das reicht aber bei weitem nicht... musste mich erstmal Stunden durch etliche Webseiten ackern, doch das hat auch alles nichts gebracht.
Erst als ich die Homebrew Seite gefunden hatte... dann war alles ganz einfach. Musste dann noch ca. 5 Sachen installieren, bis es halbwegs funktionierte (Mountain Lion ist bescheiden schön).
Gut, das .hex File habe ich nun... was mich nur stutzig macht, es sind nur 12 KB (das Caterina-Leonardo.hex ist 78 KB gross). Vielleicht fehlt die USB library?
Und ausserdem, wie kommt das .hex ins Leo ?
Uh, schon wieder 00:40 Uhr. Das hasse ich so an Computer... sie helfen Dir nicht, die rauben Dir die Zeit und den Schlaf = Tod. Ich geh schlafen.
Das HEX-File ist etwas aufgebläht, aus den 78kB werden im Binary-Format "nur" noch 32kB. Die bestehen zur Hauptsache aus 0xFF-Bytes, nur am Anfang und am Ende sind einige kB wirkliche Daten (bzw. Code) enthalten. Deine ca. 6kB kommen somit einigermassen hin, wenn alles am Stück ist. Wieso die beiden Blöcke im Original-Bootloader am Anfang und am Ende aufgesplittet sind, entzieht sich leider meiner Kenntnis. Meine Vermutung wäre, dass der Teil am Anfang der eigentliche Bootloader-Code ist, während der Teil am Ende überschrieben werden kann (und bei entsprechend grossen Sketches auch wird). Was dort allerdings drin enthalten sein soll, entzieht sich meiner Kenntnis.
Ok, also um das zu erreichen was ich vor 4 Tagen wollte (4 Tage habe ich an diesem Mist gesessen^^) ist das hier alles durchzuführen (auf Mac OSX Mountain Lion 10.8.2 clean install):
Ordner "Bootloader-Leonardo" irgendwo anlegen und dort einen Ordner "Source" und "LUFA" erstellen
In den "LUVA" Ordner das neuste LUFA reinpacken
In den Source Ordner kopieren alles was hier drin ist /Applications/Arduino.app/Contents/Resources/Java/hardware/
In den Ordner wechseln: "Bootloader-Leonardo/Source/arduino/bootloaders/caterina"
make clean
make all VID=0x046a PID=0x0011
Beim compilieren erscheint evtl. ein Fehler das LUFA betrifft, dann stimmt der Pfad im makefile ../../../../../../LUFA nicht, und muss auf ../../../../LUFA geändert werden
copy Caterina.hex Caterina-Leonardo_usb_fix.hex
Das .hex File hat dann 11 KB.
Das wars.
So, immer noch mit Fragezeichen:
Wie bekomme ich das .hex in den Leonardo?
Ich würds ja einfach mit meiner Arduino-IDE (Processing like) machen, aber wenn ich im Menü: "Tools-> Bootloader installieren" drücke kommt das:
"avrdude: usbdev_open(): did not find any USB device "usb"
Ich denke mal davon hat auch keiner eine Ahnung?
Ich denke ich muss avrdude per hand starten und die ganzen Parameter angeben... jemand der das schon mal gemacht hat?
Herzlichen Glückwunsch, das Teil bringt dir überhaupt nichts. Der USB-Chip ist nicht ausbaubar und passt außerdem nicht in so eine Fassung. Das gilt für den Leonardo genau so wie für den Uno, nur dass bei letzterem wenigstens der andere Chip, der mit dem eigentlichen Programmcode, entfernt, umprogrammiert und gewechselt werden kann (sofern es nicht die SMD-Variante ist).
Was du brauchst ist ein In-System-Programmer oder ISP. Den kannst du dir notfalls auch aus einem anderen Arduino zusammenbauen, aber der muss auf jeden Fall an die 6 ISP-Pins am rechten Rand vom Arduino angeschlossen werden können.
Und Uwe, deine Beschreibung von VID und PID stimmt auch nicht ganz. VID und PID stellen gemeinsam eine Gerätesignatur dar, die für alle gleichartigen Geräte (und manchmal auch etwas mehr) identisch ist. Der Unterschied ist lediglich, dass die VID vom USB-IF an einzelne Hersteller vergeben wird, welche dann 65536 verschiedene Gerätetypen damit herausgeben können.
DreiMalNull, wenn du soweit bist dass du eine Hex-File draufgebrannt kriegst kannst du ihn beim Schreiben einer falschen Hex-Datei auch ohne weiteres wiederherstellen, wenn er nicht mehr antwortet. Das einzige was du so kaputt machen kannst dass du den Chip mit einem Programmiergerät nicht mehr beschreiben kannst sind die Fuses, und an die solltest du bei deinen Programmieraktionen gar nicht drankommen.
Gut, streng genommen könntest du deinen Chip noch elektrisch zerstören, aber das liegt dann nicht an der falschen Hex-Datei, sondern an falschen Spannungen. Ein ordentliches Programmiergerät sollte sowas aber nicht ermöglichen, wenn du den Stecker richtig draufsteckst.
Ok, gut, dann brauch ich keinen brenner für den Leonardo... nur, was soll ich dann machen? Ich gebe wirklich bald auf, das bringt doch alles nichts.
Habe mit avrdude rumgespielt ( avrdude -c avrispmkII -p atmega32u4 -P /dev/tty.usbmodem1d1311121 -v ) und das hier erhalten:
Last login: Tue Jan 22 13:48:22 on ttys000
meinserver:~ mApple$ avrdude -c avrispmkII -p atmega32u4 -P /dev/tty.usbmodem1d1311121 -v
avrdude: Version 5.11.1, compiled on Jan 22 2013 at 11:44:50
Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
Copyright (c) 2007-2009 Joerg Wunsch
System wide configuration file is "/usr/local/Cellar/avrdude/5.11.1/etc/avrdude.conf"
User configuration file is "/Users/mApple/.avrduderc"
User configuration file does not exist or is not a regular file, skipping
Using Port : /dev/tty.usbmodem1d1311121
Using Programmer : avrispmkII
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: stk500v2_getsync(): timeout communicating with programmer
AVR Part : ATmega32U4
Chip Erase delay : 9000 us
PAGEL : PD7
BS2 : PA0
RESET disposition : dedicated
RETRY pulse : SCK
serial program mode : yes
parallel program mode : yes
Timeout : 200
StabDelay : 100
CmdexeDelay : 25
SyncLoops : 32
ByteDelay : 0
PollIndex : 3
PollValue : 0x53
Memory Detail :
Lustig dabei ist, ich habe ja auch im Internationalen Forum gepostet... und mir wird immer nur die Frage gestellt warum ich da machen will, und ich soll das doch lieber bleiben lassen :=)
Anscheinend mache ich immer das was keiner normalerweise macht^^
Hmmm... also brauch ich doch Hardware zum brennen. Ich werde mal ein paar Arduinos verschalten (habe zig davon) und sehen ob sich damit irgendein programmer ergibt mit dem man was anfangen kann... nur frage ich mich, warum braucht ein Leonardo eine Hardware zum brennen, der hat doch den super neuen 32u2 ... dachte das ist so ein intelligentes flexibles Teil, dass man dazu keine extra Hardware mehr benötigt, so wie beim UNO und Del.
kannst du ihn beim Schreiben einer falschen Hex-Datei auch ohne weiteres wiederherstellen
das ist schon mal gut... habe da negative Erfahrungen mit Android Tabletts = Brick = 500€ futsch und das 2 mal 2x
Du weisst schon, dass Du den Bootloader auch mit der IDE brennen kannst?
Ja, ist ja unter "Tools -> install bootloader"
aber das klappt nicht (wie schon beschrieben)
Wenn Du weisst wie es geht, sag es uns
Du hast uns ja noch nicht verraten, welchen Programmer Du dafür verwendet hast, ob Du den Programmer im Menu richtig eingestellt hast und welches Board Du ausgewählt hast. Alles relevante Faktoren. Ich hab zwar keinen Mac, um das dort zu probieren, aber unter Linux lief's problemlos, wenn alles richtig eingestellt war (ich benutzte einen USBtiny Programmer).
Noch mit keinem programmer. Dachte ja das man beim Leonardo das nicht braucht. Den TinyProgrammer gabs bei www.watterott.com auch für 20€ ... aber ich wusste nicht genau ob der reicht.
DreiMalNull:
Wenn ich überlege... so einen Riesenaufwand um nur mal VID und PID zu ändern^^
Wir leben echt in der Steinzeit.
Sei froh, daß sich damals jemand Gedanken gemacht hat wie man Programme einfach auf den Atmega bekommt ansonsten müßtest Du jeden Sketch über einen ISP-Programmierer Draufspielen.
da hast Du natürlich irgendwo recht, aber auch irgendwie nicht.
Man kennt ja die PC Kisten, oder die alten Handys. Bis dato glaubte man, PC sind nun mal so, dass man ständig daran rumreparieren muss, und von Handys glaubte man auch das es so nicht anders geht.
Bis Apple kam. Ich bin kein Apple Fan... aber so einfach müssen die Dinge sein, und nicht verkompliziert. Die Leute die diese komplizierten Sachen entwickeln sind Ingenieure und Technikfreaks, und keine Anwender. Das ist das Problem (Tunnelblick).
Deshalb ist alles kompliziert. Die verschwenden 99% der Gedanken und Entwicklungsarbeit in die Technik und 1% in Usability und Workflow^^
Apple macht das anders... die Denken von der Usablilty und Workflow abwärts, hinunter zur Technik. 99% der Anderen machen es von der Technik abwärts... und dann "irgendwie benutzen" (siehe Videorekorder
Der Vergleich geht meiner Meinung nach mit 1:0 für Arduino aus.
Die Arduinos sind in erster Linie so konzipiert, dass sie einfach zu bedienen sind. Für die gängigen normalen Sachen. Wie bei den Äppls.
VID und PID ändern sind ja nun schon keine Standardaktionen mehr und dürfte 99,9% der Leonardo User nicht interessieren. Aber es geht, man muss halt etwas mehr Aufwand reinstecken. Mach mal mit dem komischen Eierfon was, was von Äppl nicht direkt vorgesehen ist...