cs:arm_programming
Rozdíly
Zde můžete vidět rozdíly mezi vybranou verzí a aktuální verzí dané stránky.
Předchozí verze | |||
cs:arm_programming [2014/01/17 19:11] – [Kompilátor] kaklik | — | ||
---|---|---|---|
Řádek 1: | Řádek 1: | ||
- | ====== Programování procesorů ARM STM32 ====== | ||
- | |||
- | |||
- | Pro používání procesorů ARM je nejlepší pracovat v operačním systému Linux, proto následující návod popisuje instalaci a využití nástrojů pro práci s ARM v tomto systému. | ||
- | |||
- | Veškeré zde užité programové vybavení je dostupné zdarma. | ||
- | |||
- | |||
- | |||
- | ===== Kompilátor ===== | ||
- | |||
- | Jako volně dostupný kompilátor se může použít GNU C Compiler, dostupný v git repositáři [[https:// | ||
- | |||
- | == Rychlá instalace pomocí repositáře == | ||
- | |||
- | sudo add-apt-repository ppa: | ||
- | sudo apt-get update | ||
- | sudo apt-get install gcc-arm-none-eabi | ||
- | | ||
- | Pokud si nechcete do systému přidávat nový PPA repozitář, | ||
- | | ||
- | | ||
- | == Postup kompilace == | ||
- | |||
- | V terminálu je potřeba se nacházet ve složce, kde se nachází soubory potřebné pro kompilaci a následně stačí zadat příkaz make. | ||
- | | ||
- | ===== Programovací GUI ===== | ||
- | |||
- | Programovací prostředí v kterém je vytvářen zdrojový kód. Mezi uživateli jsou nejoblíbenější následující dvě volby. Jinak lze ale zdrojový kód psát v libovolném textovém editoru. | ||
- | |||
- | ==== Sublime text ==== | ||
- | |||
- | Je placený editor pro linux mezi jeho vyjímečné vlastnosti patří například náhled celého zdrojového kódu. | ||
- | |||
- | [[http:// | ||
- | |||
- | ==== Code:: | ||
- | |||
- | Jde o velmi rozřířený editor, jehož výhodou je, že běží na více platformách a mohou ho tedy používat i uživatelé windows. | ||
- | |||
- | [[http:// | ||
- | |||
- | sudo apt-get install codeblocks | ||
- | | ||
- | | ||
- | ===== Knihovny periférií ===== | ||
- | |||
- | Protože nastavení a obsluha | ||
- | |||
- | ==== STM32F10X standard peripheral library ==== | ||
- | |||
- | Úplná proprietární knihovna od STMicroelectronics, | ||
- | |||
- | Dostupná ke stažení na [[http:// | ||
- | |||
- | ==== libopencm3 ==== | ||
- | |||
- | Nová open-source knihovna, prostorově úsporná a s lepším rozhraním, která je ale zatím neúplná (avšak pod aktivním vývojem). | ||
- | |||
- | [[http:// | ||
- | |||
- | ===== Zápis přeloženého kódu ===== | ||
- | |||
- | Po přeložení zdrojového kódu je potřeba výsledný binární program zapsat do FLASH paměti mikroprocesoru. To lze udělat několika způsoby. Podle toho, jaký konkrétní procesor ARM máme a jak je konstruovaná elektronika ve které je procesor osazený. | ||
- | |||
- | ==== Modul STM32F10xRxT01A ==== | ||
- | |||
- | === Sériový bootloader === | ||
- | |||
- | Booloader může být použit na rozhraních USART1, USART2, CAN2 nebo USB. Všechny typy ARM ale nepodporují všechny typy. Dále může být bootloader použit pouze v případě užití konkrétních frekvencí krystalů. | ||
- | |||
- | * USART pracuje s interním 8 MHz oscilátorem | ||
- | * CAN a USB OTG FS funguje pouze s externími oscilátory 8 MHz, 14.7456 MHz nebo 25 MHz | ||
- | |||
- | |||
- | Užití bootloaderu je výhodné v případech, | ||
- | |||
- | Pro aktivaci bootloaderu držte tlačítko BOOT, zmáčkněte tlačítka RESET a poté hned pusťte tlačítko BOOT. | ||
- | S bootloaderem se může komunikovat přes USB nebo přes UART (např. programem [[http:// | ||
- | |||
- | == Připojení modulu == | ||
- | |||
- | Pro použití sériového bootloaderu je třeba modul připojit na seriovou linku. V případě použití modulu [[cs: | ||
- | |||
- | |||
- | ^ USB232R01B ^ STM32F10xRxT01A | ||
- | | TXD | PA10 | | ||
- | | RXD | PA9 | | ||
- | |||
- | Ostatní signály DTR a RTS si na modulu zapojují profesionálové, | ||
- | (Tato funkce vyžaduje upravený stm32flash, který se však asi podařilo ztratit) | ||
- | |||
- | == Kompilace stm32flash == | ||
- | |||
- | svn checkout http:// | ||
- | cd stm32flash-read-only | ||
- | make | ||
- | sudo make install | ||
- | |||
- | |||
- | Příklad použití: | ||
- | |||
- | sudo stm32flash / | ||
- | | ||
- | stm32flash - http:// | ||
- | | ||
- | Serial Config: 57600 8E1 | ||
- | Version | ||
- | Option 1 : 0x00 | ||
- | Option 2 : 0x00 | ||
- | Device ID : 0x0418 (Connectivity line) | ||
- | RAM : 64KiB (4096b reserved by bootloader) | ||
- | Flash : 256KiB (sector size: 2x2048) | ||
- | Option RAM : 15b | ||
- | System RAM : 18KiB | ||
- | | ||
- | Resetting device... done. | ||
- | |||
- | |||
- | Nahravani programu vypada napriklad takto: | ||
- | |||
- | $ ./ | ||
- | stm32flash - http:// | ||
- | | ||
- | Using Parser : Intel HEX | ||
- | Serial Config: 57600 8E1 | ||
- | Version | ||
- | Option 1 : 0x00 | ||
- | Option 2 : 0x00 | ||
- | Device ID : 0x0414 (High-density) | ||
- | RAM : 64KiB (512b reserved by bootloader) | ||
- | Flash : 512KiB (sector size: 2x2048) | ||
- | Option RAM : 15b | ||
- | System RAM : 2KiB | ||
- | | ||
- | Wrote and verified address 0x08000c48 (100.00%) Done. | ||
- | Starting execution at address 0x08000000... done. | ||
- | | ||
- | === USB bootloader === | ||
- | |||
- | [[http:// | ||
- | |||
- | == Zapojení == | ||
- | |||
- | Pro aktivaci bootloaderu přes USB musíte připojit Vcc (+3,3 V) na nožičku PA9. Spuštění bootloaderu se provádí sekvencí tlačítek: stiskni RESET, stiskni BOOT, pusť RESET, pusť BOOT. Že je mikroprocesor přepnutý do DFU módu lze zkontrolovat přikazem lsusb: | ||
- | |||
- | $ lsusb | ||
- | Bus 003 Device 007: ID 0483:df11 STMicroelectronics STM Device in DFU Mode | ||
- | |||
- | Dále je dobré si zkontrolovat, | ||
- | |||
- | |||
- | Dávka pro volání dfu-util pro platformu Windows a přeložená verze dfu-util bez potřeby dalších knihoven je uložena v dokumentační složce modulu [[cs: | ||
- | |||
- | Příklad volání dfu-util: | ||
- | |||
- | dfu-util -d 0483:df11 -a 0 -D ./ | ||
- | | ||
- | Popis parametrů příkazu | ||
- | |||
- | - // | ||
- | - // | ||
- | |||
- | Nahrání firmware si můžete vyzkoušet pomocí tohoto vzorového bináru, který z procesoru STM32F107 udělá USB HID myš, která opisuje kolečko: [[http:// | ||
- | |||
- | Přímo z klonu MLAB svn repozitáře se nahrání přeloženého bináru // | ||
- | |||
- | $ sudo ./dfu-util -d 0483:df11 -a 0 -D ../ | ||
- | | ||
- | je však potřeba v terminálu být na správné cestě. tj. například // | ||
- | | ||
- | ==== J-TAG ==== | ||
- | |||
- | Jtag lze použít téměř s libovolným ARM mikroprocesorem. | ||
- | |||
- | K programování přes JTAG je potřeba externí programátor. Na modulu [[cs: | ||
- | |||
- | Modul JTAGFT2232V02A lze ovládat například programem [[http:// | ||
- | |||
- | |||
- | ===== RTOS operační systém ===== | ||
- | |||
- | ==== Chibios ==== | ||
- | |||
- | [[http:// | ||
- | |||
- | Jde o základní relaltime operační systém s HAL zjednodušující práci s mikroprocesorem. Pro snazší práci byla vytvorena kofigurace Chibios přímo pro modul s ARM dostupná je na [[https:// | ||
- | |||
- | Další programová dokumentace je dostupná [[http:// | ||
- | === Demo blikání LED === | ||
- | |||
- | #include < | ||
- | #include < | ||
- | | ||
- | int main(void) { | ||
- | | ||
- | halInit(); | ||
- | chSysInit(); | ||
- | | ||
- | while (TRUE) { | ||
- | palTogglePad(GPIOB, | ||
- | chThdSleepMilliseconds(250); | ||
- | | ||
- | } | ||
- | } | ||
- | |||
- | |||
- | |||
cs/arm_programming.txt · Poslední úprava: 2015/03/30 16:37 (upraveno mimo DokuWiki)