Commit c7e29876 authored by Anton Blanchard's avatar Anton Blanchard

ppc64: merge some 2.4 fixes

parent 47c4b10b
...@@ -36,6 +36,12 @@ ...@@ -36,6 +36,12 @@
#define DO_SOFT_DISABLE #define DO_SOFT_DISABLE
#endif #endif
/*
* hcall interface to pSeries LPAR
*/
#define HSC .long 0x44000022
#define H_SET_ASR 0x30
/* /*
* We layout physical memory as follows: * We layout physical memory as follows:
* 0x0000 - 0x00ff : Secondary processor spin code * 0x0000 - 0x00ff : Secondary processor spin code
...@@ -152,7 +158,7 @@ _GLOBAL(__secondary_hold) ...@@ -152,7 +158,7 @@ _GLOBAL(__secondary_hold)
*/ */
/* /*
* This is the start of the interrupt handlers for Pseries * This is the start of the interrupt handlers for pSeries
* This code runs with relocation off. * This code runs with relocation off.
*/ */
#define EX_SRR0 0 #define EX_SRR0 0
...@@ -1025,6 +1031,17 @@ SLB_NUM_ENTRIES = 64 ...@@ -1025,6 +1031,17 @@ SLB_NUM_ENTRIES = 64
ori r20,r20,256 /* map kernel region with large ptes */ ori r20,r20,256 /* map kernel region with large ptes */
#endif #endif
/*
* XXX we should handle this in the exception exit path in 2.5,
* we need to make this path quick - Anton
*/
/* Invalidate the old entry */
slbmfee r21,r22
lis r23,-2049
ori r23,r23,65535
and r21,r21,r23
slbie r21
/* Put together the esid portion of the entry. */ /* Put together the esid portion of the entry. */
mfspr r21,DAR /* Get the new esid */ mfspr r21,DAR /* Get the new esid */
rldicl r21,r21,36,28 /* Permits a full 36b of ESID */ rldicl r21,r21,36,28 /* Permits a full 36b of ESID */
...@@ -1522,7 +1539,17 @@ _GLOBAL(__secondary_start) ...@@ -1522,7 +1539,17 @@ _GLOBAL(__secondary_start)
ori r3,r3,4 /* 0x8000000000000004 */ ori r3,r3,4 /* 0x8000000000000004 */
sc /* HvCall_setASR */ sc /* HvCall_setASR */
#else #else
/* set the ASR */
addi r3,0,0x4000 /* r3 = ptr to naca */
lhz r3,PLATFORM(r3) /* r3 = platform flags */
cmpldi r3,PLATFORM_PSERIES_LPAR
bne 98f
li r3,H_SET_ASR /* hcall = H_SET_ASR */
HSC /* Invoking hcall */
b 99f
98: /* This is not a hypervisor machine */
mtasr r4 /* set the stab location */ mtasr r4 /* set the stab location */
99:
#endif #endif
li r7,0 li r7,0
mtlr r7 mtlr r7
...@@ -1651,17 +1678,34 @@ _STATIC(start_here_pSeries) ...@@ -1651,17 +1678,34 @@ _STATIC(start_here_pSeries)
mtspr SPRG3,r6 /* PPPBBB: Temp... -Peter */ mtspr SPRG3,r6 /* PPPBBB: Temp... -Peter */
ld r3,PACASTABREAL(r6) ld r3,PACASTABREAL(r6)
ori r4,r3,1 /* turn on valid bit */ ori r4,r3,1 /* turn on valid bit */
/* set the ASR */
addi r3,0,0x4000 /* r3 = ptr to naca */
lhz r3,PLATFORM(r3) /* r3 = platform flags */
cmpldi r3,PLATFORM_PSERIES_LPAR
bne 98f
li r3,H_SET_ASR /* hcall = H_SET_ASR */
HSC /* Invoking hcall */
b 99f
98: /* This is not a hypervisor machine */
mtasr r4 /* set the stab location */ mtasr r4 /* set the stab location */
99:
mfspr r6,SPRG3
ld r3,PACASTABREAL(r6) /* restore r3 for stab_initialize */
/* Initialize an initial memory mapping and turn on relocation. */ /* Initialize an initial memory mapping and turn on relocation. */
bl .stab_initialize bl .stab_initialize
bl .htab_initialize bl .htab_initialize
LOADADDR(r6,_SDR1) addi r3,0,0x4000 /* r3 = ptr to naca */
lhz r3,PLATFORM(r3) /* r3 = platform flags */
cmpldi r3,PLATFORM_PSERIES
bne 98f
LOADADDR(r6,_SDR1) /* Only if NOT LPAR */
sub r6,r6,r26 sub r6,r6,r26
ld r6,0(r6) /* get the value of _SDR1 */ ld r6,0(r6) /* get the value of _SDR1 */
mtspr SDR1,r6 /* set the htab location */ mtspr SDR1,r6 /* set the htab location */
98:
LOADADDR(r3,.start_here_common) LOADADDR(r3,.start_here_common)
SET_REG_TO_CONST(r4, MSR_KERNEL) SET_REG_TO_CONST(r4, MSR_KERNEL)
mtspr SRR0,r3 mtspr SRR0,r3
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment