Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit bbd08c72 authored by Scott Wood's avatar Scott Wood
Browse files

powerpc/e6500: hw tablewalk: clear TID in kernel indirect entries



Previously TID was being cleared before the tlbsx, but not after.  This
can lead to a multiway hit between a TLB entry with TID=0 (previously
inserted when PID=0) and a TLB entry with TID!=0 that matches PID.
This can theoretically result in undefined behavior, though we probably
get lucky due to the details of the overlap.  It also results in the
inability to use multihit detection to detect other conflicting TLB
entries, as well as poorer TLB utilization due to duplicating kernel
TLB entries.

Rather than try to patch up MAS1 after tlbsx, the entire value is
saved/restored as with MAS2.

I observed a slight improvement in TLB miss performance with this patch
applied.

Signed-off-by: default avatarScott Wood <scottwood@freescale.com>
Reported-by: default avatarEd Swarthout <ed.swarthout@freescale.com>
parent 68986c9f
Loading
Loading
Loading
Loading
+5 −7
Original line number Original line Diff line number Diff line
@@ -322,19 +322,17 @@ tlb_miss_common_e6500:
	b	1b
	b	1b
	.previous
	.previous


	mfspr	r15,SPRN_MAS2
	mfspr	r15,SPRN_MAS1
	mfspr	r10,SPRN_MAS2


	tlbsx	0,r16
	tlbsx	0,r16
	mtspr	SPRN_MAS2,r10
	mfspr	r10,SPRN_MAS1
	mfspr	r10,SPRN_MAS1
	mtspr	SPRN_MAS1,r15

	andis.	r10,r10,MAS1_VALID@h
	andis.	r10,r10,MAS1_VALID@h
	bne	tlb_miss_done_e6500
	bne	tlb_miss_done_e6500


	/* Undo MAS-damage from the tlbsx */
	mfspr	r10,SPRN_MAS1
	oris	r10,r10,MAS1_VALID@h
	mtspr	SPRN_MAS1,r10
	mtspr	SPRN_MAS2,r15

	/* Now, we need to walk the page tables. First check if we are in
	/* Now, we need to walk the page tables. First check if we are in
	 * range.
	 * range.
	 */
	 */