aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kernel/head_fsl_booke.S
diff options
context:
space:
mode:
Diffstat (limited to 'arch/powerpc/kernel/head_fsl_booke.S')
-rw-r--r--arch/powerpc/kernel/head_fsl_booke.S26
1 files changed, 18 insertions, 8 deletions
diff --git a/arch/powerpc/kernel/head_fsl_booke.S b/arch/powerpc/kernel/head_fsl_booke.S
index 3cb52fa0eda..590304c24da 100644
--- a/arch/powerpc/kernel/head_fsl_booke.S
+++ b/arch/powerpc/kernel/head_fsl_booke.S
@@ -422,7 +422,6 @@ skpinv: addi r6,r6,1 /* Increment */
422 * r12 is pointer to the pte 422 * r12 is pointer to the pte
423 */ 423 */
424#ifdef CONFIG_PTE_64BIT 424#ifdef CONFIG_PTE_64BIT
425#define PTE_FLAGS_OFFSET 4
426#define FIND_PTE \ 425#define FIND_PTE \
427 rlwinm r12, r10, 13, 19, 29; /* Compute pgdir/pmd offset */ \ 426 rlwinm r12, r10, 13, 19, 29; /* Compute pgdir/pmd offset */ \
428 lwzx r11, r12, r11; /* Get pgd/pmd entry */ \ 427 lwzx r11, r12, r11; /* Get pgd/pmd entry */ \
@@ -431,7 +430,6 @@ skpinv: addi r6,r6,1 /* Increment */
431 rlwimi r12, r10, 23, 20, 28; /* Compute pte address */ \ 430 rlwimi r12, r10, 23, 20, 28; /* Compute pte address */ \
432 lwz r11, 4(r12); /* Get pte entry */ 431 lwz r11, 4(r12); /* Get pte entry */
433#else 432#else
434#define PTE_FLAGS_OFFSET 0
435#define FIND_PTE \ 433#define FIND_PTE \
436 rlwimi r11, r10, 12, 20, 29; /* Create L1 (pgdir/pmd) address */ \ 434 rlwimi r11, r10, 12, 20, 29; /* Create L1 (pgdir/pmd) address */ \
437 lwz r11, 0(r11); /* Get L1 entry */ \ 435 lwz r11, 0(r11); /* Get L1 entry */ \
@@ -579,13 +577,19 @@ interrupt_base:
579 577
580 FIND_PTE 578 FIND_PTE
581 andc. r13,r13,r11 /* Check permission */ 579 andc. r13,r13,r11 /* Check permission */
582 bne 2f /* Bail if permission mismach */
583 580
584#ifdef CONFIG_PTE_64BIT 581#ifdef CONFIG_PTE_64BIT
585 lwz r13, 0(r12) 582#ifdef CONFIG_SMP
583 subf r10,r11,r12 /* create false data dep */
584 lwzx r13,r11,r10 /* Get upper pte bits */
585#else
586 lwz r13,0(r12) /* Get upper pte bits */
587#endif
586#endif 588#endif
587 589
588 /* Jump to common tlb load */ 590 bne 2f /* Bail if permission/valid mismach */
591
592 /* Jump to common tlb load */
589 b finish_tlb_load 593 b finish_tlb_load
5902: 5942:
591 /* The bailout. Restore registers to pre-exception conditions 595 /* The bailout. Restore registers to pre-exception conditions
@@ -640,12 +644,18 @@ interrupt_base:
640 644
641 FIND_PTE 645 FIND_PTE
642 andc. r13,r13,r11 /* Check permission */ 646 andc. r13,r13,r11 /* Check permission */
643 bne 2f /* Bail if permission mismach */
644 647
645#ifdef CONFIG_PTE_64BIT 648#ifdef CONFIG_PTE_64BIT
646 lwz r13, 0(r12) 649#ifdef CONFIG_SMP
650 subf r10,r11,r12 /* create false data dep */
651 lwzx r13,r11,r10 /* Get upper pte bits */
652#else
653 lwz r13,0(r12) /* Get upper pte bits */
654#endif
647#endif 655#endif
648 656
657 bne 2f /* Bail if permission mismach */
658
649 /* Jump to common TLB load point */ 659 /* Jump to common TLB load point */
650 b finish_tlb_load 660 b finish_tlb_load
651 661
@@ -702,7 +712,7 @@ interrupt_base:
702/* 712/*
703 * Both the instruction and data TLB miss get to this 713 * Both the instruction and data TLB miss get to this
704 * point to load the TLB. 714 * point to load the TLB.
705 * r10 - EA of fault 715 * r10 - available to use
706 * r11 - TLB (info from Linux PTE) 716 * r11 - TLB (info from Linux PTE)
707 * r12 - available to use 717 * r12 - available to use
708 * r13 - upper bits of PTE (if PTE_64BIT) or available to use 718 * r13 - upper bits of PTE (if PTE_64BIT) or available to use