Mercurial > emacs
annotate src/ecrt0.c @ 95328:44c693827736
(casify_object): Try to guess better whether the argument is a byte or a char.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Tue, 27 May 2008 00:50:01 +0000 |
parents | 8971ddf55736 |
children | ddedcecb18ef |
rev | line source |
---|---|
25844 | 1 /* C code startup routine. |
75227
e90d04cd455a
Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents:
68651
diff
changeset
|
2 Copyright (C) 1985, 1986, 1992, 2001, 2002, 2003, 2004, |
79759 | 3 2005, 2006, 2007, 2008 Free Software Foundation, Inc. |
25844 | 4 |
5 This file is part of GNU Emacs. | |
6 | |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91702
diff
changeset
|
7 GNU Emacs is free software: you can redistribute it and/or modify |
25844 | 8 it under the terms of the GNU General Public License as published by |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91702
diff
changeset
|
9 the Free Software Foundation, either version 3 of the License, or |
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91702
diff
changeset
|
10 (at your option) any later version. |
25844 | 11 |
12 GNU Emacs is distributed in the hope that it will be useful, | |
13 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 GNU General Public License for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
91702
diff
changeset
|
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
25844 | 19 |
20 | |
21 /* The standard Vax 4.2 Unix crt0.c cannot be used for Emacs | |
22 because it makes `environ' an initialized variable. | |
23 It is easiest to have a special crt0.c on all machines | |
24 though I don't know whether other machines actually need it. */ | |
25 | |
26 /* On the vax and 68000, in BSD4.2 and USG5.2, | |
27 this is the data format on startup: | |
28 (vax) ap and fp are unpredictable as far as I know; don't use them. | |
29 sp -> word containing argc | |
30 word pointing to first arg string | |
31 [word pointing to next arg string]... 0 or more times | |
32 0 | |
33 Optionally: | |
34 [word pointing to environment variable]... 1 or more times | |
35 ... | |
36 0 | |
37 And always: | |
38 first arg string | |
39 [next arg string]... 0 or more times | |
40 */ | |
41 | |
42 /* On the 16000, at least in the one 4.2 system I know about, | |
43 the initial data format is | |
44 sp -> word containing argc | |
45 word containing argp | |
46 word pointing to first arg string, and so on as above | |
47 */ | |
48 | |
49 #ifdef emacs | |
50 #include <config.h> | |
51 #endif | |
52 | |
53 /* ******** WARNING ******** | |
54 Do not insert any data definitions before data_start! | |
55 Since this is the first file linked, the address of the following | |
56 variable should correspond to the start of initialized data space. | |
57 On some systems this is a constant that is independent of the text | |
58 size for shared executables. On others, it is a function of the | |
59 text size. In short, this seems to be the most portable way to | |
60 discover the start of initialized data space dynamically at runtime, | |
61 for either shared or unshared executables, on either swapping or | |
62 virtual systems. It only requires that the linker allocate objects | |
63 in the order encountered, a reasonable model for most Unix systems. | |
64 Similarly, note that the address of _start() should be the start | |
65 of text space. Fred Fish, UniSoft Systems Inc. */ | |
66 | |
67 int data_start = 0; | |
68 | |
69 #ifdef NEED_ERRNO | |
70 int errno; | |
71 #endif | |
72 | |
91702
b7a5a89054dc
* configure.in (LIBX11_MACHINE, HAVE_XFREE386): Remove code
Dan Nicolaescu <dann@ics.uci.edu>
parents:
87730
diff
changeset
|
73 #ifndef MSDOS |
25844 | 74 char **environ; |
75 #endif | |
76 | |
77 #ifndef static | |
78 /* On systems where the static storage class is usable, this function | |
79 should be declared as static. Otherwise, the static keyword has | |
80 been defined to be something else, and code for those systems must | |
81 take care of this declaration appropriately. */ | |
82 static start1 (); | |
83 #endif | |
84 | |
85 #ifdef CRT0_DUMMIES | |
86 | |
87 /* Define symbol "start": here; some systems want that symbol. */ | |
88 #ifdef DOT_GLOBAL_START | |
89 asm(" .text "); | |
90 asm(" .globl start "); | |
91 asm(" start: "); | |
92 #endif /* DOT_GLOBAL_START */ | |
93 | |
94 #ifdef NODOT_GLOBAL_START | |
95 asm(" text "); | |
96 asm(" global start "); | |
97 asm(" start: "); | |
98 #endif /* NODOT_GLOBAL_START */ | |
99 | |
100 #ifdef m68000 | |
101 | |
102 /* GCC 2.1, when optimization is turned off, seems to want to push a | |
103 word of garbage on the stack, which screws up the CRT0_DUMMIES | |
104 hack. So we hand-code _start in assembly language. */ | |
105 asm(".text "); | |
106 asm(" .even "); | |
107 asm(".globl __start "); | |
108 asm("__start: "); | |
109 asm(" link a6,#0 "); | |
110 asm(" jbsr _start1 "); | |
111 asm(" unlk a6 "); | |
112 asm(" rts "); | |
113 | |
114 #else /* not m68000 */ | |
115 | |
116 _start () | |
117 { | |
118 /* On vax, nothing is pushed here */ | |
119 /* On sequent, bogus fp is pushed here */ | |
120 start1 (); | |
121 } | |
122 | |
123 #endif /* possibly m68000 */ | |
124 | |
125 static | |
126 start1 (CRT0_DUMMIES argc, xargv) | |
127 int argc; | |
128 char *xargv; | |
129 { | |
130 register char **argv = &xargv; | |
131 environ = argv + argc + 1; | |
132 | |
133 if ((char *)environ == xargv) | |
134 environ--; | |
135 exit (main (argc, argv, environ)); | |
136 | |
137 /* Refer to `start1' so GCC will not think it is never called | |
138 and optimize it out. */ | |
139 (void) &start1; | |
140 } | |
141 #else /* not CRT0_DUMMIES */ | |
142 | |
143 /* "m68k" and "m68000" both stand for m68000 processors, | |
144 but with different program-entry conventions. | |
145 This is a kludge. Now that the CRT0_DUMMIES mechanism above exists, | |
146 most of these machines could use the vax code above | |
147 with some suitable definition of CRT0_DUMMIES. | |
148 Then the symbol m68k could be flushed. | |
149 But I don't want to risk breaking these machines | |
150 in a version 17 patch release, so that change is being put off. */ | |
151 | |
152 #ifdef m68k /* Can't do it all from C */ | |
153 asm (" global _start"); | |
154 asm (" text"); | |
155 asm ("_start:"); | |
156 asm (" comm splimit%,4"); | |
157 asm (" global exit"); | |
158 asm (" text"); | |
159 asm (" mov.l %d0,splimit%"); | |
160 asm (" jsr start1"); | |
161 asm (" mov.l %d0,(%sp)"); | |
162 asm (" jsr exit"); | |
163 asm (" mov.l &1,%d0"); /* d0 = 1 => exit */ | |
164 asm (" trap &0"); | |
165 #else /* m68000, not m68k */ | |
166 | |
167 #ifdef m68000 | |
168 | |
169 _start () | |
170 { | |
171 #ifdef sun | |
172 finitfp_(); | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
27727
diff
changeset
|
173 #endif |
25844 | 174 /* On 68000, _start pushes a6 onto stack */ |
175 start1 (); | |
176 } | |
177 #endif /* m68000 */ | |
178 #endif /* m68k */ | |
179 | |
180 #if defined(m68k) || defined(m68000) | |
181 /* ignore takes care of skipping the a6 value pushed in start. */ | |
182 static | |
183 #if defined(m68k) | |
184 start1 (argc, xargv) | |
185 #else | |
186 start1 (ignore, argc, xargv) | |
187 #endif | |
188 int argc; | |
189 char *xargv; | |
190 { | |
191 register char **argv = &xargv; | |
192 environ = argv + argc + 1; | |
193 | |
194 if ((char *)environ == xargv) | |
195 environ--; | |
196 exit (main (argc, argv, environ)); | |
197 } | |
198 | |
199 #endif /* m68k or m68000 */ | |
200 | |
201 #endif /* not CRT0_DUMMIES */ | |
202 | |
203 #ifdef hp9000s300 | |
204 int argc_value; | |
205 char **argv_value; | |
206 #ifdef OLD_HP_ASSEMBLER | |
207 asm(" text"); | |
208 asm(" globl __start"); | |
209 asm(" globl _exit"); | |
210 asm(" globl _main"); | |
211 asm("__start"); | |
212 asm(" dc.l 0"); | |
213 asm(" subq.w #0x1,d0"); | |
214 asm(" move.w d0,float_soft"); | |
215 asm(" move.l 0x4(a7),d0"); | |
216 asm(" beq.s skip_1"); | |
217 asm(" move.l d0,a0"); | |
218 asm(" clr.l -0x4(a0)"); | |
219 asm("skip_1"); | |
220 asm(" move.l a7,a0"); | |
221 asm(" subq.l #0x8,a7"); | |
222 asm(" move.l (a0),(a7)"); | |
223 asm(" move.l (a0),_argc_value"); | |
224 asm(" addq.l #0x4,a0"); | |
225 asm(" move.l a0,0x4(a7)"); | |
226 asm(" move.l a0,_argv_value"); | |
227 asm("incr_loop"); | |
228 asm(" tst.l (a0)+"); | |
229 asm(" bne.s incr_loop"); | |
230 asm(" move.l 0x4(a7),a1"); | |
231 asm(" cmp.l (a1),a0"); | |
232 asm(" blt.s skip_2"); | |
233 asm(" subq.l #0x4,a0"); | |
234 asm("skip_2"); | |
235 asm(" move.l a0,0x8(a7)"); | |
236 asm(" move.l a0,_environ"); | |
237 asm(" jsr _main"); | |
238 asm(" addq.l #0x8,a7"); | |
239 asm(" move.l d0,-(a7)"); | |
240 asm(" jsr _exit"); | |
241 asm(" move.w #0x1,d0"); | |
242 asm(" trap #0x0"); | |
243 asm(" comm float_soft,4"); | |
244 /* float_soft is allocated in this way because C would | |
245 put an underscore character in its name otherwise. */ | |
246 | |
247 #else /* new hp assembler */ | |
248 | |
249 asm(" text"); | |
250 asm(" global float_loc"); | |
251 asm(" set float_loc,0xFFFFB000"); | |
252 asm(" global fpa_loc"); | |
253 asm(" set fpa_loc,0xfff08000"); | |
254 asm(" global __start"); | |
255 asm(" global _exit"); | |
256 asm(" global _main"); | |
257 asm("__start:"); | |
258 asm(" byte 0,0,0,0"); | |
259 asm(" subq.w &1,%d0"); | |
260 asm(" mov.w %d0,float_soft"); | |
261 asm(" mov.w %d1,flag_68881"); | |
262 #ifndef HPUX_68010 | |
263 asm(" beq.b skip_float"); | |
264 asm(" fmov.l &0x7400,%fpcr"); | |
265 /* asm(" fmov.l &0x7480,%fpcr"); */ | |
266 #endif /* HPUX_68010 */ | |
267 asm("skip_float:"); | |
268 asm(" mov.l %a0,%d0"); | |
269 asm(" add.l %d0,%d0"); | |
270 asm(" subx.w %d1,%d1"); | |
271 asm(" mov.w %d1,flag_68010"); | |
272 asm(" add.l %d0,%d0"); | |
273 asm(" subx.w %d1,%d1"); | |
274 asm(" mov.w %d1,flag_fpa"); | |
275 asm(" tst.l %d2"); | |
276 asm(" ble.b skip_3"); | |
277 asm(" lsl flag_68881"); | |
278 asm(" lsl flag_fpa"); | |
279 asm("skip_3:"); | |
280 asm(" mov.l 4(%a7),%d0"); | |
281 asm(" beq.b skip_1"); | |
282 asm(" mov.l %d0,%a0"); | |
283 asm(" clr.l -4(%a0)"); | |
284 asm("skip_1:"); | |
285 asm(" mov.l %a7,%a0"); | |
286 asm(" subq.l &8,%a7"); | |
287 asm(" mov.l (%a0),(%a7)"); | |
288 asm(" mov.l (%a0),_argc_value"); | |
289 asm(" addq.l &4,%a0"); | |
290 asm(" mov.l %a0,4(%a7)"); | |
291 asm(" mov.l %a0,_argv_value"); | |
292 asm("incr_loop:"); | |
293 asm(" tst.l (%a0)+"); | |
294 asm(" bne.b incr_loop"); | |
295 asm(" mov.l 4(%a7),%a1"); | |
296 asm(" cmp.l %a0,(%a1)"); | |
297 asm(" blt.b skip_2"); | |
298 asm(" subq.l &4,%a0"); | |
299 asm("skip_2:"); | |
300 asm(" mov.l %a0,8(%a7)"); | |
301 asm(" mov.l %a0,_environ"); | |
302 asm(" jsr _main"); | |
303 asm(" addq.l &8,%a7"); | |
304 asm(" mov.l %d0,-(%a7)"); | |
305 asm(" jsr _exit"); | |
306 asm(" mov.w &1,%d0"); | |
307 asm(" trap &0"); | |
308 asm(" comm float_soft, 4"); | |
309 asm(" comm flag_68881, 4"); | |
310 asm(" comm flag_68010, 4"); | |
311 asm(" comm flag_68040, 4"); | |
312 asm(" comm flag_fpa, 4"); | |
313 | |
314 #endif /* new hp assembler */ | |
315 #endif /* hp9000s300 */ | |
316 | |
317 #ifdef sparc | |
318 asm (".global __start"); | |
319 asm (".text"); | |
320 asm ("__start:"); | |
321 asm (" mov 0, %fp"); | |
322 asm (" ld [%sp + 64], %o0"); | |
323 asm (" add %sp, 68, %o1"); | |
324 asm (" sll %o0, 2, %o2"); | |
325 asm (" add %o2, 4, %o2"); | |
326 asm (" add %o1, %o2, %o2"); | |
327 asm (" sethi %hi(_environ), %o3"); | |
328 asm (" st %o2, [%o3+%lo(_environ)]"); | |
329 asm (" andn %sp, 7, %sp"); | |
330 asm (" call _main"); | |
331 asm (" sub %sp, 24, %sp"); | |
332 asm (" call __exit"); | |
333 asm (" nop"); | |
334 | |
335 #endif /* sparc */ | |
336 | |
337 #if __FreeBSD__ == 2 | |
338 char *__progname; | |
339 #endif | |
340 #ifdef __bsdi__ | |
341 #include <sys/param.h> /* for version number */ | |
342 #if defined(_BSDI_VERSION) && (_BSDI_VERSION >= 199501) | |
343 char *__progname; | |
344 #endif | |
345 #endif /* __bsdi__ */ | |
52401 | 346 |
347 /* arch-tag: 4025c2fb-d6b1-4d29-b1b6-8100b6bd1e74 | |
348 (do not change this comment) */ |