Эх сурвалжийг харах

[SPARC64]: Mark most of initial bootup asm as .text.init.ref_ok

We can't mark the whole thing init because there are dependencies
in bootloaders that assume that _start, or whatever the image
entry value, is 2 instructions before the "HdrS" signature.

In fact, TILO assumes this entry is always at 0x4000, yikes!

Also, right after the bootloader info area there are OBP strings and
values that get used later in the boot process, and those are not all
provably .init yet.

Signed-off-by: David S. Miller <davem@davemloft.net>
David S. Miller 18 жил өмнө
parent
commit
1966287dfa

+ 7 - 4
arch/sparc64/kernel/head.S

@@ -1,15 +1,15 @@
-/* $Id: head.S,v 1.87 2002/02/09 19:49:31 davem Exp $
- * head.S: Initial boot code for the Sparc64 port of Linux.
+/* head.S: Initial boot code for the Sparc64 port of Linux.
  *
  *
- * Copyright (C) 1996,1997 David S. Miller (davem@caip.rutgers.edu)
+ * Copyright (C) 1996, 1997, 2007 David S. Miller (davem@davemloft.net)
  * Copyright (C) 1996 David Sitsky (David.Sitsky@anu.edu.au)
  * Copyright (C) 1996 David Sitsky (David.Sitsky@anu.edu.au)
- * Copyright (C) 1997,1998 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
+ * Copyright (C) 1997, 1998 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
  * Copyright (C) 1997 Miguel de Icaza (miguel@nuclecu.unam.mx)
  * Copyright (C) 1997 Miguel de Icaza (miguel@nuclecu.unam.mx)
  */
  */
 
 
 #include <linux/version.h>
 #include <linux/version.h>
 #include <linux/errno.h>
 #include <linux/errno.h>
 #include <linux/threads.h>
 #include <linux/threads.h>
+#include <linux/init.h>
 #include <asm/thread_info.h>
 #include <asm/thread_info.h>
 #include <asm/asi.h>
 #include <asm/asi.h>
 #include <asm/pstate.h>
 #include <asm/pstate.h>
@@ -374,6 +374,7 @@ jump_to_sun4u_init:
 	jmpl    %g2 + %g0, %g0
 	jmpl    %g2 + %g0, %g0
 	 nop
 	 nop
 
 
+	.section	.text.init.refok
 sun4u_init:
 sun4u_init:
 	BRANCH_IF_SUN4V(g1, sun4v_init)
 	BRANCH_IF_SUN4V(g1, sun4v_init)
 
 
@@ -529,6 +530,8 @@ tlb_fixup_done:
 	 nop
 	 nop
 	/* Not reached... */
 	/* Not reached... */
 
 
+	.previous
+
 	/* This is meant to allow the sharing of this code between
 	/* This is meant to allow the sharing of this code between
 	 * boot processor invocation (via setup_tba() below) and
 	 * boot processor invocation (via setup_tba() below) and
 	 * secondary processor startup (via trampoline.S).  The
 	 * secondary processor startup (via trampoline.S).  The