Využítí ARM GCC vývojového retezce

| Kategorie: Diplomové, bakalářské práce  | Tento dokument chci!

Předmětem této práce je studium stávajícího vývojového řetězce pro mikroprocesor LPC23xx v předmětu MPOA. Hlavním cílem je zkoumání možností realizace nového vývojového řetězce, postaveného na GCC. Výstupy této práce jsou ukázkové aplikace s mikroprocesorem LPC2378 a GCC. Součástí vysledků jsou i návody pro studenty, jak tyto ukázkové aplikace implementovat. Ukázky zahrnují základní aplikace, RTOS aEthernet.

Vydal: FEKT VUT Brno Autor: Jan Ledvina

Strana 29 z 93

Vámi hledaný text obsahuje tato stránku dokumentu který není autorem určen k veřejnému šíření.

Jak získat tento dokument?






Poznámky redaktora
Samotný kód obou funkcí jejich prototypy jsou uvedeny příloze C. Tyto chyby byly odstraněny vypuštěním částí kódů, kde vznikaly.1 FreeRTOS První aplikací oblasti pokročilejších bylo základní zprovoznění jádra RTOS. Nejprve docházelo chybám při překladu.h.5 Realizace pokročilejších aplikací Tato podkapitola již věnuje úlohám náročnějšími aplikacemi. Výsledný projekt touto aplikací opět elektronické příloze. Jelikož tato aplikace jen částí úlohy, návod spojen návodem druhé aplikaci. Pro tuto realizaci třeba provést propojení mezi jazykem ASM. Tento soubor vkladán preprocesorem jednotlivých modulů, které mohly využít tuto funkci. Návod tedy příloze D. Bylo opět jasné, někde zásadní systematická chyba. Poté povedlo aplikaci zkompilovat nahrát MCU, avšak nic nestalo. základě dokumentace k projektu FreeRTOS byl vytvořen nový projekt, kterého byly postupně přidávány klíčové soubory jádra RTOS. Funkce byly uspěšně ověřeny byly přidány modulu irq. Přesné úkoly aplikací byly opět převzaty zadání počítačových cvičení předmětu MPOA pro zimní semestr 2011/2012. Pokud tedy modul bude tuto funkci volat, překladač jejího prototypu zjisti, že: extern funkce jiném modulu inline funkce měla být přeložena jako In-Line, pokud použije optimalizace void žádné předávání parametrů __attribute__ ((always_inline)) funkce vždy přeloží jako inline, nezavisle na optimalizaci Na závěr ještě vysvětlení kódu samotné funkce. Toto propojení velice jednoduché. Prvním pokusem tímto systémem bylo zprovoznit demo aplikaci pro MCU LPC2368. 3.22 Důvody proč prototyp funkce vypadá takto jsou následující.5. 3. Jedná RTOS, Ethernet USB.c. Rovněž ani žádná další ukázková aplikace. Místo registru použije virtuální „proměnná“ %0 (nula) viz ukázka. Tato aplikace však nepodařila rozběhnout. Bylo zjištěno, startu jádra RTOS dojde „pádu“ aplikace. vytvoření nejnutnější kostry byly vytvořeny . konci kódu provede přiřazení této proměnné proměnné jazyka Detailní popis této problematiky lze nalézt dokumentaci GCC [14] v kapitole sekcích In-Line Function, Extended Asm, Constrains Assembler Instruction with Expression Operands.3. Jednalo o nepodstatné části kódů. této práci byl zvolen projekt FreeRTOS. Aby překladač dostal maximální volnost pro případné optimalizace, vhodné funkci napsat tak, aby nezasahovala do konkrétních registrů MCU, ale aby překladač mohl rozhodnout tom, který registr bude použit. Prototyp deklarován v hlavičkovém souboru irq.3. Tato druhá aplikace principiálně stejná, avšak využívá již RTOS. Na základě této dokumentace tedy povedlo napsat obě funkce, jak pro vypnutí, tak pro zapnutí přerušení