UefiCpuPkg/MpService: Simply Lock usage

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Chen Fan <chen.fan.fnst@cn.fujitsu.com>
Reviewed-by: Jeff Fan <jeff.fan@intel.com>

git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16363 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
Chen Fan
2014-11-13 18:28:33 +00:00
committed by jljusten
parent acb2172d15
commit d16cf36d2a

View File

@@ -37,6 +37,36 @@ EFI_MP_SERVICES_PROTOCOL mMpServicesTemplate = {
WhoAmI WhoAmI
}; };
/**
Get Mp Service Lock.
@param CpuData the pointer to CPU_DATA_BLOCK of specified processor
**/
VOID
GetMpSpinLock (
IN CPU_DATA_BLOCK *CpuData
)
{
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) {
CpuPause ();
}
}
/**
Release Mp Service Lock.
@param CpuData the pointer to CPU_DATA_BLOCK of specified processor
**/
VOID
ReleaseMpSpinLock (
IN CPU_DATA_BLOCK *CpuData
)
{
ReleaseSpinLock (&CpuData->CpuDataLock);
}
/** /**
Check whether caller processor is BSP. Check whether caller processor is BSP.
@@ -75,12 +105,9 @@ GetApState (
{ {
CPU_STATE State; CPU_STATE State;
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
State = CpuData->State; State = CpuData->State;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
return State; return State;
} }
@@ -98,12 +125,9 @@ SetApState (
IN CPU_STATE State IN CPU_STATE State
) )
{ {
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
CpuData->State = State; CpuData->State = State;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
} }
/** /**
@@ -122,13 +146,10 @@ SetApProcedure (
IN VOID *ProcedureArgument IN VOID *ProcedureArgument
) )
{ {
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
CpuData->Parameter = ProcedureArgument; CpuData->Parameter = ProcedureArgument;
CpuData->Procedure = Procedure; CpuData->Procedure = Procedure;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
} }
/** /**
@@ -149,12 +170,9 @@ TestCpuStatusFlag (
{ {
UINT32 Ret; UINT32 Ret;
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
Ret = CpuData->Info.StatusFlag & Flags; Ret = CpuData->Info.StatusFlag & Flags;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
return !!(Ret); return !!(Ret);
} }
@@ -172,12 +190,9 @@ CpuStatusFlagOr (
IN UINT32 Flags IN UINT32 Flags
) )
{ {
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
CpuData->Info.StatusFlag |= Flags; CpuData->Info.StatusFlag |= Flags;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
} }
/** /**
@@ -193,12 +208,9 @@ CpuStatusFlagAndNot (
IN UINT32 Flags IN UINT32 Flags
) )
{ {
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
CpuData->Info.StatusFlag &= ~Flags; CpuData->Info.StatusFlag &= ~Flags;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
} }
/** /**
@@ -1127,25 +1139,18 @@ ProcessorToIdleState (
AsmApDoneWithCommonStack (); AsmApDoneWithCommonStack ();
while (TRUE) { while (TRUE) {
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
ProcedureArgument = CpuData->Parameter; ProcedureArgument = CpuData->Parameter;
Procedure = CpuData->Procedure; Procedure = CpuData->Procedure;
ReleaseSpinLock (&CpuData->CpuDataLock); ReleaseMpSpinLock (CpuData);
if (Procedure != NULL) { if (Procedure != NULL) {
Procedure (ProcedureArgument); Procedure (ProcedureArgument);
while (!AcquireSpinLockOrFail (&CpuData->CpuDataLock)) { GetMpSpinLock (CpuData);
CpuPause ();
}
CpuData->Procedure = NULL; CpuData->Procedure = NULL;
ReleaseSpinLock (&CpuData->CpuDataLock); CpuData->State = CpuStateFinished;
ReleaseMpSpinLock (CpuData);
SetApState (CpuData, CpuStateFinished);
} }
CpuPause (); CpuPause ();