mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-25 03:03:32 +00:00 
			
		
		
		
	target-mips: support Page Frame Number Extension field
Update tlb->PFN to contain PFN concatenated with PFNX. PFNX is 0 if large physical address is not supported. Signed-off-by: Leon Alrae <leon.alrae@imgtec.com> Reviewed-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
		
							parent
							
								
									284b731a6a
								
							
						
					
					
						commit
						cd0d45c401
					
				| @ -1826,6 +1826,16 @@ static void r4k_mips_tlb_flush_extra (CPUMIPSState *env, int first) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static inline uint64_t get_tlb_pfn_from_entrylo(uint64_t entrylo) | ||||
| { | ||||
| #if defined(TARGET_MIPS64) | ||||
|     return extract64(entrylo, 6, 54); | ||||
| #else | ||||
|     return extract64(entrylo, 6, 24) | /* PFN */ | ||||
|            (extract64(entrylo, 32, 32) << 24); /* PFNX */ | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| static void r4k_fill_tlb(CPUMIPSState *env, int idx) | ||||
| { | ||||
|     r4k_tlb_t *tlb; | ||||
| @ -1849,13 +1859,13 @@ static void r4k_fill_tlb(CPUMIPSState *env, int idx) | ||||
|     tlb->C0 = (env->CP0_EntryLo0 >> 3) & 0x7; | ||||
|     tlb->XI0 = (env->CP0_EntryLo0 >> CP0EnLo_XI) & 1; | ||||
|     tlb->RI0 = (env->CP0_EntryLo0 >> CP0EnLo_RI) & 1; | ||||
|     tlb->PFN[0] = (env->CP0_EntryLo0 >> 6) << 12; | ||||
|     tlb->PFN[0] = get_tlb_pfn_from_entrylo(env->CP0_EntryLo0) << 12; | ||||
|     tlb->V1 = (env->CP0_EntryLo1 & 2) != 0; | ||||
|     tlb->D1 = (env->CP0_EntryLo1 & 4) != 0; | ||||
|     tlb->C1 = (env->CP0_EntryLo1 >> 3) & 0x7; | ||||
|     tlb->XI1 = (env->CP0_EntryLo1 >> CP0EnLo_XI) & 1; | ||||
|     tlb->RI1 = (env->CP0_EntryLo1 >> CP0EnLo_RI) & 1; | ||||
|     tlb->PFN[1] = (env->CP0_EntryLo1 >> 6) << 12; | ||||
|     tlb->PFN[1] = get_tlb_pfn_from_entrylo(env->CP0_EntryLo1) << 12; | ||||
| } | ||||
| 
 | ||||
| void r4k_helper_tlbinv(CPUMIPSState *env) | ||||
| @ -1972,6 +1982,16 @@ void r4k_helper_tlbp(CPUMIPSState *env) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static inline uint64_t get_entrylo_pfn_from_tlb(uint64_t tlb_pfn) | ||||
| { | ||||
| #if defined(TARGET_MIPS64) | ||||
|     return tlb_pfn << 6; | ||||
| #else | ||||
|     return (extract64(tlb_pfn, 0, 24) << 6) | /* PFN */ | ||||
|            (extract64(tlb_pfn, 24, 32) << 32); /* PFNX */ | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| void r4k_helper_tlbr(CPUMIPSState *env) | ||||
| { | ||||
|     r4k_tlb_t *tlb; | ||||
| @ -1998,12 +2018,12 @@ void r4k_helper_tlbr(CPUMIPSState *env) | ||||
|         env->CP0_PageMask = tlb->PageMask; | ||||
|         env->CP0_EntryLo0 = tlb->G | (tlb->V0 << 1) | (tlb->D0 << 2) | | ||||
|                         ((uint64_t)tlb->RI0 << CP0EnLo_RI) | | ||||
|                         ((uint64_t)tlb->XI0 << CP0EnLo_XI) | | ||||
|                         (tlb->C0 << 3) | (tlb->PFN[0] >> 6); | ||||
|                         ((uint64_t)tlb->XI0 << CP0EnLo_XI) | (tlb->C0 << 3) | | ||||
|                         get_entrylo_pfn_from_tlb(tlb->PFN[0] >> 12); | ||||
|         env->CP0_EntryLo1 = tlb->G | (tlb->V1 << 1) | (tlb->D1 << 2) | | ||||
|                         ((uint64_t)tlb->RI1 << CP0EnLo_RI) | | ||||
|                         ((uint64_t)tlb->XI1 << CP0EnLo_XI) | | ||||
|                         (tlb->C1 << 3) | (tlb->PFN[1] >> 6); | ||||
|                         ((uint64_t)tlb->XI1 << CP0EnLo_XI) | (tlb->C1 << 3) | | ||||
|                         get_entrylo_pfn_from_tlb(tlb->PFN[1] >> 12); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Leon Alrae
						Leon Alrae