2635a8d6df
* microblaze/Makefile.in: Add LINUX_BSP. * microblaze/elf-gloss-linux.ld: New file. * microblaze/elf-gloss-linux.specs: Likewise. * microblaze/linux-crt0.S: Likewise. * microblaze/linux-inbyte.c: Likewise. * microblaze/linux-outbyte.c: Likewise. * microblaze/linux-syscalls-wrap.c: Likewise. * microblaze/linux-syscalls.S: Likewise. * microblaze/linux-syscalls.h: Likewise.
59 lines
1.5 KiB
ArmAsm
59 lines
1.5 KiB
ArmAsm
/* linux-crt0 -- Startup routines for the Linux BSP.
|
|
*
|
|
* Copyright (c) 2011 Edgar E. Iglesias
|
|
*
|
|
* The authors hereby grant permission to use, copy, modify, distribute,
|
|
* and license this software and its documentation for any purpose, provided
|
|
* that existing copyright notices are retained in all copies and that this
|
|
* notice is included verbatim in any distributions. No written agreement,
|
|
* license, or royalty fee is required for any of the authorized uses.
|
|
* Modifications to this software may be copyrighted by their authors
|
|
* and need not follow the licensing terms described here, provided that
|
|
* the new terms are clearly indicated on the first page of each file where
|
|
* they apply.
|
|
*/
|
|
|
|
.section .text
|
|
.globl _start
|
|
.ent _start
|
|
.type _start, @function
|
|
_start:
|
|
la r13, r0, _SDA_BASE_
|
|
la r2, r0, _SDA2_BASE_
|
|
|
|
brlid r15, __init
|
|
nop
|
|
|
|
lwi r5, r1, 0
|
|
addik r6, r1, 4
|
|
|
|
# Add argc * 4.
|
|
addk r7, r5, r5
|
|
addk r7, r7, r7
|
|
|
|
brlid r15, main
|
|
# Now add 4 + r1 (i.e r6) in the delayslot.
|
|
addk r7, r7, r6
|
|
|
|
brlid r15, exit
|
|
addik r5, r3, 0
|
|
.size _start, . - _start
|
|
.end _start
|
|
|
|
/* Replacement for the GCC provided crti.S. This one avoids the
|
|
setup of stack protection regs (which result in privilieged
|
|
insn exceptions when running in user-space). */
|
|
.section .init, "ax"
|
|
.global __init
|
|
.align 2
|
|
__init:
|
|
addik r1, r1, -8
|
|
sw r15, r0, r1
|
|
|
|
.section .fini, "ax"
|
|
.global __fini
|
|
.align 2
|
|
__fini:
|
|
addik r1, r1, -8
|
|
sw r15, r0, r1
|