Files
linux-apfs/arch/mips/kernel/relocate_kernel.S
T

83 lines
1.6 KiB
ArmAsm
Raw Normal View History

2006-10-18 15:14:55 +02:00
/*
* relocate_kernel.S for kexec
* Created by <nschichan@corp.free.fr> on Thu Oct 12 17:49:57 2006
*
* This source code is licensed under the GNU General Public License,
* Version 2. See the file COPYING for more details.
*/
#include <asm/asm.h>
#include <asm/asmmacro.h>
#include <asm/regdef.h>
#include <asm/page.h>
#include <asm/mipsregs.h>
#include <asm/stackframe.h>
#include <asm/addrspace.h>
2007-07-31 15:17:21 +01:00
LEAF(relocate_new_kernel)
PTR_L s0, kexec_indirection_page
PTR_L s1, kexec_start_address
2006-10-18 15:14:55 +02:00
process_entry:
2007-07-31 15:17:21 +01:00
PTR_L s2, (s0)
PTR_ADD s0, s0, SZREG
2006-10-18 15:14:55 +02:00
/* destination page */
2007-07-31 15:17:21 +01:00
and s3, s2, 0x1
beq s3, zero, 1f
and s4, s2, ~0x1 /* store destination addr in s4 */
move a0, s4
b process_entry
2006-10-18 15:14:55 +02:00
1:
/* indirection page, update s0 */
2007-07-31 15:17:21 +01:00
and s3, s2, 0x2
beq s3, zero, 1f
and s0, s2, ~0x2
b process_entry
2006-10-18 15:14:55 +02:00
1:
/* done page */
2007-07-31 15:17:21 +01:00
and s3, s2, 0x4
beq s3, zero, 1f
b done
2006-10-18 15:14:55 +02:00
1:
/* source page */
2007-07-31 15:17:21 +01:00
and s3, s2, 0x8
beq s3, zero, process_entry
and s2, s2, ~0x8
li s6, (1 << PAGE_SHIFT) / SZREG
2006-10-18 15:14:55 +02:00
copy_word:
/* copy page word by word */
2007-07-31 15:17:21 +01:00
REG_L s5, (s2)
REG_S s5, (s4)
PTR_ADD s4, s4, SZREG
PTR_ADD s2, s2, SZREG
LONG_SUB s6, s6, 1
beq s6, zero, process_entry
b copy_word
b process_entry
2006-10-18 15:14:55 +02:00
done:
/* jump to kexec_start_address */
2007-07-31 15:17:21 +01:00
j s1
END(relocate_new_kernel)
2006-10-18 15:14:55 +02:00
kexec_start_address:
2007-07-31 15:17:21 +01:00
EXPORT(kexec_start_address)
PTR 0x0
.size kexec_start_address, PTRSIZE
2006-10-18 15:14:55 +02:00
kexec_indirection_page:
2007-07-31 15:17:21 +01:00
EXPORT(kexec_indirection_page)
PTR 0
.size kexec_indirection_page, PTRSIZE
2006-10-18 15:14:55 +02:00
relocate_new_kernel_end:
relocate_new_kernel_size:
2007-07-31 15:17:21 +01:00
EXPORT(relocate_new_kernel_size)
PTR relocate_new_kernel_end - relocate_new_kernel
.size relocate_new_kernel_size, PTRSIZE