2  * relocate_kernel.S - put the kernel image in place to boot
 
   3  * Copyright (C) 2002-2003 Eric Biederman  <ebiederm@xmission.com>
 
   5  * GameCube/ppc32 port Copyright (C) 2004 Albert Herranz
 
   7  * This source code is licensed under the GNU General Public License,
 
   8  * Version 2.  See the file COPYING for more details.
 
  12 #include <asm/ppc_asm.h>
 
  13 #include <asm/processor.h>
 
  15 #include <asm/kexec.h>
 
  17 #define PAGE_SIZE      4096 /* must be same value as in <asm/page.h> */
 
  20          * Must be relocatable PIC code callable as a C function.
 
  22         .globl relocate_new_kernel
 
  25         /* r4 = reboot_code_buffer */
 
  26         /* r5 = start_address      */
 
  31          * Set Machine Status Register to a known status,
 
  32          * switch the MMU off and jump to 1: in a single step.
 
  36         ori     r8, r8, MSR_RI|MSR_ME
 
  38         addi    r8, r4, 1f - relocate_new_kernel
 
  44         /* from this point address translation is turned off */
 
  45         /* and interrupts are disabled */
 
  47         /* set a new stack at the bottom of our page... */
 
  48         /* (not really needed now) */
 
  49         addi    r1, r4, KEXEC_CONTROL_CODE_SIZE - 8 /* for LR Save+Back Chain */
 
  53         li      r6, 0 /* checksum */
 
  57 0:      /* top, read another word for the indirection page */
 
  61         /* is it a destination page? (r8) */
 
  62         rlwinm. r7, r0, 0, 31, 31 /* IND_DESTINATION (1<<0) */
 
  65         rlwinm  r8, r0, 0, 0, 19 /* clear kexec flags, page align */
 
  68 2:      /* is it an indirection page? (r3) */
 
  69         rlwinm. r7, r0, 0, 30, 30 /* IND_INDIRECTION (1<<1) */
 
  72         rlwinm  r3, r0, 0, 0, 19 /* clear kexec flags, page align */
 
  77         rlwinm. r7, r0, 0, 29, 29 /* IND_DONE (1<<2) */
 
  81 2:      /* is it a source page? (r9) */
 
  82         rlwinm. r7, r0, 0, 28, 28 /* IND_SOURCE (1<<3) */
 
  85         rlwinm  r9, r0, 0, 0, 19 /* clear kexec flags, page align */
 
  92         lwzu    r0, 4(r9)  /* do the copy */
 
 106         /* To be certain of avoiding problems with self-modifying code
 
 107          * execute a serializing instruction here.
 
 112         /* jump to the entry point, usually the setup routine */
 
 118 relocate_new_kernel_end:
 
 120         .globl relocate_new_kernel_size
 
 121 relocate_new_kernel_size:
 
 122         .long relocate_new_kernel_end - relocate_new_kernel