2 * arch/alpha/kernel/head.S
4 * initial boot stuff.. At this point, the bootloader has already
5 * switched into OSF/1 PAL-code, and loaded us at the correct address
6 * (START_ADDR). So there isn't much left for us to do: just set up
7 * the kernel global pointer and jump to the kernel entry-point.
10 #include <asm/system.h>
11 #include <asm/asm-offsets.h>
15 swapper_pg_dir=SWAPPER_PGD
25 /* We need to get current_task_info loaded up... */
26 lda $8,init_thread_union
27 /* ... and find our stack ... */
28 lda $30,0x4000 - SIZEOF_PT_REGS($8)
29 /* ... and then we can start the kernel. */
38 /* On entry here from SRM console, the HWPCB of the per-cpu
39 slot for this processor has been loaded. We've arranged
40 for the UNIQUE value for this process to contain the PCBB
41 of the target idle task. */
44 ldgp $29,0($27) # First order of business, load the GP.
46 call_pal PAL_rduniq # Grab the target PCBB.
47 mov $0,$16 # Install it.
50 lda $8,0x3fff # Find "current".
56 #endif /* CONFIG_SMP */
59 # The following two functions are needed for supporting SRM PALcode
60 # on the PC164 (at least), since that PALcode manages the interrupt
61 # masking, and we cannot duplicate the effort without causing problems
87 # It is handy, on occasion, to make halt actually just loop.
88 # Putting it here means we dont have to recompile the whole