source: mainline/uspace/lib/libc/arch/mips32/src/entry.s@ 86018c1

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 86018c1 was c98e6ee, checked in by Jiri Svoboda <jirik.svoboda@…>, 17 years ago

Merge program-loader related stuff from dynload branch to trunk. (huge)

  • Property mode set to 100644
File size: 2.1 KB
Line 
1#
2# Copyright (c) 2005 Martin Decky
3# All rights reserved.
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions
7# are met:
8#
9# - Redistributions of source code must retain the above copyright
10# notice, this list of conditions and the following disclaimer.
11# - Redistributions in binary form must reproduce the above copyright
12# notice, this list of conditions and the following disclaimer in the
13# documentation and/or other materials provided with the distribution.
14# - The name of the author may not be used to endorse or promote products
15# derived from this software without specific prior written permission.
16#
17# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27#
28
29.text
30.section .init, "ax"
31.global __entry
32.global __entry_driver
33.set noreorder
34.option pic2
35
36## User-space task entry point
37#
38# $a0 ($4) contains the PCB pointer
39#
40.ent __entry
41__entry:
42 .frame $sp, 32, $31
43 .cpload $25
44
45 # Mips o32 may store its arguments on stack, make space (16 bytes),
46 # so that it could work with -O0
47 # Make space additional 16 bytes for the stack frame
48
49 addiu $sp, -32
50 .cprestore 16 # Allow PIC code
51
52 # Pass pcb_ptr to __main() as the first argument. pcb_ptr is already
53 # in $a0. As the first argument is passed in $a0, no operation
54 # is needed.
55
56 jal __main
57 nop
58
59 jal __exit
60 nop
61.end
62
63# Alignment of output section data to 0x4000
64.section .data
65.align 14
Note: See TracBrowser for help on using the repository browser.