relocate_kernel.S 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /*
  2. * relocate_kernel.S - put the kernel image in place to boot
  3. * 2005.9.17 kogiidena@eggplant.ddo.jp
  4. *
  5. * LANDISK/sh4 is supported. Maybe, SH archtecture works well.
  6. *
  7. * This source code is licensed under the GNU General Public License,
  8. * Version 2. See the file COPYING for more details.
  9. */
  10. #include <linux/linkage.h>
  11. #include <asm/addrspace.h>
  12. #include <asm/page.h>
  13. .globl relocate_new_kernel
  14. relocate_new_kernel:
  15. /* r4 = indirection_page */
  16. /* r5 = reboot_code_buffer */
  17. /* r6 = start_address */
  18. mov.l 10f,r8 /* PAGE_SIZE */
  19. /* stack setting */
  20. add r8,r5
  21. mov r5,r15
  22. bra 1f
  23. mov r4,r0 /* cmd = indirection_page */
  24. 0:
  25. mov.l @r4+,r0 /* cmd = *ind++ */
  26. 1: /* addr = cmd & 0xfffffff0 */
  27. mov r0,r2
  28. mov #-16,r1
  29. and r1,r2
  30. /* if(cmd & IND_DESTINATION) dst = addr */
  31. tst #1,r0
  32. bt 2f
  33. bra 0b
  34. mov r2,r5
  35. 2: /* else if(cmd & IND_INDIRECTION) ind = addr */
  36. tst #2,r0
  37. bt 3f
  38. bra 0b
  39. mov r2,r4
  40. 3: /* else if(cmd & IND_DONE) goto 6 */
  41. tst #4,r0
  42. bt 4f
  43. bra 6f
  44. nop
  45. 4: /* else if(cmd & IND_SOURCE) memcpy(dst,addr,PAGE_SIZE) */
  46. tst #8,r0
  47. bt 0b
  48. mov r8,r3
  49. shlr2 r3
  50. shlr2 r3
  51. 5:
  52. dt r3
  53. mov.l @r2+,r1 /* 16n+0 */
  54. mov.l r1,@r5
  55. add #4,r5
  56. mov.l @r2+,r1 /* 16n+4 */
  57. mov.l r1,@r5
  58. add #4,r5
  59. mov.l @r2+,r1 /* 16n+8 */
  60. mov.l r1,@r5
  61. add #4,r5
  62. mov.l @r2+,r1 /* 16n+12 */
  63. mov.l r1,@r5
  64. add #4,r5
  65. bf 5b
  66. bra 0b
  67. nop
  68. 6:
  69. jmp @r6
  70. nop
  71. .align 2
  72. 10:
  73. .long PAGE_SIZE
  74. relocate_new_kernel_end:
  75. .globl relocate_new_kernel_size
  76. relocate_new_kernel_size:
  77. .long relocate_new_kernel_end - relocate_new_kernel