Unify wint_t handling in wchar.h and wctype.h.
[glibc.git] / sysdeps / sh / elf / start.S
blob0da0861f6cf0c4ad790e448cc877d049ca7e6a70
1 /* Startup code for SH & ELF.
2    Copyright (C) 1999, 2001, 2002 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
10    In addition to the permissions in the GNU Lesser General Public
11    License, the Free Software Foundation gives you unlimited
12    permission to link the compiled version of this file with other
13    programs, and to distribute those programs without any restriction
14    coming from the use of this file. (The GNU Lesser General Public
15    License restrictions do apply in other respects; for example, they
16    cover modification of the file, and distribution when not linked
17    into another program.)
19    Note that people who make modified versions of this file are not
20    obligated to grant this special exception for their modified
21    versions; it is their choice whether to do so. The GNU Lesser
22    General Public License gives permission to release a modified
23    version without this exception; this exception also makes it
24    possible to release a modified version which carries forward this
25    exception.
27    The GNU C Library is distributed in the hope that it will be useful,
28    but WITHOUT ANY WARRANTY; without even the implied warranty of
29    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
30    Lesser General Public License for more details.
32    You should have received a copy of the GNU Lesser General Public
33    License along with the GNU C Library; if not, write to the Free
34    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
35    02111-1307 USA.  */
37 /* This is the canonical entry point, usually the first thing in the text
38    segment.
40         Note that the code in the .init section has already been run.
41         This includes _init and _libc_init
44         At this entry point, most registers' values are unspecified, except:
46    r4           Contains a function pointer to be registered with `atexit'.
47                 This is how the dynamic linker arranges to have DT_FINI
48                 functions called for shared libraries that have been loaded
49                 before this code runs.
51    sp           The stack contains the arguments and environment:
52                 0(sp)                   argc
53                 4(sp)                   argv[0]
54                 ...
55                 (4*argc)(sp)            NULL
56                 (4*(argc+1))(sp)        envp[0]
57                 ...
58                                         NULL
61         .text
62         .globl _start
63         .type _start,@function
64 _start:
65         /* Clear the frame pointer since this is the outermost frame.  */
66         mov #0, r14
68         /* Pop argc off the stack and save a pointer to argv */
69         mov.l @r15+,r5
70         mov r15, r6
72         /* Push the last arguments to main() onto the stack */
73         mov.l r4,@-r15
74         mov.l L_fini,r0
75         mov.l r0,@-r15
77         /* Set up the other arguments for main() that go in registers */
78         mov.l L_main,r4
79         mov.l L_init,r7
81         /* __libc_start_main (main, argc, argv, init, fini, rtld_fini) */
83         /* Let the libc call main and exit with its return code.  */
84         mov.l L_libc_start_main,r1
85         jsr @r1
86         nop
87         /* should never get here....*/
88         mov.l L_abort,r1
89         jsr @r1
90         nop
91         .align  2
92 L_main:
93         .long   main
94 L_init:
95         .long   __libc_csu_init
96 L_fini:
97         .long   __libc_csu_fini
98 L_libc_start_main:
99         .long   __libc_start_main
100 L_abort:
101         .long   abort
102 /* Define a symbol for the first piece of initialized data.  */
103         .data
104         .globl __data_start
105 __data_start:
106         .long 0
107         .weak data_start
108         data_start = __data_start
109         .global __fpscr_values
110 __fpscr_values:
111         .long   0
112         .long   0x80000