head_32.S 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*
  2. * linux/arch/sh/boot/compressed/head.S
  3. *
  4. * Copyright (C) 1999 Stuart Menefy
  5. * Copyright (C) 2003 SUGIOKA Toshinobu
  6. */
  7. .text
  8. #include <asm/page.h>
  9. .global startup
  10. startup:
  11. /* Load initial status register */
  12. mov.l init_sr, r1
  13. ldc r1, sr
  14. /* Move myself to proper location if necessary */
  15. mova 1f, r0
  16. mov.l 1f, r2
  17. cmp/eq r2, r0
  18. bt clear_bss
  19. sub r0, r2
  20. mov.l bss_start_addr, r0
  21. mov #0xffffffe0, r1
  22. and r1, r0 ! align cache line
  23. mov.l text_start_addr, r3
  24. mov r0, r1
  25. sub r2, r1
  26. 3:
  27. mov.l @r1, r4
  28. mov.l @(4,r1), r5
  29. mov.l @(8,r1), r6
  30. mov.l @(12,r1), r7
  31. mov.l @(16,r1), r8
  32. mov.l @(20,r1), r9
  33. mov.l @(24,r1), r10
  34. mov.l @(28,r1), r11
  35. mov.l r4, @r0
  36. mov.l r5, @(4,r0)
  37. mov.l r6, @(8,r0)
  38. mov.l r7, @(12,r0)
  39. mov.l r8, @(16,r0)
  40. mov.l r9, @(20,r0)
  41. mov.l r10, @(24,r0)
  42. mov.l r11, @(28,r0)
  43. #ifdef CONFIG_CPU_SH4
  44. ocbwb @r0
  45. #endif
  46. cmp/hi r3, r0
  47. add #-32, r0
  48. bt/s 3b
  49. add #-32, r1
  50. mov.l 2f, r0
  51. jmp @r0
  52. nop
  53. .align 2
  54. 1: .long 1b
  55. 2: .long clear_bss
  56. text_start_addr:
  57. .long startup
  58. /* Clear BSS */
  59. clear_bss:
  60. mov.l end_addr, r1
  61. mov.l bss_start_addr, r2
  62. mov #0, r0
  63. l1:
  64. mov.l r0, @-r1
  65. cmp/eq r1,r2
  66. bf l1
  67. /* Set the initial pointer. */
  68. mov.l init_stack_addr, r0
  69. mov.l @r0, r15
  70. /* Decompress the kernel */
  71. mov.l decompress_kernel_addr, r0
  72. jsr @r0
  73. nop
  74. /* Jump to the start of the decompressed kernel */
  75. mov.l kernel_start_addr, r0
  76. jmp @r0
  77. nop
  78. .align 2
  79. bss_start_addr:
  80. .long __bss_start
  81. end_addr:
  82. .long _end
  83. init_sr:
  84. .long 0x500000F0 /* Privileged mode, Bank=0, Block=1, IMASK=0xF */
  85. kexec_magic:
  86. .long 0x400000F0 /* magic used by kexec to parse zImage format */
  87. init_stack_addr:
  88. .long stack_start
  89. decompress_kernel_addr:
  90. .long decompress_kernel
  91. kernel_start_addr:
  92. #ifdef CONFIG_32BIT
  93. .long ___pa(_text+PAGE_SIZE)
  94. #else
  95. .long _text+PAGE_SIZE
  96. #endif
  97. .align 9
  98. fake_headers_as_bzImage:
  99. .word 0
  100. .ascii "HdrS" ! header signature
  101. .word 0x0202 ! header version number (>= 0x0105)
  102. ! or else old loadlin-1.5 will fail)
  103. .word 0 ! default_switch
  104. .word 0 ! SETUPSEG
  105. .word 0x1000
  106. .word 0 ! pointing to kernel version string
  107. .byte 0 ! = 0, old one (LILO, Loadlin,
  108. ! 0xTV: T=0 for LILO
  109. ! V = version
  110. .byte 1 ! Load flags bzImage=1
  111. .word 0x8000 ! size to move, when setup is not
  112. .long 0x100000 ! 0x100000 = default for big kernel
  113. .long 0 ! address of loaded ramdisk image
  114. .long 0 # its size in bytes