X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=arch%2Fs390%2Fkernel%2Frelocate_kernel64.S;h=7c3ce589a7f0cdb3ceef2b08d24977b504f80a23;hb=144d634a21caff1d54cb4bb0d073774e88130045;hp=4fb443042d9cc39bd64cf8502aed48636cd608bd;hpb=e993835441734c184d70d3716eed78a08eeb71c2;p=deliverable%2Flinux.git diff --git a/arch/s390/kernel/relocate_kernel64.S b/arch/s390/kernel/relocate_kernel64.S index 4fb443042d9c..7c3ce589a7f0 100644 --- a/arch/s390/kernel/relocate_kernel64.S +++ b/arch/s390/kernel/relocate_kernel64.S @@ -8,6 +8,8 @@ * */ +#include + /* * moves the new kernel to its destination... * %r2 = pointer to first kimage_entry_t @@ -23,12 +25,10 @@ */ .text - .globl relocate_kernel - relocate_kernel: +ENTRY(relocate_kernel) basr %r13,0 # base address .base: - stnsm sys_msk-.base(%r13),0xf8 # disable DAT and IRQs - spx zero64-.base(%r13) # absolute addressing mode + stnsm sys_msk-.base(%r13),0xfb # disable DAT stctg %c0,%c15,ctlregs-.base(%r13) stmg %r0,%r15,gprregs-.base(%r13) lghi %r0,3 @@ -100,8 +100,6 @@ lpsw 0 # hopefully start new kernel... .align 8 - zero64: - .quad 0 load_psw: .long 0x00080000,0x80000000 sys_msk: @@ -118,6 +116,7 @@ .byte 0 .align 8 relocate_kernel_end: + .align 8 .globl relocate_kernel_len relocate_kernel_len: .quad relocate_kernel_end - relocate_kernel