start.S 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * Copyright (C) 2016 Vladimir Zapolskiy <vz@mleia.com>
  3. * Copyright (C) 2007, 2010 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <asm-offsets.h>
  8. #include <config.h>
  9. .text
  10. .align 2
  11. .global _start
  12. _start:
  13. #ifdef CONFIG_CPU_SH2
  14. .long 0x00000010 /* Ppower ON reset PC*/
  15. .long 0x00000000
  16. .long 0x00000010 /* Manual reset PC */
  17. .long 0x00000000
  18. #endif
  19. mov.l ._lowlevel_init, r0
  20. 100: bsrf r0
  21. nop
  22. bsr 1f
  23. nop
  24. 1: sts pr, r5
  25. mov.l ._reloc_dst, r4
  26. add #(_start-1b), r5
  27. mov.l ._reloc_dst_end, r6
  28. 2: mov.l @r5+, r1
  29. mov.l r1, @r4
  30. add #4, r4
  31. cmp/hs r6, r4
  32. bf 2b
  33. mov.l ._bss_start, r4
  34. mov.l ._bss_end, r5
  35. mov #0, r1
  36. 3: mov.l r1, @r4 /* bss clear */
  37. add #4, r4
  38. cmp/hs r5, r4
  39. bf 3b
  40. mov.l ._gd_init, r13 /* global data */
  41. mov.l ._stack_init, r15 /* stack */
  42. mov.l ._sh_generic_init, r0
  43. jsr @r0
  44. mov #0, r4
  45. loop:
  46. bra loop
  47. .align 2
  48. ._lowlevel_init: .long (lowlevel_init - (100b + 4))
  49. ._reloc_dst: .long _start
  50. ._reloc_dst_end: .long reloc_dst_end
  51. ._bss_start: .long bss_start
  52. ._bss_end: .long bss_end
  53. ._gd_init: .long (_start - GENERATED_GBL_DATA_SIZE)
  54. ._stack_init: .long (_start - GENERATED_GBL_DATA_SIZE - CONFIG_SYS_MALLOC_LEN - 16)
  55. ._sh_generic_init: .long board_init_f