head31.S 998 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Startup glue code to uncompress the kernel
  3. *
  4. * Copyright IBM Corp. 2010
  5. *
  6. * Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com>
  7. */
  8. #include <linux/init.h>
  9. #include <linux/linkage.h>
  10. #include <asm/asm-offsets.h>
  11. #include <asm/thread_info.h>
  12. #include <asm/page.h>
  13. #include "sizes.h"
  14. __HEAD
  15. ENTRY(startup_continue)
  16. basr %r13,0 # get base
  17. .LPG1:
  18. # setup stack
  19. l %r15,.Lstack-.LPG1(%r13)
  20. ahi %r15,-96
  21. l %r1,.Ldecompress-.LPG1(%r13)
  22. basr %r14,%r1
  23. # setup registers for memory mover & branch to target
  24. lr %r4,%r2
  25. l %r2,.Loffset-.LPG1(%r13)
  26. la %r4,0(%r2,%r4)
  27. l %r3,.Lmvsize-.LPG1(%r13)
  28. lr %r5,%r3
  29. # move the memory mover someplace safe
  30. la %r1,0x200
  31. mvc 0(mover_end-mover,%r1),mover-.LPG1(%r13)
  32. # decompress image is started at 0x11000
  33. lr %r6,%r2
  34. br %r1
  35. mover:
  36. mvcle %r2,%r4,0
  37. jo mover
  38. br %r6
  39. mover_end:
  40. .align 8
  41. .Lstack:
  42. .long 0x8000 + (1<<(PAGE_SHIFT+THREAD_ORDER))
  43. .Ldecompress:
  44. .long decompress_kernel
  45. .Loffset:
  46. .long 0x11000
  47. .Lmvsize:
  48. .long SZ__bss_start