200 likes | 387 Views
UEE072HM. Linking HLL and ALP An example on ARM. Embedded and Real-Time Systems. We will mainly look at embedded systems Systems which have the computer system embedded within their application area, normally using a specialised single board computer (SBC)
E N D
UEE072HM Linking HLL and ALP An example on ARM
Embedded and Real-Time Systems • We will mainly look at embedded systems • Systems which have the computer system embedded within their application area, normally using a specialised single board computer (SBC) • There is a difference between embedded and real-time – one does not imply the other • Hard real-time vs soft real-time
Embedded Systems Development • Embedded systems require host-target development – this means • The development is done on a different machine than the target • The code must be downloaded to run • Can be running on different CPU and architecture
Host Target Development Target boards Development Host (Linux?)
Embedded Systems Development • Embedded systems development requires • Mixed language programming – HLL plus assembler • Increased knowledge of tools – compiler, linker and librarians • Use of specialised tools – i.e. down loaders • Special skills to debug code
Using C for Embedded Systems #define ADDRESS 0xFFFF41 main() { char *mem_p; mem_p=(char*)ADDRESS; while !(*mem_p ) ;// do nothing } • A major requirement is for direct memory access, this is achieved using pointers. • This style of code is quite common
Using C for Embedded Systems #define ADDRESS 0xFFFF41 #define MASK 0x3 main() { volatile char *mem_p; mem_p=(char*)ADDRESS; while !(*mem_p & MASK ) ;// do nothing } • Note • Use of # define • Use of char * • Use of volatile • Casting of return value • Use of binary op &
Using C for Embedded Systems • Using C in Embedded Systems you will need to know more about • Compilation process • Linking • Storage issues
Using C for Embedded Systems • Compilation issues • Passing parameters • Naming conventions • Symbol table and map generation • Assembler output
Why use HLL? • Why do high level language programmers need to know the low level details of storage and function calls? • To write more efficient code • To write assembler routines that are called from a HLL • To call assembler routine from a HLL • Improves knowledge of both tools and CPU
Why use ALP? • Why use assembler in place of HLL? • Speed up code • Smaller code • Special instructions • Boot strap routines • Optimise HLL code
Using C for Embedded Systems • Ways to link HLL & ALP - passing parameters • Parameter blocks • No recursion • Using registers • Limited numbers of registers • Using the stack • Most favoured method • Many use a combination of the above
The run-time stack • In order to see how HLLs are implemented we need to know about the run-time stack and the registers that control it. • The stack is used for • Storing important values that may get changed during execution • Local variables • Passing some function parameters
In C function set up consists of Creating an executable label Saving the stack pointer into ip Storing registers used onto the stack Using stmfd store multiple registers instructions Putting the frame pointer at the stack base Function set-up gcc2_compiled.:.text .align 2 .global main .type main,functionmain: @ args = 0, pretend = 0, frame = 8 @ frame_needed = 1 mov ip, sp stmfd sp!, {fp, ip, lr, pc} sub fp, ip, #4
Registers Low memory SP Stack Pointer PC LR IP FP Frame Pointer FP High memory IP Intra-Procedure Function set-up Stack
Local variables • The stack is used for local variable storage • The compiler creates a stack frame to store the variables • The variables are accessed by an offset from the frame pointer fp • This means • variable names can be repeated • functions can be recursively called
mov ip, sp stmfd sp!, {fp, ip, lr, pc} sub fp, ip, #4 sub sp, sp, #8mov r3, #10 str r3, [fp, #-16] mov r3, #20 str r3, [fp, #-20] main() { int i , j; i = 10; j = 20; Initialise Variable i } } Initialise Variable j Creating a stack frame Create the Stack frame
A stack frame Registers Low memory SP Stack Pointer j 20 FP - 20 i 10 FP - 16 PC LR IP FP Frame Pointer FP High memory IP Intra-Procedure
Leaving a function call • The code to leave a function call is simple • ldmea • Load multiple registers command is used from the stack • The old • frame & stack pointers & program counter • are restored • This does a return with a cleaned stack .L2: ldmea fp, {fp, sp, pc}.Lfe1: .size main,.Lfe1-main
@ Generated by gcc 2.95.3 20010315 (release) for ARM/elf .file "ex1.c"@ GNU C version 2.95.3 20010315 (release) (arm-linux) compiled by GNU C version 2.95.2 20000220 (Debian GNU/Linux).@ options passed: -fverbose-asm@ options enabled: -fpeephole -ffunction-cse -fkeep-static-consts@ -freg-struct-return -fsjlj-exceptions -fcommon -fverbose-asm -fgnu-linker@ -fargument-alias -fident -mapcs-32 -mshort-load-bytes -mno-short-load-wordsgcc2_compiled.:.text .align 2 .global main .type main,functionmain: @ args = 0, pretend = 0, frame = 8 @ frame_needed = 1, current_function_anonymous_args = 0 mov ip, sp stmfd sp!, {fp, ip, lr, pc} sub fp, ip, #4 sub sp, sp, #8mov r3, #10 str r3, [fp, #-16] mov r3, #20 str r3, [fp, #-20] mov r0, #1mov r1, #2 mov r2, #3 mov r3, #4 bl do_it.L2: ldmea fp, {fp, sp, pc}.Lfe1: .size main,.Lfe1-main