diff options
author | Geoffrey Keating <geoffk@geoffk.org> | 2001-12-23 01:47:58 +0300 |
---|---|---|
committer | Geoffrey Keating <geoffk@geoffk.org> | 2001-12-23 01:47:58 +0300 |
commit | f6eff1c04649af4f2a18c434d9be2870c24cc668 (patch) | |
tree | ce025040088849a3c238acf2892ae64a14bf7727 /libgloss/xstormy16/crt0_stub.s | |
parent | a3e320f3c9759b2ad6267daca68e24952f27d59c (diff) |
In newlib/:
2001-12-22 Geoffrey Keating <geoffk@redhat.com>
Catherine Moore <clm@redhat.com>
Richard Henderson <rth@redhat.com>
Corinna Vinschen <vinschen@redhat.com>
* configure.host: Add support for xstormy16.
* libc/include/machine/ieeefp.h: Add support for xstormy16.
* libc/include/machine/setjmp.h: Add support for xstormy16.
* libc/include/sys/config.h: Add support for xstormy16.
* libc/machine/xstormy16/Makefile.am: New file.
* libc/machine/xstormy16/Makefile.in: New file.
* libc/machine/xstormy16/aclocal.m4: New file.
* libc/machine/xstormy16/configure: New file.
* libc/machine/xstormy16/configure.in: New file.
* libc/machine/xstormy16/setjmp.S: New file.
In libgloss/:
2001-12-22 Geoffrey Keating <geoffk@redhat.com>
Mark Salter <msalter@redhat.com>
Catherine Moore <clm@redhat.com>
Richard Henderson <rth@redhat.com>
* configure.in: Add xstormy16.
* libnosys/configure.in: Add xstormy16.
* configure: Regenerated.
* libnosys/configure: Regenerated.
* xstormy16/Makefile.in: New file.
* xstormy16/close.c: New file.
* xstormy16/configure: New file.
* xstormy16/configure.in: New file.
* xstormy16/crt0.s: New file.
* xstormy16/crt0_stub.s: New file.
* xstormy16/crti.s: New file.
* xstormy16/crtn.s: New file.
* xstormy16/eva_app.c: New file.
* xstormy16/eva_app.ld: New file.
* xstormy16/eva_stub.ld: New file.
* xstormy16/fstat.c: New file.
* xstormy16/getpid.c: New file.
* xstormy16/kill.c: New file.
* xstormy16/lseek.c: New file.
* xstormy16/open.c: New file.
* xstormy16/sbrk.c: New file.
* xstormy16/sim_high.ld: New file.
* xstormy16/stat.c: New file.
* xstormy16/syscalls.S: New file.
* xstormy16/syscalls.m4: New file.
* xstormy16/unlink.c: New file.
* xstormy16/xstormy16_stub.c: New file.
Diffstat (limited to 'libgloss/xstormy16/crt0_stub.s')
-rw-r--r-- | libgloss/xstormy16/crt0_stub.s | 178 |
1 files changed, 178 insertions, 0 deletions
diff --git a/libgloss/xstormy16/crt0_stub.s b/libgloss/xstormy16/crt0_stub.s new file mode 100644 index 000000000..ce3ad366a --- /dev/null +++ b/libgloss/xstormy16/crt0_stub.s @@ -0,0 +1,178 @@ +# XSTORMY16 startup code for GDB stub. + +# CPU Data for Sanyo EVA debugger at 0x7F00 + .section .cpudata,"ax" + .byte 0x00,0x02,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x44,0x35,0x39,0x52,0x30,0x30,0x30,0x30,0x2E,0x4F,0x50,0x54,0x00,0x00,0x00,0x00 + .byte 0x4c,0x43,0x35,0x39,0x52,0x30,0x30,0x30,0x30,0x00,0x00,0x00,0x00,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x04,0x80,0x00,0x20,0x48,0x00,0x00,0x00 + .byte 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x20,0x01,0x12,0x31,0x23,0x59 + +# Interrupt vectors at 0x8000. + .section .int_vec,"ax" + .global _start + .align 1 +_start: + ;; Reset, watchdog timer interrupt + jmpf _int_reset + ;; base timer interrupt + jmpf _int_basetimer + ;; timer 0 + jmpf _int_timer0 + ;; timer 1 + jmpf _int_timer1 + ;; SIO0 interrupt + jmpf _int_sio0 + ;; SIO1 interrupt + jmpf _int_sio1 + ;; port0 interrupt + jmpf _int_port0 + ;; port1 interrupt + jmpf _int_port1 + + .org 0x80 + ;; sys interrupt (0x8080) + jmpf _int_sys + + ;; Application void write(char *buf, int nbytes) + ;; This jmps to a stub function to packetize the buf for GDB + jmpf gdb_write + ;; Application int read(char *buf, int nbytes) + jmpf gdb_read + + .text +# Reset code, set up memory and call main. +_int_reset: + ;; Set up the application stack pointer. + mov sp,#0x002 + + ;; Zero the data space + mov r0,#_edata + mov r1,#_end + mov r2,#0 +0: mov.w (r0++),r2 + blt r0,r1,0b + + ;; Init the UART + callf uart_init + + ;; Turn on illegal insn trap + mov r0,r14 + set1 r0,#11 + mov r14,r0 + mov.b 0x7f08,#0x11 + mov.b 0x7f09,#0x10 + + ;; "breakpoint" sends us into stub. +0: + .hword 0x0006 + br 0b + +1: .size _int_reset,1b-_int_reset + +# Stub interrupt routines. + .globl _int_timer0 + .weak _int_timer0 + .globl _int_timer1 + .weak _int_timer1 + .globl _int_sio0 + .weak _int_sio0 + .globl _int_sio1 + .weak _int_sio1 + .globl _int_port0 + .weak _int_port0 + .globl _int_port1 + .weak _int_port1 + .globl _int_basetimer + .weak _int_basetimer +_int_timer0: +_int_timer1: +_int_sio0: +_int_sio1: +_int_port0: +_int_port1: +_int_basetimer: + iret +1: .size _int_timer0,1b-_int_timer0 + +_int_sys: + push r13 + mov r13,#registers + mov.w (r13++),r0 + mov.w (r13++),r1 + mov.w (r13++),r2 + mov.w (r13++),r3 + mov.w (r13++),r4 + mov.w (r13++),r5 + mov.w (r13++),r6 + mov.w (r13++),r7 + mov r0,r8 + mov.w (r13++),r0 + mov r0,r9 + mov.w (r13++),r0 + mov r0,r10 + mov.w (r13++),r0 + mov r0,r11 + mov.w (r13++),r0 + mov r0,r12 + mov.w (r13++),r0 + pop r0 + mov.w (r13++),r0 ; R13 + pop r0 + mov.w (r13++),r0 ; PSW + mov r0,r15 + sub r0,#4 + mov.w (r13++),r0 ; SP + pop r0 + pop r1 + mov.w (r13++),r1 ; PCL + mov.w (r13++),r0 ; PCH + + ;; switch to stub stack and invoke stub + mov sp,#0x700 + callf handle_exception + + mov r0,#registers+34 + mov.w r1,(r0) ; PCH + mov.w r2,(--r0) ; PCL + mov.w r3,(--r0) ; SP + mov r15,r3 + push r2 + push r1 + mov.w r1,(--r0) ; PSW + push r1 + mov.w r1,(--r0) + mov r13,r1 + mov.w r1,(--r0) + mov r12,r1 + mov.w r1,(--r0) + mov r11,r1 + mov.w r1,(--r0) + mov r10,r1 + mov.w r1,(--r0) + mov r9,r1 + mov.w r1,(--r0) + mov r8,r1 + mov.w r7,(--r0) + mov.w r6,(--r0) + mov.w r5,(--r0) + mov.w r4,(--r0) + mov.w r3,(--r0) + mov.w r2,(--r0) + mov.w r1,(--r0) + mov.w r0,(--r0) + iret +1: .size _int_sys,1b-_int_sys + + |