diff options
author | Vineet Gupta <vgupta@synopsys.com> | 2013-06-17 10:14:06 -0400 |
---|---|---|
committer | Vineet Gupta <vgupta@synopsys.com> | 2013-08-30 00:49:12 -0400 |
commit | d091fcb97ff48a5cb6de19ad0881fb2c8e76dbc0 (patch) | |
tree | c54e1ce880e399ed6a72c054f6cf244bc3752071 /arch/arc/mm | |
parent | 64b703ef276964b160a5e88df0764f254460cafb (diff) |
ARC: MMUv4 preps/2 - Reshuffle PTE bits
With previous commit freeing up PTE bits, reassign them so as to:
- Match the bit to H/w counterpart where possible
(e.g. MMUv2 GLOBAL/PRESENT, this avoids a shift in create_tlb())
- Avoid holes in _PAGE_xxx definitions
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
Diffstat (limited to 'arch/arc/mm')
-rw-r--r-- | arch/arc/mm/tlb.c | 11 | ||||
-rw-r--r-- | arch/arc/mm/tlbex.S | 3 |
2 files changed, 3 insertions, 11 deletions
diff --git a/arch/arc/mm/tlb.c b/arch/arc/mm/tlb.c index f9908341e8a7..85a8716e6028 100644 --- a/arch/arc/mm/tlb.c +++ b/arch/arc/mm/tlb.c | |||
@@ -342,7 +342,6 @@ void create_tlb(struct vm_area_struct *vma, unsigned long address, pte_t *ptep) | |||
342 | { | 342 | { |
343 | unsigned long flags; | 343 | unsigned long flags; |
344 | unsigned int idx, asid_or_sasid, rwx; | 344 | unsigned int idx, asid_or_sasid, rwx; |
345 | unsigned long pd0_flags; | ||
346 | 345 | ||
347 | /* | 346 | /* |
348 | * create_tlb() assumes that current->mm == vma->mm, since | 347 | * create_tlb() assumes that current->mm == vma->mm, since |
@@ -381,17 +380,13 @@ void create_tlb(struct vm_area_struct *vma, unsigned long address, pte_t *ptep) | |||
381 | /* update this PTE credentials */ | 380 | /* update this PTE credentials */ |
382 | pte_val(*ptep) |= (_PAGE_PRESENT | _PAGE_ACCESSED); | 381 | pte_val(*ptep) |= (_PAGE_PRESENT | _PAGE_ACCESSED); |
383 | 382 | ||
384 | /* Create HW TLB entry Flags (in PD0) from PTE Flags */ | 383 | /* Create HW TLB(PD0,PD1) from PTE */ |
385 | #if (CONFIG_ARC_MMU_VER <= 2) | ||
386 | pd0_flags = ((pte_val(*ptep) & PTE_BITS_IN_PD0) >> 1); | ||
387 | #else | ||
388 | pd0_flags = ((pte_val(*ptep) & PTE_BITS_IN_PD0)); | ||
389 | #endif | ||
390 | 384 | ||
391 | /* ASID for this task */ | 385 | /* ASID for this task */ |
392 | asid_or_sasid = read_aux_reg(ARC_REG_PID) & 0xff; | 386 | asid_or_sasid = read_aux_reg(ARC_REG_PID) & 0xff; |
393 | 387 | ||
394 | write_aux_reg(ARC_REG_TLBPD0, address | pd0_flags | asid_or_sasid); | 388 | write_aux_reg(ARC_REG_TLBPD0, address | asid_or_sasid | |
389 | (pte_val(*ptep) & PTE_BITS_IN_PD0)); | ||
395 | 390 | ||
396 | /* | 391 | /* |
397 | * ARC MMU provides fully orthogonal access bits for K/U mode, | 392 | * ARC MMU provides fully orthogonal access bits for K/U mode, |
diff --git a/arch/arc/mm/tlbex.S b/arch/arc/mm/tlbex.S index ec382e59d681..50e83ca96b96 100644 --- a/arch/arc/mm/tlbex.S +++ b/arch/arc/mm/tlbex.S | |||
@@ -229,9 +229,6 @@ ex_saved_reg1: | |||
229 | sr r3, [ARC_REG_TLBPD1] ; these go in PD1 | 229 | sr r3, [ARC_REG_TLBPD1] ; these go in PD1 |
230 | 230 | ||
231 | and r2, r0, PTE_BITS_IN_PD0 ; Extract other PTE flags: (V)alid, (G)lb | 231 | and r2, r0, PTE_BITS_IN_PD0 ; Extract other PTE flags: (V)alid, (G)lb |
232 | #if (CONFIG_ARC_MMU_VER <= 2) /* Neednot be done with v3 onwards */ | ||
233 | lsr r2, r2 ; shift PTE flags to match layout in PD0 | ||
234 | #endif | ||
235 | 232 | ||
236 | lr r3,[ARC_REG_TLBPD0] ; MMU prepares PD0 with vaddr and asid | 233 | lr r3,[ARC_REG_TLBPD0] ; MMU prepares PD0 with vaddr and asid |
237 | 234 | ||