FreeCalypso > hg > freecalypso-tools
changeset 197:dbb54db721d1
target-utils/flash-boot-test written
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 30 Apr 2017 17:40:26 +0000 (2017-04-30) |
parents | 47d56330609d |
children | 06c629b34903 |
files | target-utils/flash-boot-test/Makefile target-utils/flash-boot-test/cmdtab.c target-utils/flash-boot-test/ld.script target-utils/flash-boot-test/magic0.S target-utils/flash-boot-test/magic1.S target-utils/flash-boot-test/main.c target-utils/flash-boot-test/mygetchar.c target-utils/flash-boot-test/uartbase.S target-utils/flash-boot-test/vectors.S |
diffstat | 9 files changed, 172 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/Makefile Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,33 @@ +CC= arm-elf-gcc +CFLAGS= -Os -fno-builtin +CPPFLAGS=-I../include +LD= arm-elf-ld +OBJCOPY=arm-elf-objcopy + +OBJS= vectors.o crt0.o cmdtab.o main.o mygetchar.o uartbase.o +LIBS= ../libcommon/libcommon.a ../libprintf/libprintf.a ../libbase/libbase.a \ + ../libc/libc.a +LIBGCC= `${CC} -print-file-name=libgcc.a` +LDS= ld.script + +all: fbt-mode0.bin fbt-mode1.bin + +crt0.S: ../env/crt0.S + ln -s $< . + +fbt-mode0.elf: ${OBJS} magic0.o ${LIBS} ${LDS} + ${LD} -N -T ${LDS} -o $@ ${OBJS} magic0.o ${LIBS} ${LIBGCC} + +fbt-mode0.bin: fbt-mode0.elf + ${OBJCOPY} -O binary $< $@ + +fbt-mode1.elf: ${OBJS} magic1.o ${LIBS} ${LDS} + ${LD} -N -T ${LDS} -o $@ ${OBJS} magic1.o ${LIBS} ${LIBGCC} + +fbt-mode1.bin: fbt-mode1.elf + ${OBJCOPY} -O binary $< $@ + +clean: + rm -f *.o *errs *core *.elf *.bin *.srec crt0.S + +FRC:
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/cmdtab.c Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,32 @@ +#include "cmdtab.h" + +extern void cmd_abbr(); +extern void cmd_abbw(); +extern void cmd_jump(); +extern void cmd_r8(); +extern void cmd_r16(); +extern void cmd_r32(); +extern void cmd_w8(); +extern void cmd_w16(); +extern void cmd_w32(); + +extern void cmd_memdump_human(); + +extern void abb_init(); +extern void abb_power_off(); + +const struct cmdtab cmdtab[] = { + {"abbinit", abb_init}, + {"abbr", cmd_abbr}, + {"abbw", cmd_abbw}, + {"dump", cmd_memdump_human}, + {"jump", cmd_jump}, + {"poweroff", abb_power_off}, + {"r8", cmd_r8}, + {"r16", cmd_r16}, + {"r32", cmd_r32}, + {"w8", cmd_w8}, + {"w16", cmd_w16}, + {"w32", cmd_w32}, + {0, 0} +};
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/ld.script Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,46 @@ +ENTRY(_entry) +SECTIONS +{ + /* flash boot */ + .vectors 0 : { + *(.vectors) + } + + .magic 0x2000 : { + *(.magic) + } + + /* main code */ + .text 0x4000 : { + /* regular code */ + *(.text*) + /* gcc voodoo */ + *(.glue_7t) *(.glue_7) *(.vfp11_veneer) *(.v4_bx) + . = ALIGN(4); + } + + /* read-only data */ + . = ALIGN(4); + .rodata : { + *(.rodata*) + } + + /* cannot have any initialized data */ + /DISCARD/ : { + *(.data) + } + + /* uninitialized data */ + .bss 0x83C000 (NOLOAD) : { + . = ALIGN(4); + __bss_start = .; + *(.bss) + } + . = ALIGN(4); + __bss_end = .; + /* end of image */ + _end = .; + PROVIDE(end = .); +} + +stack_bottom = 0x83FFFC;
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/magic0.S Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,7 @@ + .section .magic,"ax",%progbits + .code 32 + + .globl _Magic_words +_Magic_words: + .word 0 + .word _entry
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/magic1.S Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,6 @@ + .section .magic,"ax",%progbits + .code 32 + + .globl _Magic_words +_Magic_words: + .word 1
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/main.c Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,9 @@ +main() +{ + printf("\nFlash boot test program running\n"); + for (;;) { + putchar('='); + if (command_entry()) + command_dispatch(); + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/flash-boot-test/mygetchar.c Sun Apr 30 17:40:26 2017 +0000 @@ -0,0 +1,21 @@ +/* + * The interactive command entry (editing) function in libcommon + * will call mygetchar() for its character input. It is supposed + * to be a blocking wait for input, but in some programs other + * processing can be done while waiting - for example, check for + * keypad presses as well. This is the basic version which waits + * for serial input and nothing else. + */ + +extern int serial_in_poll(); + +int +mygetchar() +{ + register int c; + + do + c = serial_in_poll(); + while (c < 0); + return c; +}