diff options
Diffstat (limited to 'arch/powerpc/kernel/head_fsl_booke.S')
-rw-r--r-- | arch/powerpc/kernel/head_fsl_booke.S | 26 |
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 |
590 | 2: | 594 | 2: |
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 |