diff options
author | Peter Kjellerstedt <peter.kjellerstedt@axis.com> | 2006-02-22 08:51:58 +0000 |
---|---|---|
committer | Peter Kjellerstedt <peter.kjellerstedt@axis.com> | 2006-02-22 08:51:58 +0000 |
commit | 212b3faa267c8f3eeafd275de3f7f3f3434a5e96 (patch) | |
tree | c6eae13a4f2822f4a1fe19de01a35d1a2becaf56 /libc/sysdeps/linux/cris | |
parent | 618e8ec63d29c58c85895feec79d3ce1ca4cb1a9 (diff) |
No longer needed.
Diffstat (limited to 'libc/sysdeps/linux/cris')
-rw-r--r-- | libc/sysdeps/linux/cris/crt0.c | 73 |
1 files changed, 0 insertions, 73 deletions
diff --git a/libc/sysdeps/linux/cris/crt0.c b/libc/sysdeps/linux/cris/crt0.c deleted file mode 100644 index a676ee908..000000000 --- a/libc/sysdeps/linux/cris/crt0.c +++ /dev/null @@ -1,73 +0,0 @@ -/* Startup code compliant to the ELF CRIS ABI */ - -/* The first piece of initialized data. */ -int __data_start = 0; - -static void start1 (int argc, char **argv) __attribute__ ((used, noreturn)); - -/* - * It is important that this be the first function. - * This file is the first thing in the text section. - * This is implemented completely in assembler to avoid that the - * compiler pushes stuff on the stack (e.g. the frame pointer when - * debuging). - */ - -/* - * On the stack we have argc. We can calculate argv/envp - * from that and the succeeding stack location, but fix so - * we get the right calling convention (regs in r10/r11). - * - * Please view linux/fs/binfmt_elf.c for a complete - * understanding of this. - */ -__asm__ ( \ - ".text\n\t" \ - ".global _start\n\t" \ - "_start:\n\t" \ - "pop $r10\n\t" \ - "move.d $sp, $r11\n\t" \ - "jump start1\n\t"); - -#include <features.h> - -extern void __uClibc_main(int argc, char **argv, char **envp) - __attribute__ ((__noreturn__)); -extern void __uClibc_start_main(int argc, char **argv, char **envp, - void (*app_init)(void), void (*app_fini)(void)) - __attribute__ ((__noreturn__)); -extern void weak_function _init(void); -extern void weak_function _fini(void); - -/* Stick in a dummy reference to main(), so that if an application - * is linking when the main() function is in a static library (.a) - * we can be sure that main() actually gets linked in */ -extern void main(int argc,void *argv,void *envp); -void (*__mainp)(int argc,void *argv,void *envp) = main; - -static void -start1 (int argc, char **argv) -{ - char** environ; - - /* The environment starts just after ARGV. */ - environ = &argv[argc + 1]; - - /* - * If the first thing after ARGV is the arguments - * themselves, there is no environment. - */ - if ((char *) environ == *argv) - /* - * The environment is empty. Make environ - * point at ARGV[ARGC], which is NULL. - */ - --environ; - -#if defined L_crt0 || ! defined __UCLIBC_CTOR_DTOR__ - /* Leave control to the libc */ - __uClibc_main(argc, argv, environ); -#else - __uClibc_start_main(argc, argv, environ, _init, _fini); -#endif -} |