ack/plat/rpi/boot.s
2013-05-22 00:16:59 +01:00

92 lines
1.8 KiB
ArmAsm

#
/*
* Raspberry Pi support library for the ACK
* © 2013 David Given
* This file is redistributable under the terms of the 3-clause BSD license.
* See the file 'Copying' in the root of the distribution for the full text.
*/
! Declare segments (the order is important).
.sect .text
.sect .rom
.sect .data
.sect .bss
.sect .text
#define gp r15
begtext:
! Set up system registers.
lea gp, begtext
st sp, .returnsp
st lr, .returnlr
! The GPU kernel code will load parameters into r0-r5. Save them
! so that the user code can access them.
sub r0, gp ! pointer
sub r1, gp ! pointer
sub r2, gp ! pointer
sub r3, gp ! pointer
! r4-r5 are not pointers and don't need adjusting
push r0-r5
sub r0, sp, gp
st r0, _gpu_parameters
! Wipe the bss. (I'm a little suprised that __m_a_i_n doesn't do this.)
lea r0, begbss
lea r1, endbss
mov r2, #0
_1:
stb r2, (r0)
addcmpb.lt r2, #1, r1, _1
! Push standard parameters onto the stack and go.
mov r0, #0
push r0 ! envp
push r0 ! argv
push r0 ! argc
! Call the language startup code.
bl __m_a_i_n
! Fall through to __exit if this returns.
.define __exit
__exit:
ld sp, .returnsp
ld lr, .returnlr
b lr
! Define symbols at the beginning of our various segments, so that we can find
! them. (Except .text, which has already been done.)
.define begtext, begdata, begbss
.sect .data; begdata:
.sect .rom; begrom:
.sect .bss; begbss:
! Some magic data. All EM systems need these.
.define .trppc, .ignmask, _errno
.comm .trppc, 4
.comm .ignmask, 4
.comm _errno, 4
! We store the stack pointer and return address on entry so that we can
! cleanly exit.
.comm .returnsp, 4
.comm .returnlr, 4
! User pointer to the GPU kernel parameter block.
.define _gpu_parameters
.comm _gpu_parameters, 4