⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 itlb_base.s

📁 优龙2410linux2.6.8内核源代码
💻 S
字号:
/* $Id: itlb_base.S,v 1.12 2002/02/09 19:49:30 davem Exp $ * itlb_base.S:	Front end to ITLB miss replacement strategy. *              This is included directly into the trap table. * * Copyright (C) 1996,1998 David S. Miller (davem@redhat.com) * Copyright (C) 1997,1998 Jakub Jelinek   (jj@ultra.linux.cz) */#if PAGE_SHIFT == 13/* * To compute vpte offset, we need to do ((addr >> 13) << 3), * which can be optimized to (addr >> 10) if bits 10/11/12 can * be guaranteed to be 0 ... mmu_context.h does guarantee this * by only using 10 bits in the hwcontext value. */#define CREATE_VPTE_OFFSET1(r1, r2) \				srax	r1, 10, r2#define CREATE_VPTE_OFFSET2(r1, r2)#define CREATE_VPTE_NOP		nop#else /* PAGE_SHIFT */#define CREATE_VPTE_OFFSET1(r1, r2) \				srax	r1, PAGE_SHIFT, r2#define CREATE_VPTE_OFFSET2(r1, r2) \				sllx	r2, 3, r2#define CREATE_VPTE_NOP#endif /* PAGE_SHIFT *//* Ways we can get here: * * 1) Nucleus instruction misses from module code. * 2) All user instruction misses. * * All real page faults merge their code paths to the * sparc64_realfault_common label below. *//* ITLB ** ICACHE line 1: Quick user TLB misses		*/	ldxa		[%g1 + %g1] ASI_IMMU, %g4	! Get TAG_ACCESS	CREATE_VPTE_OFFSET1(%g4, %g6)			! Create VPTE offset	CREATE_VPTE_OFFSET2(%g4, %g6)			! Create VPTE offset	ldxa		[%g3 + %g6] ASI_P, %g5		! Load VPTE1:	brgez,pn	%g5, 3f				! Not valid, branch out	 sethi		%hi(_PAGE_EXEC), %g4		! Delay-slot	andcc		%g5, %g4, %g0			! Executable?	be,pn		%xcc, 3f			! Nope, branch.	 nop						! Delay-slot2:	stxa		%g5, [%g0] ASI_ITLB_DATA_IN	! Load PTE into TLB	retry						! Trap return3:	rdpr		%pstate, %g4			! Move into alternate globals/* ITLB ** ICACHE line 2: Real faults			*/	wrpr		%g4, PSTATE_AG|PSTATE_MG, %pstate	rdpr		%tpc, %g5			! And load faulting VA	mov		FAULT_CODE_ITLB, %g4		! It was read from ITLBsparc64_realfault_common:				! Called by TL0 dtlb_miss too	stb		%g4, [%g6 + TI_FAULT_CODE]	stx		%g5, [%g6 + TI_FAULT_ADDR]	ba,pt		%xcc, etrap			! Save state1:	 rd		%pc, %g7			! ...	nop/* ITLB ** ICACHE line 3: Finish faults + window fixups	*/	call		do_sparc64_fault		! Call fault handler	 add		%sp, PTREGS_OFF, %o0! Compute pt_regs arg	ba,pt		%xcc, rtrap_clr_l6		! Restore cpu state	 nopwinfix_trampoline:	rdpr		%tpc, %g3			! Prepare winfixup TNPC	or		%g3, 0x7c, %g3			! Compute offset to branch	wrpr		%g3, %tnpc			! Write it into TNPC	done						! Do it to it/* ITLB ** ICACHE line 4: Unused...	*/	nop	nop	nop	nop	CREATE_VPTE_NOP#undef CREATE_VPTE_OFFSET1#undef CREATE_VPTE_OFFSET2#undef CREATE_VPTE_NOP

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -