Title: FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 30. March 2016, 14:07:46
Hallo OM's
nach dem ich mich nun einige Tage mit der Programmierung meiner UI-Platine (d.h. Flashen der Software - nicht Porgrammentwicklung) beschäftigt habe, wollte ich Euch meine Erfahrungen kund tun.
Mangels eines Windows Rechners habe ich die FW und den Bootloader unter Linux (OpenSuse 13.1) mit Hilfe eines ST-Link USB Programmier-Adapters draufgespielt.
Meine anfänglichen Probleme lagen daran, dass ich mit dem Kommandozeilen Programm st-flash aus dem Paket ( stlink ) den Bootloader im falschem Format (*.dfu) statt (*.bin) übertragen habe.
Leider ist es dem st-flash Programm egal, in welchem Format die Datei zum MC übertragen wird und es quittiert den Vorgang mit OK.
Erst nach einigem Suchen in den Sourcen habe ich gesehen, dass der Bootloader auch als bootloader.bin vorliegt, jedoch im Verlauf des Buildvorgangs zu einem bootloader.dfu umkonvertiert wird.
Das benötigte Packet ist z.B. bei Suse wie folgt zu installieren:
sudo zypper search stlink (Paket-Suche) sudo zypper install stlink (Packet-Installation)
Danach genügen zwei Kommandos auf der Konsole um die Firmware zum Controller zu übertragen.
st-flash write ./bootloader.bin 0x08000000 und st-flash write ./mcfh.bin 0x08010000
wobei sich beide Dateien in dem Verzeichnis befinden sollen, wo man steht, ansonsten muss der Pfad vollständig angegeben verden.
st-flash write <vollständiger pfad>/bootloader.bin 0x08000000 und st-flash write <vollständiger pfad>/mcfh.bin 0x08010000
Der Flashvorgang sollte mit der Zeile:
2016-03-25T20:21:01 INFO src/stlink-common.c: Successfully loaded flash loader in sram
enden, was den Erfolgreichen Flashvorgang abschließt.
Den ST-Link Programmieradapter bekommt man bei Ebay für ein Paar Euros. Ihr solltet die Version #2 verwenden, da es noch alte Versionen #1 zu kaufen gibt und diese nicht alle ST ARM Controller unterstützen.
Je nach Linux System muss noch vor Benützung des ST-Link Sticks im Verzeichnis /etc/udev/rules.d/ eine Regel als Administrator (root) in einer Datei hinterlegt werden, damit der Stick beim Einstöpseln erkannt wird.
Im meinem Fall steht dieRegel in der Datei '49-stlinkv2.rules' und lautet:
# stm32 discovery boards, with onboard st/linkv2 (Kommentar Zeile 1) # ie, STM32L, STM32F4. (Kommentar Zeile 2) # STM32VL has st/linkv1, which is quite different (Kommentar Zeile 3)
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="3748", \ MODE:="0666", \ SYMLINK+="stlinkv2_%n"
Ohne die '\' am Ende jeder Zeile, kann man die Regel zum Erkennen des ST-Link-Sticks auch in einer Zeile schreiben, was aber etwas un- übersichtlicher ist.
SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483",ATTRS{idProduct}=="3748",MODE:="0666",SYMLINK+="stlinkv2_%n"
So ich hoffe der eine oder andere kann mit dieser Information auch unter Linux den mcfh mit der FW beschreiben.
vy73 Markus DL8MBY
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DC3AX on 07. April 2016, 09:15:59
Hallo,
unter Ubuntu ist dieses Paket nicht bekannt. Allerdings gibt es ein ppa zu einem kleinen grafischen Tool, das die Aufgabe ebenfalls für jeden einfach macht. https://launchpad.net/~fpoussin/+archive/ubuntu/ppa
Installation: ~$ sudo add-apt-repository ppa:fpoussin/ppa ~$ sudo apt-get update ~$ sudo apt-get install qstlink2
Schön gelöst ist, dass auch die udev Regeln automatisch installiert werden. Damit sollten alle STLink-V1 und V2 Boards über eine kleinen grafische Oberfläche programmiert werden können: ~$ qstlink2
Die Oberfläche sollte selbsterklärend sein.
vy 73 de Ulrich
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 07. April 2016, 11:22:21
Danke Uli für die Info.
Ich habe gerade gelesen, das die neuen UI Boards Version 0.5 geinen Debug/Prog Pin-Header mehr haben sollen.
Hat schon jemand die 0.5er PCBs und kann feststellen, wo man da eventuell ein Behelfs-Pin-Header für die Programmierung dranlöten könnte.
Ist ja eigentlich schade, dass dieser Weg nun erschwert wird.
vy73 Markus DL8MBY
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 07. April 2016, 11:29:56
Hallo Uli, und OMs,
Nachtrag zum Post von Uli -> qstlink2.
Das genannte Packet qstlink2 gibt es auch zum bauen in github:
https://github.com/fpoussin/QStlink2
Habe es gerade gefunden.
vy73 Markus DL8MBY
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DF8OE on 07. April 2016, 11:32:38
"Eigentlich" ist eine sehr rücksichtsvolle Benennung dieser Tatsache - das ist meine Meinung dazu...
Ich vergleiche die 0.5er Version der PCBs daher mit "Windows Vista". Keiner wollte es (außer dem Hersteller selbst) und die Akzeptanz war (vorsichtig ausgedrückt) sehr gering.
vy 73 Andreas |
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 07. April 2016, 13:58:14
Hallo Andreas,
ich habe mir ja zwei Sätze der Version 0.4 vor Wochen geordert. Mangels Erfahrung, wie weit das Projekt vorangekommen ist und der ständigen Zunahme der Änderungen in Deiner Liste, wollte ich vorsichtig agieren ;-)
Nun habe ich aber doch Blut geleckt und wollte noch zwei weitere Geräte aufbauen und meinen befreundeten OM's zum Spielen vermachen.
Habe gestern zwei weitere Plaitiensätze bestellt und bin gespannt, welche Version im Päckchen aus UK enthalten sein wird.
Da ja die HW offen ist, kann man sich eigentlich gleich selber eine UI und RF Platine nach dem Vorbild machen, aber dann in vier Lagen, was die Layout-Situation etwas entspannt.
Ein Board mit 20x15cm² mit zwei Nutzen drauf und in 5facher Ausführung würde etwas über 170US$ kosten, so meine letzte Recherche auf mikrocontroller.net, Platinen. (den ganzen Link habe ich leider auf dem Rechner daheim.)
Der nächste Winter kommt bestimmt ;-)
Aber erst muss ich kleinere Brötchen backen und die RF-Platine bestücken. Danach kommt noch ein ansehnliches Gehäuse Marke Eigenbau.
vy73 Markus DL8MBY
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DB4PLE on 07. April 2016, 16:06:33
Hallo,
Alles falsch was hier stand, siehe EDIT unten.
ich habe hier ein 0.5 PCB. Und da sind sehr wohl die Debug-Header drauf. Aber eben auch die Verbindung dieser Pins zum Touchpanel (über 0R).
D.h man muss nicht die Debug-Fähigkeiten verlieren, aber es gibt andererseits auch keine einheitliche Linie, auf die sich alle einigen können. Denn auf Developermaschinen mit ST-Link ginge dann kein Touch. Das ist natürlich sehr, sehr unschön. Kann man alles irgendwie lösen, wäre aber nicht notwendig gewesen. Fairerweise muss man sagen, das vermutlich zu dem Zeitpunkt als die 0.5 Revision gemacht wurde, den ST-Link aktiv benutzt hat.
Trotzdem keine gute Idee, den einzig vernünftigen Debugzugang zu kappen, insbesondere möglicherweise bei den vorbestückten Boards (das weiß ich aber nicht, da ich kein solches Board habe).
Um bei der Analogie von Andreas zu bleiben, jede 2. Version Microsoft ware eigentlich eine ordentliche Verbesserung (XP - [Vista] - 7 - [8.x] - 10). Verrückt, Microsoft als Vorbild :-)
73 Danilo
EDIT: Ich habe das Board noch nicht aufgebaut und hatte aus dem Vorhandensein des P8 auf dessen identische Funktion geschlossen. Aber weit gefehlt. Hätte mir die Schaltung mal genauer anschauen sollen. Nicht nur dass das Debug-Interface entfernt wurde, es wurden auch noch alle bisherigen Daten-Pins auf Masse gelegt (auch die vom Debug-Interface getriebenen Pins, d.h. u.U. zerstört man seine Debug HW (habe nicht vor das zu prüfen). Siehe http://www.m0nka.co.uk/wp-content/uploads/2016/03/mcHF_ui.pdf (https://uk.groups.yahoo.com/neo/groups/M0NKA-mcHF/conversations/messages/6046]https://uk.groups.yahoo.com/neo/groups/M0NKA-mcHF/conversations/messages/6046[/url] und [url=http://www.m0nka.co.uk/wp-content/uploads/2016/03/mcHF_ui.pdf) Seite 2 links unten P8 Now I am officially disappointed.
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DF8OE on 07. April 2016, 20:26:09
Die Welt ist halt verrückt - und Humor ist, wenn man lacht und es nicht persönliche nimmt oder jemanden dafür verantwortlich macht :)
Jeder von uns sollte in der Lage sein, ein paar Drähte zu ziehen.
Übrigens lasse ich meine Platinen bei LeitOn in Berlin fertigen. Faire Preise, elektronisch geprüft, und liefern Standard in ca. 4 Wochen, wenn Du mehr löhnst, auch schneller.
vy 73 Andreas |
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 08. April 2016, 09:30:08
Hallo Andreas,
was kostet Dich eine vier-Lagen Europakarte bei kleiner Stückzahl.
Machen die auch Protoytping?
vy73 Markus DL8MBY |
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DF8OE on 08. April 2016, 10:02:17
Ja, machen sie.
Und es gibt einen Online-Preiskalulator
http://www.leiton.de (http://www.leiton.de)
vy 73 Andreas |
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 08. April 2016, 12:03:59
Hallo Andreas,
im Preiscalculator konnte ich aber nur 2-Lagen Produkte finden. Unterschiedliche Materialien FR4, Roggers, Flex und Alu aber keine Einstellmöglichkeit für mehr als zwei Lagen.
Gruß Markus
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DF8OE on 08. April 2016, 14:08:55
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 08. April 2016, 16:51:40
Sorry Andreas,
klappt nicht.
Muss man eventuell registriert sein?
Siehe meinen Output!
Markus
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 08. April 2016, 16:54:32
Sorry #2,
übersehen - Javascript Abgeschaltet!
Wer lesen kann ....
Jetzt klappt es.
Markus DL8MBY
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: dl8mby on 08. April 2016, 17:04:31
Hallo Andreas,
zwei Platinen 190x75 mit vier Lagen liegen (mit BestückungsDruck, sonst 50€ günstiger) bei ca. 215€ Brutto.
Finde ich einen guten Preis für DE Fertigung.
Siehe Anhang.
|
Title: Re:FW und Bootloader Programmierung unter Linux
Post by: DF8OE on 08. April 2016, 21:50:24
ich weiß. Deswegen habe ich den Link auch geteilt.
Ich lasse lieber in DL fertigen und die Chemierückstände landen nicht ungefiltert im nächsten Dorfteich (oder im Trinkwasser). Und die Qualität ist SUPER. Ich habe dort schon viel fertigen lassen - noch nie Streß gehabt.
vy 73 Andreas |
Diskussions- und Newsboard des DARC-Ortsverbandes I40 | Powered by YaBB SE
© 2001-2003, YaBB SE Dev Team. All Rights Reserved.
|