aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/ppc64/kernel/entry.S30
-rw-r--r--arch/ppc64/kernel/head.S194
2 files changed, 112 insertions, 112 deletions
diff --git a/arch/ppc64/kernel/entry.S b/arch/ppc64/kernel/entry.S
index e8c0bbf4d000..ea30af810e0c 100644
--- a/arch/ppc64/kernel/entry.S
+++ b/arch/ppc64/kernel/entry.S
@@ -191,8 +191,8 @@ syscall_exit_trace_cont:
191 ld r1,GPR1(r1) 191 ld r1,GPR1(r1)
192 mtlr r4 192 mtlr r4
193 mtcr r5 193 mtcr r5
194 mtspr SRR0,r7 194 mtspr SPRN_SRR0,r7
195 mtspr SRR1,r8 195 mtspr SPRN_SRR1,r8
196 rfid 196 rfid
197 b . /* prevent speculative execution */ 197 b . /* prevent speculative execution */
198 198
@@ -531,7 +531,7 @@ restore:
531 mtctr r3 531 mtctr r3
532 mtlr r0 532 mtlr r0
533 ld r3,_XER(r1) 533 ld r3,_XER(r1)
534 mtspr XER,r3 534 mtspr SPRN_XER,r3
535 535
536 REST_8GPRS(5, r1) 536 REST_8GPRS(5, r1)
537 537
@@ -543,12 +543,12 @@ restore:
543 mtmsrd r0,1 543 mtmsrd r0,1
544 544
545 ld r0,_MSR(r1) 545 ld r0,_MSR(r1)
546 mtspr SRR1,r0 546 mtspr SPRN_SRR1,r0
547 547
548 ld r2,_CCR(r1) 548 ld r2,_CCR(r1)
549 mtcrf 0xFF,r2 549 mtcrf 0xFF,r2
550 ld r2,_NIP(r1) 550 ld r2,_NIP(r1)
551 mtspr SRR0,r2 551 mtspr SPRN_SRR0,r2
552 552
553 ld r0,GPR0(r1) 553 ld r0,GPR0(r1)
554 ld r2,GPR2(r1) 554 ld r2,GPR2(r1)
@@ -643,7 +643,7 @@ _GLOBAL(enter_rtas)
643 std r4,_CCR(r1) 643 std r4,_CCR(r1)
644 mfctr r5 644 mfctr r5
645 std r5,_CTR(r1) 645 std r5,_CTR(r1)
646 mfspr r6,XER 646 mfspr r6,SPRN_XER
647 std r6,_XER(r1) 647 std r6,_XER(r1)
648 mfdar r7 648 mfdar r7
649 std r7,_DAR(r1) 649 std r7,_DAR(r1)
@@ -697,14 +697,14 @@ _GLOBAL(enter_rtas)
697 ld r5,RTASENTRY(r4) /* get the rtas->entry value */ 697 ld r5,RTASENTRY(r4) /* get the rtas->entry value */
698 ld r4,RTASBASE(r4) /* get the rtas->base value */ 698 ld r4,RTASBASE(r4) /* get the rtas->base value */
699 699
700 mtspr SRR0,r5 700 mtspr SPRN_SRR0,r5
701 mtspr SRR1,r6 701 mtspr SPRN_SRR1,r6
702 rfid 702 rfid
703 b . /* prevent speculative execution */ 703 b . /* prevent speculative execution */
704 704
705_STATIC(rtas_return_loc) 705_STATIC(rtas_return_loc)
706 /* relocation is off at this point */ 706 /* relocation is off at this point */
707 mfspr r4,SPRG3 /* Get PACA */ 707 mfspr r4,SPRN_SPRG3 /* Get PACA */
708 SET_REG_TO_CONST(r5, KERNELBASE) 708 SET_REG_TO_CONST(r5, KERNELBASE)
709 sub r4,r4,r5 /* RELOC the PACA base pointer */ 709 sub r4,r4,r5 /* RELOC the PACA base pointer */
710 710
@@ -718,8 +718,8 @@ _STATIC(rtas_return_loc)
718 LOADADDR(r3,.rtas_restore_regs) 718 LOADADDR(r3,.rtas_restore_regs)
719 ld r4,PACASAVEDMSR(r4) /* Restore our MSR */ 719 ld r4,PACASAVEDMSR(r4) /* Restore our MSR */
720 720
721 mtspr SRR0,r3 721 mtspr SPRN_SRR0,r3
722 mtspr SRR1,r4 722 mtspr SPRN_SRR1,r4
723 rfid 723 rfid
724 b . /* prevent speculative execution */ 724 b . /* prevent speculative execution */
725 725
@@ -730,14 +730,14 @@ _STATIC(rtas_restore_regs)
730 REST_8GPRS(14, r1) /* Restore the non-volatiles */ 730 REST_8GPRS(14, r1) /* Restore the non-volatiles */
731 REST_10GPRS(22, r1) /* ditto */ 731 REST_10GPRS(22, r1) /* ditto */
732 732
733 mfspr r13,SPRG3 733 mfspr r13,SPRN_SPRG3
734 734
735 ld r4,_CCR(r1) 735 ld r4,_CCR(r1)
736 mtcr r4 736 mtcr r4
737 ld r5,_CTR(r1) 737 ld r5,_CTR(r1)
738 mtctr r5 738 mtctr r5
739 ld r6,_XER(r1) 739 ld r6,_XER(r1)
740 mtspr XER,r6 740 mtspr SPRN_XER,r6
741 ld r7,_DAR(r1) 741 ld r7,_DAR(r1)
742 mtdar r7 742 mtdar r7
743 ld r8,_DSISR(r1) 743 ld r8,_DSISR(r1)
@@ -774,7 +774,7 @@ _GLOBAL(enter_prom)
774 std r4,_CCR(r1) 774 std r4,_CCR(r1)
775 mfctr r5 775 mfctr r5
776 std r5,_CTR(r1) 776 std r5,_CTR(r1)
777 mfspr r6,XER 777 mfspr r6,SPRN_XER
778 std r6,_XER(r1) 778 std r6,_XER(r1)
779 mfdar r7 779 mfdar r7
780 std r7,_DAR(r1) 780 std r7,_DAR(r1)
@@ -827,7 +827,7 @@ _GLOBAL(enter_prom)
827 ld r5,_CTR(r1) 827 ld r5,_CTR(r1)
828 mtctr r5 828 mtctr r5
829 ld r6,_XER(r1) 829 ld r6,_XER(r1)
830 mtspr XER,r6 830 mtspr SPRN_XER,r6
831 ld r7,_DAR(r1) 831 ld r7,_DAR(r1)
832 mtdar r7 832 mtdar r7
833 ld r8,_DSISR(r1) 833 ld r8,_DSISR(r1)
diff --git a/arch/ppc64/kernel/head.S b/arch/ppc64/kernel/head.S
index db0cd3587627..d5e6be200764 100644
--- a/arch/ppc64/kernel/head.S
+++ b/arch/ppc64/kernel/head.S
@@ -201,22 +201,22 @@ exception_marker:
201#define EX_CCR 60 201#define EX_CCR 60
202 202
203#define EXCEPTION_PROLOG_PSERIES(area, label) \ 203#define EXCEPTION_PROLOG_PSERIES(area, label) \
204 mfspr r13,SPRG3; /* get paca address into r13 */ \ 204 mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
205 std r9,area+EX_R9(r13); /* save r9 - r12 */ \ 205 std r9,area+EX_R9(r13); /* save r9 - r12 */ \
206 std r10,area+EX_R10(r13); \ 206 std r10,area+EX_R10(r13); \
207 std r11,area+EX_R11(r13); \ 207 std r11,area+EX_R11(r13); \
208 std r12,area+EX_R12(r13); \ 208 std r12,area+EX_R12(r13); \
209 mfspr r9,SPRG1; \ 209 mfspr r9,SPRN_SPRG1; \
210 std r9,area+EX_R13(r13); \ 210 std r9,area+EX_R13(r13); \
211 mfcr r9; \ 211 mfcr r9; \
212 clrrdi r12,r13,32; /* get high part of &label */ \ 212 clrrdi r12,r13,32; /* get high part of &label */ \
213 mfmsr r10; \ 213 mfmsr r10; \
214 mfspr r11,SRR0; /* save SRR0 */ \ 214 mfspr r11,SPRN_SRR0; /* save SRR0 */ \
215 ori r12,r12,(label)@l; /* virt addr of handler */ \ 215 ori r12,r12,(label)@l; /* virt addr of handler */ \
216 ori r10,r10,MSR_IR|MSR_DR|MSR_RI; \ 216 ori r10,r10,MSR_IR|MSR_DR|MSR_RI; \
217 mtspr SRR0,r12; \ 217 mtspr SPRN_SRR0,r12; \
218 mfspr r12,SRR1; /* and SRR1 */ \ 218 mfspr r12,SPRN_SRR1; /* and SRR1 */ \
219 mtspr SRR1,r10; \ 219 mtspr SPRN_SRR1,r10; \
220 rfid; \ 220 rfid; \
221 b . /* prevent speculative execution */ 221 b . /* prevent speculative execution */
222 222
@@ -225,12 +225,12 @@ exception_marker:
225 * This code runs with relocation on. 225 * This code runs with relocation on.
226 */ 226 */
227#define EXCEPTION_PROLOG_ISERIES_1(area) \ 227#define EXCEPTION_PROLOG_ISERIES_1(area) \
228 mfspr r13,SPRG3; /* get paca address into r13 */ \ 228 mfspr r13,SPRN_SPRG3; /* get paca address into r13 */ \
229 std r9,area+EX_R9(r13); /* save r9 - r12 */ \ 229 std r9,area+EX_R9(r13); /* save r9 - r12 */ \
230 std r10,area+EX_R10(r13); \ 230 std r10,area+EX_R10(r13); \
231 std r11,area+EX_R11(r13); \ 231 std r11,area+EX_R11(r13); \
232 std r12,area+EX_R12(r13); \ 232 std r12,area+EX_R12(r13); \
233 mfspr r9,SPRG1; \ 233 mfspr r9,SPRN_SPRG1; \
234 std r9,area+EX_R13(r13); \ 234 std r9,area+EX_R13(r13); \
235 mfcr r9 235 mfcr r9
236 236
@@ -283,7 +283,7 @@ exception_marker:
283 std r9,_LINK(r1); \ 283 std r9,_LINK(r1); \
284 mfctr r10; /* save CTR in stackframe */ \ 284 mfctr r10; /* save CTR in stackframe */ \
285 std r10,_CTR(r1); \ 285 std r10,_CTR(r1); \
286 mfspr r11,XER; /* save XER in stackframe */ \ 286 mfspr r11,SPRN_XER; /* save XER in stackframe */ \
287 std r11,_XER(r1); \ 287 std r11,_XER(r1); \
288 li r9,(n)+1; \ 288 li r9,(n)+1; \
289 std r9,_TRAP(r1); /* set trap number */ \ 289 std r9,_TRAP(r1); /* set trap number */ \
@@ -300,7 +300,7 @@ exception_marker:
300 .globl label##_pSeries; \ 300 .globl label##_pSeries; \
301label##_pSeries: \ 301label##_pSeries: \
302 HMT_MEDIUM; \ 302 HMT_MEDIUM; \
303 mtspr SPRG1,r13; /* save r13 */ \ 303 mtspr SPRN_SPRG1,r13; /* save r13 */ \
304 RUNLATCH_ON(r13); \ 304 RUNLATCH_ON(r13); \
305 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, label##_common) 305 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, label##_common)
306 306
@@ -308,7 +308,7 @@ label##_pSeries: \
308 .globl label##_iSeries; \ 308 .globl label##_iSeries; \
309label##_iSeries: \ 309label##_iSeries: \
310 HMT_MEDIUM; \ 310 HMT_MEDIUM; \
311 mtspr SPRG1,r13; /* save r13 */ \ 311 mtspr SPRN_SPRG1,r13; /* save r13 */ \
312 RUNLATCH_ON(r13); \ 312 RUNLATCH_ON(r13); \
313 EXCEPTION_PROLOG_ISERIES_1(area); \ 313 EXCEPTION_PROLOG_ISERIES_1(area); \
314 EXCEPTION_PROLOG_ISERIES_2; \ 314 EXCEPTION_PROLOG_ISERIES_2; \
@@ -318,7 +318,7 @@ label##_iSeries: \
318 .globl label##_iSeries; \ 318 .globl label##_iSeries; \
319label##_iSeries: \ 319label##_iSeries: \
320 HMT_MEDIUM; \ 320 HMT_MEDIUM; \
321 mtspr SPRG1,r13; /* save r13 */ \ 321 mtspr SPRN_SPRG1,r13; /* save r13 */ \
322 RUNLATCH_ON(r13); \ 322 RUNLATCH_ON(r13); \
323 EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN); \ 323 EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN); \
324 lbz r10,PACAPROCENABLED(r13); \ 324 lbz r10,PACAPROCENABLED(r13); \
@@ -388,7 +388,7 @@ __start_interrupts:
388 . = 0x200 388 . = 0x200
389_machine_check_pSeries: 389_machine_check_pSeries:
390 HMT_MEDIUM 390 HMT_MEDIUM
391 mtspr SPRG1,r13 /* save r13 */ 391 mtspr SPRN_SPRG1,r13 /* save r13 */
392 RUNLATCH_ON(r13) 392 RUNLATCH_ON(r13)
393 EXCEPTION_PROLOG_PSERIES(PACA_EXMC, machine_check_common) 393 EXCEPTION_PROLOG_PSERIES(PACA_EXMC, machine_check_common)
394 394
@@ -396,18 +396,18 @@ _machine_check_pSeries:
396 .globl data_access_pSeries 396 .globl data_access_pSeries
397data_access_pSeries: 397data_access_pSeries:
398 HMT_MEDIUM 398 HMT_MEDIUM
399 mtspr SPRG1,r13 399 mtspr SPRN_SPRG1,r13
400BEGIN_FTR_SECTION 400BEGIN_FTR_SECTION
401 mtspr SPRG2,r12 401 mtspr SPRN_SPRG2,r12
402 mfspr r13,DAR 402 mfspr r13,SPRN_DAR
403 mfspr r12,DSISR 403 mfspr r12,SPRN_DSISR
404 srdi r13,r13,60 404 srdi r13,r13,60
405 rlwimi r13,r12,16,0x20 405 rlwimi r13,r12,16,0x20
406 mfcr r12 406 mfcr r12
407 cmpwi r13,0x2c 407 cmpwi r13,0x2c
408 beq .do_stab_bolted_pSeries 408 beq .do_stab_bolted_pSeries
409 mtcrf 0x80,r12 409 mtcrf 0x80,r12
410 mfspr r12,SPRG2 410 mfspr r12,SPRN_SPRG2
411END_FTR_SECTION_IFCLR(CPU_FTR_SLB) 411END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
412 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, data_access_common) 412 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, data_access_common)
413 413
@@ -415,19 +415,19 @@ END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
415 .globl data_access_slb_pSeries 415 .globl data_access_slb_pSeries
416data_access_slb_pSeries: 416data_access_slb_pSeries:
417 HMT_MEDIUM 417 HMT_MEDIUM
418 mtspr SPRG1,r13 418 mtspr SPRN_SPRG1,r13
419 RUNLATCH_ON(r13) 419 RUNLATCH_ON(r13)
420 mfspr r13,SPRG3 /* get paca address into r13 */ 420 mfspr r13,SPRN_SPRG3 /* get paca address into r13 */
421 std r9,PACA_EXSLB+EX_R9(r13) /* save r9 - r12 */ 421 std r9,PACA_EXSLB+EX_R9(r13) /* save r9 - r12 */
422 std r10,PACA_EXSLB+EX_R10(r13) 422 std r10,PACA_EXSLB+EX_R10(r13)
423 std r11,PACA_EXSLB+EX_R11(r13) 423 std r11,PACA_EXSLB+EX_R11(r13)
424 std r12,PACA_EXSLB+EX_R12(r13) 424 std r12,PACA_EXSLB+EX_R12(r13)
425 std r3,PACA_EXSLB+EX_R3(r13) 425 std r3,PACA_EXSLB+EX_R3(r13)
426 mfspr r9,SPRG1 426 mfspr r9,SPRN_SPRG1
427 std r9,PACA_EXSLB+EX_R13(r13) 427 std r9,PACA_EXSLB+EX_R13(r13)
428 mfcr r9 428 mfcr r9
429 mfspr r12,SRR1 /* and SRR1 */ 429 mfspr r12,SPRN_SRR1 /* and SRR1 */
430 mfspr r3,DAR 430 mfspr r3,SPRN_DAR
431 b .do_slb_miss /* Rel. branch works in real mode */ 431 b .do_slb_miss /* Rel. branch works in real mode */
432 432
433 STD_EXCEPTION_PSERIES(0x400, instruction_access) 433 STD_EXCEPTION_PSERIES(0x400, instruction_access)
@@ -436,19 +436,19 @@ data_access_slb_pSeries:
436 .globl instruction_access_slb_pSeries 436 .globl instruction_access_slb_pSeries
437instruction_access_slb_pSeries: 437instruction_access_slb_pSeries:
438 HMT_MEDIUM 438 HMT_MEDIUM
439 mtspr SPRG1,r13 439 mtspr SPRN_SPRG1,r13
440 RUNLATCH_ON(r13) 440 RUNLATCH_ON(r13)
441 mfspr r13,SPRG3 /* get paca address into r13 */ 441 mfspr r13,SPRN_SPRG3 /* get paca address into r13 */
442 std r9,PACA_EXSLB+EX_R9(r13) /* save r9 - r12 */ 442 std r9,PACA_EXSLB+EX_R9(r13) /* save r9 - r12 */
443 std r10,PACA_EXSLB+EX_R10(r13) 443 std r10,PACA_EXSLB+EX_R10(r13)
444 std r11,PACA_EXSLB+EX_R11(r13) 444 std r11,PACA_EXSLB+EX_R11(r13)
445 std r12,PACA_EXSLB+EX_R12(r13) 445 std r12,PACA_EXSLB+EX_R12(r13)
446 std r3,PACA_EXSLB+EX_R3(r13) 446 std r3,PACA_EXSLB+EX_R3(r13)
447 mfspr r9,SPRG1 447 mfspr r9,SPRN_SPRG1
448 std r9,PACA_EXSLB+EX_R13(r13) 448 std r9,PACA_EXSLB+EX_R13(r13)
449 mfcr r9 449 mfcr r9
450 mfspr r12,SRR1 /* and SRR1 */ 450 mfspr r12,SPRN_SRR1 /* and SRR1 */
451 mfspr r3,SRR0 /* SRR0 is faulting address */ 451 mfspr r3,SPRN_SRR0 /* SRR0 is faulting address */
452 b .do_slb_miss /* Rel. branch works in real mode */ 452 b .do_slb_miss /* Rel. branch works in real mode */
453 453
454 STD_EXCEPTION_PSERIES(0x500, hardware_interrupt) 454 STD_EXCEPTION_PSERIES(0x500, hardware_interrupt)
@@ -466,15 +466,15 @@ system_call_pSeries:
466 RUNLATCH_ON(r9) 466 RUNLATCH_ON(r9)
467 mr r9,r13 467 mr r9,r13
468 mfmsr r10 468 mfmsr r10
469 mfspr r13,SPRG3 469 mfspr r13,SPRN_SPRG3
470 mfspr r11,SRR0 470 mfspr r11,SPRN_SRR0
471 clrrdi r12,r13,32 471 clrrdi r12,r13,32
472 oris r12,r12,system_call_common@h 472 oris r12,r12,system_call_common@h
473 ori r12,r12,system_call_common@l 473 ori r12,r12,system_call_common@l
474 mtspr SRR0,r12 474 mtspr SPRN_SRR0,r12
475 ori r10,r10,MSR_IR|MSR_DR|MSR_RI 475 ori r10,r10,MSR_IR|MSR_DR|MSR_RI
476 mfspr r12,SRR1 476 mfspr r12,SPRN_SRR1
477 mtspr SRR1,r10 477 mtspr SPRN_SRR1,r10
478 rfid 478 rfid
479 b . /* prevent speculative execution */ 479 b . /* prevent speculative execution */
480 480
@@ -504,25 +504,25 @@ system_call_pSeries:
504 .align 7 504 .align 7
505_GLOBAL(do_stab_bolted_pSeries) 505_GLOBAL(do_stab_bolted_pSeries)
506 mtcrf 0x80,r12 506 mtcrf 0x80,r12
507 mfspr r12,SPRG2 507 mfspr r12,SPRN_SPRG2
508 EXCEPTION_PROLOG_PSERIES(PACA_EXSLB, .do_stab_bolted) 508 EXCEPTION_PROLOG_PSERIES(PACA_EXSLB, .do_stab_bolted)
509 509
510/* 510/*
511 * Vectors for the FWNMI option. Share common code. 511 * Vectors for the FWNMI option. Share common code.
512 */ 512 */
513 .globl system_reset_fwnmi 513 .globl system_reset_fwnmi
514system_reset_fwnmi: 514system_reset_fwnmi:
515 HMT_MEDIUM 515 HMT_MEDIUM
516 mtspr SPRG1,r13 /* save r13 */ 516 mtspr SPRN_SPRG1,r13 /* save r13 */
517 RUNLATCH_ON(r13) 517 RUNLATCH_ON(r13)
518 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, system_reset_common) 518 EXCEPTION_PROLOG_PSERIES(PACA_EXGEN, system_reset_common)
519 519
520 .globl machine_check_fwnmi 520 .globl machine_check_fwnmi
521machine_check_fwnmi: 521machine_check_fwnmi:
522 HMT_MEDIUM 522 HMT_MEDIUM
523 mtspr SPRG1,r13 /* save r13 */ 523 mtspr SPRN_SPRG1,r13 /* save r13 */
524 RUNLATCH_ON(r13) 524 RUNLATCH_ON(r13)
525 EXCEPTION_PROLOG_PSERIES(PACA_EXMC, machine_check_common) 525 EXCEPTION_PROLOG_PSERIES(PACA_EXMC, machine_check_common)
526 526
527#ifdef CONFIG_PPC_ISERIES 527#ifdef CONFIG_PPC_ISERIES
528/*** ISeries-LPAR interrupt handlers ***/ 528/*** ISeries-LPAR interrupt handlers ***/
@@ -531,18 +531,18 @@ machine_check_fwnmi:
531 531
532 .globl data_access_iSeries 532 .globl data_access_iSeries
533data_access_iSeries: 533data_access_iSeries:
534 mtspr SPRG1,r13 534 mtspr SPRN_SPRG1,r13
535BEGIN_FTR_SECTION 535BEGIN_FTR_SECTION
536 mtspr SPRG2,r12 536 mtspr SPRN_SPRG2,r12
537 mfspr r13,DAR 537 mfspr r13,SPRN_DAR
538 mfspr r12,DSISR 538 mfspr r12,SPRN_DSISR
539 srdi r13,r13,60 539 srdi r13,r13,60
540 rlwimi r13,r12,16,0x20 540 rlwimi r13,r12,16,0x20
541 mfcr r12 541 mfcr r12
542 cmpwi r13,0x2c 542 cmpwi r13,0x2c
543 beq .do_stab_bolted_iSeries 543 beq .do_stab_bolted_iSeries
544 mtcrf 0x80,r12 544 mtcrf 0x80,r12
545 mfspr r12,SPRG2 545 mfspr r12,SPRN_SPRG2
546END_FTR_SECTION_IFCLR(CPU_FTR_SLB) 546END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
547 EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN) 547 EXCEPTION_PROLOG_ISERIES_1(PACA_EXGEN)
548 EXCEPTION_PROLOG_ISERIES_2 548 EXCEPTION_PROLOG_ISERIES_2
@@ -550,25 +550,25 @@ END_FTR_SECTION_IFCLR(CPU_FTR_SLB)
550 550
551.do_stab_bolted_iSeries: 551.do_stab_bolted_iSeries:
552 mtcrf 0x80,r12 552 mtcrf 0x80,r12
553 mfspr r12,SPRG2 553 mfspr r12,SPRN_SPRG2
554 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB) 554 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB)
555 EXCEPTION_PROLOG_ISERIES_2 555 EXCEPTION_PROLOG_ISERIES_2
556 b .do_stab_bolted 556 b .do_stab_bolted
557 557
558 .globl data_access_slb_iSeries 558 .globl data_access_slb_iSeries
559data_access_slb_iSeries: 559data_access_slb_iSeries:
560 mtspr SPRG1,r13 /* save r13 */ 560 mtspr SPRN_SPRG1,r13 /* save r13 */
561 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB) 561 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB)
562 std r3,PACA_EXSLB+EX_R3(r13) 562 std r3,PACA_EXSLB+EX_R3(r13)
563 ld r12,PACALPPACA+LPPACASRR1(r13) 563 ld r12,PACALPPACA+LPPACASRR1(r13)
564 mfspr r3,DAR 564 mfspr r3,SPRN_DAR
565 b .do_slb_miss 565 b .do_slb_miss
566 566
567 STD_EXCEPTION_ISERIES(0x400, instruction_access, PACA_EXGEN) 567 STD_EXCEPTION_ISERIES(0x400, instruction_access, PACA_EXGEN)
568 568
569 .globl instruction_access_slb_iSeries 569 .globl instruction_access_slb_iSeries
570instruction_access_slb_iSeries: 570instruction_access_slb_iSeries:
571 mtspr SPRG1,r13 /* save r13 */ 571 mtspr SPRN_SPRG1,r13 /* save r13 */
572 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB) 572 EXCEPTION_PROLOG_ISERIES_1(PACA_EXSLB)
573 std r3,PACA_EXSLB+EX_R3(r13) 573 std r3,PACA_EXSLB+EX_R3(r13)
574 ld r12,PACALPPACA+LPPACASRR1(r13) 574 ld r12,PACALPPACA+LPPACASRR1(r13)
@@ -586,7 +586,7 @@ instruction_access_slb_iSeries:
586 .globl system_call_iSeries 586 .globl system_call_iSeries
587system_call_iSeries: 587system_call_iSeries:
588 mr r9,r13 588 mr r9,r13
589 mfspr r13,SPRG3 589 mfspr r13,SPRN_SPRG3
590 EXCEPTION_PROLOG_ISERIES_2 590 EXCEPTION_PROLOG_ISERIES_2
591 b system_call_common 591 b system_call_common
592 592
@@ -596,7 +596,7 @@ system_call_iSeries:
596 596
597 .globl system_reset_iSeries 597 .globl system_reset_iSeries
598system_reset_iSeries: 598system_reset_iSeries:
599 mfspr r13,SPRG3 /* Get paca address */ 599 mfspr r13,SPRN_SPRG3 /* Get paca address */
600 mfmsr r24 600 mfmsr r24
601 ori r24,r24,MSR_RI 601 ori r24,r24,MSR_RI
602 mtmsrd r24 /* RI on */ 602 mtmsrd r24 /* RI on */
@@ -639,7 +639,7 @@ iSeries_secondary_smp_loop:
639#endif /* CONFIG_SMP */ 639#endif /* CONFIG_SMP */
640 li r0,-1 /* r0=-1 indicates a Hypervisor call */ 640 li r0,-1 /* r0=-1 indicates a Hypervisor call */
641 sc /* Invoke the hypervisor via a system call */ 641 sc /* Invoke the hypervisor via a system call */
642 mfspr r13,SPRG3 /* Put r13 back ???? */ 642 mfspr r13,SPRN_SPRG3 /* Put r13 back ???? */
643 b 1b /* If SMP not configured, secondaries 643 b 1b /* If SMP not configured, secondaries
644 * loop forever */ 644 * loop forever */
645 645
@@ -656,8 +656,8 @@ hardware_interrupt_iSeries_masked:
656 mtcrf 0x80,r9 /* Restore regs */ 656 mtcrf 0x80,r9 /* Restore regs */
657 ld r11,PACALPPACA+LPPACASRR0(r13) 657 ld r11,PACALPPACA+LPPACASRR0(r13)
658 ld r12,PACALPPACA+LPPACASRR1(r13) 658 ld r12,PACALPPACA+LPPACASRR1(r13)
659 mtspr SRR0,r11 659 mtspr SPRN_SRR0,r11
660 mtspr SRR1,r12 660 mtspr SPRN_SRR1,r12
661 ld r9,PACA_EXGEN+EX_R9(r13) 661 ld r9,PACA_EXGEN+EX_R9(r13)
662 ld r10,PACA_EXGEN+EX_R10(r13) 662 ld r10,PACA_EXGEN+EX_R10(r13)
663 ld r11,PACA_EXGEN+EX_R11(r13) 663 ld r11,PACA_EXGEN+EX_R11(r13)
@@ -713,8 +713,8 @@ bad_stack:
713 std r10,GPR1(r1) 713 std r10,GPR1(r1)
714 std r11,_NIP(r1) 714 std r11,_NIP(r1)
715 std r12,_MSR(r1) 715 std r12,_MSR(r1)
716 mfspr r11,DAR 716 mfspr r11,SPRN_DAR
717 mfspr r12,DSISR 717 mfspr r12,SPRN_DSISR
718 std r11,_DAR(r1) 718 std r11,_DAR(r1)
719 std r12,_DSISR(r1) 719 std r12,_DSISR(r1)
720 mflr r10 720 mflr r10
@@ -766,8 +766,8 @@ fast_exception_return:
766 clrrdi r10,r10,2 /* clear RI (LE is 0 already) */ 766 clrrdi r10,r10,2 /* clear RI (LE is 0 already) */
767 mtmsrd r10,1 767 mtmsrd r10,1
768 768
769 mtspr SRR1,r12 769 mtspr SPRN_SRR1,r12
770 mtspr SRR0,r11 770 mtspr SPRN_SRR0,r11
771 REST_4GPRS(10, r1) 771 REST_4GPRS(10, r1)
772 ld r1,GPR1(r1) 772 ld r1,GPR1(r1)
773 rfid 773 rfid
@@ -788,9 +788,9 @@ unrecov_fer:
788 .globl data_access_common 788 .globl data_access_common
789data_access_common: 789data_access_common:
790 RUNLATCH_ON(r10) /* It wont fit in the 0x300 handler */ 790 RUNLATCH_ON(r10) /* It wont fit in the 0x300 handler */
791 mfspr r10,DAR 791 mfspr r10,SPRN_DAR
792 std r10,PACA_EXGEN+EX_DAR(r13) 792 std r10,PACA_EXGEN+EX_DAR(r13)
793 mfspr r10,DSISR 793 mfspr r10,SPRN_DSISR
794 stw r10,PACA_EXGEN+EX_DSISR(r13) 794 stw r10,PACA_EXGEN+EX_DSISR(r13)
795 EXCEPTION_PROLOG_COMMON(0x300, PACA_EXGEN) 795 EXCEPTION_PROLOG_COMMON(0x300, PACA_EXGEN)
796 ld r3,PACA_EXGEN+EX_DAR(r13) 796 ld r3,PACA_EXGEN+EX_DAR(r13)
@@ -821,9 +821,9 @@ hardware_interrupt_entry:
821 .align 7 821 .align 7
822 .globl alignment_common 822 .globl alignment_common
823alignment_common: 823alignment_common:
824 mfspr r10,DAR 824 mfspr r10,SPRN_DAR
825 std r10,PACA_EXGEN+EX_DAR(r13) 825 std r10,PACA_EXGEN+EX_DAR(r13)
826 mfspr r10,DSISR 826 mfspr r10,SPRN_DSISR
827 stw r10,PACA_EXGEN+EX_DSISR(r13) 827 stw r10,PACA_EXGEN+EX_DSISR(r13)
828 EXCEPTION_PROLOG_COMMON(0x600, PACA_EXGEN) 828 EXCEPTION_PROLOG_COMMON(0x600, PACA_EXGEN)
829 ld r3,PACA_EXGEN+EX_DAR(r13) 829 ld r3,PACA_EXGEN+EX_DAR(r13)
@@ -1120,7 +1120,7 @@ _GLOBAL(do_stab_bolted)
1120 1120
1121 /* Hash to the primary group */ 1121 /* Hash to the primary group */
1122 ld r10,PACASTABVIRT(r13) 1122 ld r10,PACASTABVIRT(r13)
1123 mfspr r11,DAR 1123 mfspr r11,SPRN_DAR
1124 srdi r11,r11,28 1124 srdi r11,r11,28
1125 rldimi r10,r11,7,52 /* r10 = first ste of the group */ 1125 rldimi r10,r11,7,52 /* r10 = first ste of the group */
1126 1126
@@ -1162,7 +1162,7 @@ _GLOBAL(do_stab_bolted)
11622: std r9,8(r10) /* Store the vsid part of the ste */ 11622: std r9,8(r10) /* Store the vsid part of the ste */
1163 eieio 1163 eieio
1164 1164
1165 mfspr r11,DAR /* Get the new esid */ 1165 mfspr r11,SPRN_DAR /* Get the new esid */
1166 clrrdi r11,r11,28 /* Permits a full 32b of ESID */ 1166 clrrdi r11,r11,28 /* Permits a full 32b of ESID */
1167 ori r11,r11,0x90 /* Turn on valid and kp */ 1167 ori r11,r11,0x90 /* Turn on valid and kp */
1168 std r11,0(r10) /* Put new entry back into the stab */ 1168 std r11,0(r10) /* Put new entry back into the stab */
@@ -1182,8 +1182,8 @@ _GLOBAL(do_stab_bolted)
1182 clrrdi r10,r10,2 1182 clrrdi r10,r10,2
1183 mtmsrd r10,1 1183 mtmsrd r10,1
1184 1184
1185 mtspr SRR0,r11 1185 mtspr SPRN_SRR0,r11
1186 mtspr SRR1,r12 1186 mtspr SPRN_SRR1,r12
1187 ld r9,PACA_EXSLB+EX_R9(r13) 1187 ld r9,PACA_EXSLB+EX_R9(r13)
1188 ld r10,PACA_EXSLB+EX_R10(r13) 1188 ld r10,PACA_EXSLB+EX_R10(r13)
1189 ld r11,PACA_EXSLB+EX_R11(r13) 1189 ld r11,PACA_EXSLB+EX_R11(r13)
@@ -1229,8 +1229,8 @@ _GLOBAL(do_slb_miss)
1229.machine pop 1229.machine pop
1230 1230
1231#ifdef CONFIG_PPC_ISERIES 1231#ifdef CONFIG_PPC_ISERIES
1232 mtspr SRR0,r11 1232 mtspr SPRN_SRR0,r11
1233 mtspr SRR1,r12 1233 mtspr SPRN_SRR1,r12
1234#endif /* CONFIG_PPC_ISERIES */ 1234#endif /* CONFIG_PPC_ISERIES */
1235 ld r9,PACA_EXSLB+EX_R9(r13) 1235 ld r9,PACA_EXSLB+EX_R9(r13)
1236 ld r10,PACA_EXSLB+EX_R10(r13) 1236 ld r10,PACA_EXSLB+EX_R10(r13)
@@ -1316,7 +1316,7 @@ _GLOBAL(pSeries_secondary_smp_init)
1316 mr r3,r24 /* not found, copy phys to r3 */ 1316 mr r3,r24 /* not found, copy phys to r3 */
1317 b .kexec_wait /* next kernel might do better */ 1317 b .kexec_wait /* next kernel might do better */
1318 1318
13192: mtspr SPRG3,r13 /* Save vaddr of paca in SPRG3 */ 13192: mtspr SPRN_SPRG3,r13 /* Save vaddr of paca in SPRG3 */
1320 /* From now on, r24 is expected to be logical cpuid */ 1320 /* From now on, r24 is expected to be logical cpuid */
1321 mr r24,r5 1321 mr r24,r5
13223: HMT_LOW 13223: HMT_LOW
@@ -1587,7 +1587,7 @@ _GLOBAL(pmac_secondary_start)
1587 LOADADDR(r4, paca) /* Get base vaddr of paca array */ 1587 LOADADDR(r4, paca) /* Get base vaddr of paca array */
1588 mulli r13,r24,PACA_SIZE /* Calculate vaddr of right paca */ 1588 mulli r13,r24,PACA_SIZE /* Calculate vaddr of right paca */
1589 add r13,r13,r4 /* for this processor. */ 1589 add r13,r13,r4 /* for this processor. */
1590 mtspr SPRG3,r13 /* Save vaddr of paca in SPRG3 */ 1590 mtspr SPRN_SPRG3,r13 /* Save vaddr of paca in SPRG3 */
1591 1591
1592 /* Create a temp kernel stack for use before relocation is on. */ 1592 /* Create a temp kernel stack for use before relocation is on. */
1593 ld r1,PACAEMERGSP(r13) 1593 ld r1,PACAEMERGSP(r13)
@@ -1622,7 +1622,7 @@ _GLOBAL(__secondary_start)
1622 /* Initialize the page table pointer register. */ 1622 /* Initialize the page table pointer register. */
1623 LOADADDR(r6,_SDR1) 1623 LOADADDR(r6,_SDR1)
1624 ld r6,0(r6) /* get the value of _SDR1 */ 1624 ld r6,0(r6) /* get the value of _SDR1 */
1625 mtspr SDR1,r6 /* set the htab location */ 1625 mtspr SPRN_SDR1,r6 /* set the htab location */
1626#endif 1626#endif
1627 /* Initialize the first segment table (or SLB) entry */ 1627 /* Initialize the first segment table (or SLB) entry */
1628 ld r3,PACASTABVIRT(r13) /* get addr of segment table */ 1628 ld r3,PACASTABVIRT(r13) /* get addr of segment table */
@@ -1651,7 +1651,7 @@ _GLOBAL(__secondary_start)
1651 lwz r3,PLATFORM(r3) /* r3 = platform flags */ 1651 lwz r3,PLATFORM(r3) /* r3 = platform flags */
1652 andi. r3,r3,PLATFORM_LPAR /* Test if bit 0 is set (LPAR bit) */ 1652 andi. r3,r3,PLATFORM_LPAR /* Test if bit 0 is set (LPAR bit) */
1653 beq 98f /* branch if result is 0 */ 1653 beq 98f /* branch if result is 0 */
1654 mfspr r3,PVR 1654 mfspr r3,SPRN_PVR
1655 srwi r3,r3,16 1655 srwi r3,r3,16
1656 cmpwi r3,0x37 /* SStar */ 1656 cmpwi r3,0x37 /* SStar */
1657 beq 97f 1657 beq 97f
@@ -1675,8 +1675,8 @@ _GLOBAL(__secondary_start)
1675#ifdef DO_SOFT_DISABLE 1675#ifdef DO_SOFT_DISABLE
1676 ori r4,r4,MSR_EE 1676 ori r4,r4,MSR_EE
1677#endif 1677#endif
1678 mtspr SRR0,r3 1678 mtspr SPRN_SRR0,r3
1679 mtspr SRR1,r4 1679 mtspr SPRN_SRR1,r4
1680 rfid 1680 rfid
1681 b . /* prevent speculative execution */ 1681 b . /* prevent speculative execution */
1682 1682
@@ -1738,7 +1738,7 @@ _STATIC(start_here_multiplatform)
1738 1738
1739#ifdef CONFIG_HMT 1739#ifdef CONFIG_HMT
1740 /* Start up the second thread on cpu 0 */ 1740 /* Start up the second thread on cpu 0 */
1741 mfspr r3,PVR 1741 mfspr r3,SPRN_PVR
1742 srwi r3,r3,16 1742 srwi r3,r3,16
1743 cmpwi r3,0x34 /* Pulsar */ 1743 cmpwi r3,0x34 /* Pulsar */
1744 beq 90f 1744 beq 90f
@@ -1798,7 +1798,7 @@ _STATIC(start_here_multiplatform)
1798 mulli r13,r27,PACA_SIZE /* Calculate vaddr of right paca */ 1798 mulli r13,r27,PACA_SIZE /* Calculate vaddr of right paca */
1799 add r13,r13,r24 /* for this processor. */ 1799 add r13,r13,r24 /* for this processor. */
1800 sub r13,r13,r26 /* convert to physical addr */ 1800 sub r13,r13,r26 /* convert to physical addr */
1801 mtspr SPRG3,r13 /* PPPBBB: Temp... -Peter */ 1801 mtspr SPRN_SPRG3,r13 /* PPPBBB: Temp... -Peter */
1802 1802
1803 /* Do very early kernel initializations, including initial hash table, 1803 /* Do very early kernel initializations, including initial hash table,
1804 * stab and slb setup before we turn on relocation. */ 1804 * stab and slb setup before we turn on relocation. */
@@ -1815,7 +1815,7 @@ _STATIC(start_here_multiplatform)
1815 lwz r3,PLATFORM(r3) /* r3 = platform flags */ 1815 lwz r3,PLATFORM(r3) /* r3 = platform flags */
1816 andi. r3,r3,PLATFORM_LPAR /* Test if bit 0 is set (LPAR bit) */ 1816 andi. r3,r3,PLATFORM_LPAR /* Test if bit 0 is set (LPAR bit) */
1817 beq 98f /* branch if result is 0 */ 1817 beq 98f /* branch if result is 0 */
1818 mfspr r3,PVR 1818 mfspr r3,SPRN_PVR
1819 srwi r3,r3,16 1819 srwi r3,r3,16
1820 cmpwi r3,0x37 /* SStar */ 1820 cmpwi r3,0x37 /* SStar */
1821 beq 97f 1821 beq 97f
@@ -1839,12 +1839,12 @@ _STATIC(start_here_multiplatform)
1839 LOADADDR(r6,_SDR1) /* Only if NOT LPAR */ 1839 LOADADDR(r6,_SDR1) /* Only if NOT LPAR */
1840 sub r6,r6,r26 1840 sub r6,r6,r26
1841 ld r6,0(r6) /* get the value of _SDR1 */ 1841 ld r6,0(r6) /* get the value of _SDR1 */
1842 mtspr SDR1,r6 /* set the htab location */ 1842 mtspr SPRN_SDR1,r6 /* set the htab location */
184398: 184398:
1844 LOADADDR(r3,.start_here_common) 1844 LOADADDR(r3,.start_here_common)
1845 SET_REG_TO_CONST(r4, MSR_KERNEL) 1845 SET_REG_TO_CONST(r4, MSR_KERNEL)
1846 mtspr SRR0,r3 1846 mtspr SPRN_SRR0,r3
1847 mtspr SRR1,r4 1847 mtspr SPRN_SRR1,r4
1848 rfid 1848 rfid
1849 b . /* prevent speculative execution */ 1849 b . /* prevent speculative execution */
1850#endif /* CONFIG_PPC_MULTIPLATFORM */ 1850#endif /* CONFIG_PPC_MULTIPLATFORM */
@@ -1875,7 +1875,7 @@ _STATIC(start_here_common)
1875 LOADADDR(r24, paca) /* Get base vaddr of paca array */ 1875 LOADADDR(r24, paca) /* Get base vaddr of paca array */
1876 mulli r13,r26,PACA_SIZE /* Calculate vaddr of right paca */ 1876 mulli r13,r26,PACA_SIZE /* Calculate vaddr of right paca */
1877 add r13,r13,r24 /* for this processor. */ 1877 add r13,r13,r24 /* for this processor. */
1878 mtspr SPRG3,r13 1878 mtspr SPRN_SPRG3,r13
1879 1879
1880 /* ptr to current */ 1880 /* ptr to current */
1881 LOADADDR(r4,init_task) 1881 LOADADDR(r4,init_task)
@@ -1902,7 +1902,7 @@ _STATIC(start_here_common)
1902_GLOBAL(hmt_init) 1902_GLOBAL(hmt_init)
1903#ifdef CONFIG_HMT 1903#ifdef CONFIG_HMT
1904 LOADADDR(r5, hmt_thread_data) 1904 LOADADDR(r5, hmt_thread_data)
1905 mfspr r7,PVR 1905 mfspr r7,SPRN_PVR
1906 srwi r7,r7,16 1906 srwi r7,r7,16
1907 cmpwi r7,0x34 /* Pulsar */ 1907 cmpwi r7,0x34 /* Pulsar */
1908 beq 90f 1908 beq 90f
@@ -1911,10 +1911,10 @@ _GLOBAL(hmt_init)
1911 cmpwi r7,0x37 /* SStar */ 1911 cmpwi r7,0x37 /* SStar */
1912 beq 91f 1912 beq 91f
1913 b 101f 1913 b 101f
191490: mfspr r6,PIR 191490: mfspr r6,SPRN_PIR
1915 andi. r6,r6,0x1f 1915 andi. r6,r6,0x1f
1916 b 92f 1916 b 92f
191791: mfspr r6,PIR 191791: mfspr r6,SPRN_PIR
1918 andi. r6,r6,0x3ff 1918 andi. r6,r6,0x3ff
191992: sldi r4,r24,3 191992: sldi r4,r24,3
1920 stwx r6,r5,r4 1920 stwx r6,r5,r4
@@ -1925,8 +1925,8 @@ __hmt_secondary_hold:
1925 LOADADDR(r5, hmt_thread_data) 1925 LOADADDR(r5, hmt_thread_data)
1926 clrldi r5,r5,4 1926 clrldi r5,r5,4
1927 li r7,0 1927 li r7,0
1928 mfspr r6,PIR 1928 mfspr r6,SPRN_PIR
1929 mfspr r8,PVR 1929 mfspr r8,SPRN_PVR
1930 srwi r8,r8,16 1930 srwi r8,r8,16
1931 cmpwi r8,0x34 1931 cmpwi r8,0x34
1932 bne 93f 1932 bne 93f
@@ -1952,19 +1952,19 @@ __hmt_secondary_hold:
1952_GLOBAL(hmt_start_secondary) 1952_GLOBAL(hmt_start_secondary)
1953 LOADADDR(r4,__hmt_secondary_hold) 1953 LOADADDR(r4,__hmt_secondary_hold)
1954 clrldi r4,r4,4 1954 clrldi r4,r4,4
1955 mtspr NIADORM, r4 1955 mtspr SPRN_NIADORM, r4
1956 mfspr r4, MSRDORM 1956 mfspr r4, SPRN_MSRDORM
1957 li r5, -65 1957 li r5, -65
1958 and r4, r4, r5 1958 and r4, r4, r5
1959 mtspr MSRDORM, r4 1959 mtspr SPRN_MSRDORM, r4
1960 lis r4,0xffef 1960 lis r4,0xffef
1961 ori r4,r4,0x7403 1961 ori r4,r4,0x7403
1962 mtspr TSC, r4 1962 mtspr SPRN_TSC, r4
1963 li r4,0x1f4 1963 li r4,0x1f4
1964 mtspr TST, r4 1964 mtspr SPRN_TST, r4
1965 mfspr r4, HID0 1965 mfspr r4, SPRN_HID0
1966 ori r4, r4, 0x1 1966 ori r4, r4, 0x1
1967 mtspr HID0, r4 1967 mtspr SPRN_HID0, r4
1968 mfspr r4, SPRN_CTRLF 1968 mfspr r4, SPRN_CTRLF
1969 oris r4, r4, 0x40 1969 oris r4, r4, 0x40
1970 mtspr SPRN_CTRLT, r4 1970 mtspr SPRN_CTRLT, r4