start.S 1.3 KB

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