crt0.S 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /* Startup code for SH & ELF.
  2. Copyright (C) 1999 Free Software Foundation, Inc.
  3. Copyright (C) 2001 Hewlett-Packard Australia
  4. This program is free software; you can redistribute it and/or modify it under
  5. the terms of the GNU Library General Public License as published by the Free
  6. Software Foundation; either version 2 of the License, or (at your option) any
  7. later version.
  8. This program is distributed in the hope that it will be useful, but WITHOUT
  9. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  10. FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more
  11. details.
  12. You should have received a copy of the GNU Library General Public License
  13. along with this program; if not, write to the Free Software Foundation, Inc.,
  14. 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  15. Derived in part from the Linux-8086 C library, the GNU C Library, and several
  16. other sundry sources. Files within this library are copyright by their
  17. respective copyright holders.
  18. */
  19. /* This is the canonical entry point, usually the first thing in the text
  20. segment.
  21. At this entry point, most registers' values are unspecified, except:
  22. sp The stack contains the arguments and environment:
  23. 0(sp) argc
  24. 4(sp) argv[0]
  25. ...
  26. (4*argc)(sp) NULL
  27. (4*(argc+1))(sp) envp[0]
  28. ...
  29. NULL
  30. */
  31. .file "crt0.S"
  32. .text
  33. .globl _start
  34. .type _start,@function
  35. .size _start,_start_end - _start
  36. _start:
  37. /* Clear the frame pointer since this is the outermost frame. */
  38. mov #0, r14
  39. /* Pop argc off the stack and save a pointer to argv */
  40. mov.l @r15+,r4
  41. mov r15, r5
  42. #if ! defined __UCLIBC_CTOR_DTOR__
  43. /*
  44. * Setup the value for the environment pointer:
  45. * r6 = (argc + 1) * 4
  46. * r6 += argv (in delay slot)
  47. */
  48. mov r4,r6
  49. add #1,r6
  50. shll2 r6
  51. add r5, r6
  52. /* jump to __uClibc_main (argc, argv, envp) */
  53. mov.l L_main, r0
  54. jsr @r0
  55. nop /* delay slot */
  56. /* We should not get here. */
  57. mov.l L_abort, r0
  58. jmp @r0
  59. nop
  60. _start_end:
  61. .align 2
  62. L_main:
  63. .long __uClibc_main /* in libuClibc.*.so */
  64. #else /* __UCLIBC_CTOR_DTOR__ */
  65. /* Push the finip argument to __uClibc_start_main() onto the stack */
  66. mov.l L_fini,r6
  67. mov.l r6,@-r15
  68. /* Setup the value for the initp argument */
  69. mov.l L_init, r7
  70. /*
  71. * Setup the value for the environment pointer:
  72. * r6 = (argc + 1) * 4
  73. * r6 += argv (in delay slot)
  74. */
  75. mov r4,r6
  76. add #1,r6
  77. shll2 r6
  78. /* jump to __uClibc_start_main (argc, argv, envp, app_init, app_fini) */
  79. mov.l L_main, r0
  80. jsr @r0
  81. add r5, r6 /* delay slot */
  82. /* We should not get here. */
  83. mov.l L_abort, r0
  84. jmp @r0
  85. nop
  86. _start_end:
  87. .align 2
  88. L_main:
  89. .long __uClibc_start_main /* in libuClibc.*.so */
  90. .weak _init
  91. .type _init,@function
  92. _init:
  93. rts
  94. nop
  95. .Lfe1:
  96. .size _init,.Lfe1-_init
  97. .weak _fini
  98. .set _fini,_init
  99. L_init:
  100. .long _init
  101. L_fini:
  102. .long _fini
  103. #endif
  104. L_abort:
  105. .long abort
  106. /* Stick in a dummy reference to main(), so that if an application
  107. * is linking when the main() function is in a static library (.a)
  108. * we can be sure that main() actually gets linked in */
  109. L_dummy_main_reference:
  110. .long main