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

Commit 00efee7d authored by Michael Neuling's avatar Michael Neuling Committed by Paul Mackerras
Browse files

[POWERPC] Remove barriers from the SLB shadow buffer update



After talking to an IBM POWER hypervisor (PHYP) design and development
guy, there seems to be no need for memory barriers when updating the SLB
shadow buffer provided we only update it from the current CPU, which we
do.

Also, these guys see no need in the future for these barriers.

Signed-off-by: default avatarMichael Neuling <mikey@neuling.org>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent 61a564fd
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -385,15 +385,15 @@ BEGIN_FTR_SECTION
	oris	r0,r6,(SLB_ESID_V)@h
	ori	r0,r0,(SLB_NUM_BOLTED-1)@l

	/* Update the last bolted SLB */
	/* Update the last bolted SLB.  No write barriers are needed
	 * here, provided we only update the current CPU's SLB shadow
	 * buffer.
	 */
	ld	r9,PACA_SLBSHADOWPTR(r13)
	li	r12,0
	std	r12,SLBSHADOW_STACKESID(r9) /* Clear ESID */
	eieio
	std	r7,SLBSHADOW_STACKVSID(r9)  /* Save VSID */
	eieio
	std	r0,SLBSHADOW_STACKESID(r9)  /* Save ESID */
	eieio

	slbie	r6
	slbie	r6		/* Workaround POWER5 < DD2.1 issue */
+2 −4
Original line number Diff line number Diff line
@@ -59,14 +59,12 @@ static inline void slb_shadow_update(unsigned long ea,
{
	/*
	 * Clear the ESID first so the entry is not valid while we are
	 * updating it.
	 * updating it.  No write barriers are needed here, provided
	 * we only update the current CPU's SLB shadow buffer.
	 */
	get_slb_shadow()->save_area[entry].esid = 0;
	smp_wmb();
	get_slb_shadow()->save_area[entry].vsid = mk_vsid_data(ea, flags);
	smp_wmb();
	get_slb_shadow()->save_area[entry].esid = mk_esid_data(ea, entry);
	smp_wmb();
}

static inline void slb_shadow_clear(unsigned long entry)