2010-09-12 08:43:36 +02:00
|
|
|
/** @file
|
|
|
|
Header file for Multi-Processor support.
|
|
|
|
|
2018-02-02 08:34:48 +01:00
|
|
|
Copyright (c) 2010 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:07:10 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _DEBUG_MP_H_
|
|
|
|
#define _DEBUG_MP_H_
|
|
|
|
|
|
|
|
#define DEBUG_CPU_MAX_COUNT 256
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT32 CpuCount; ///< Processor count
|
|
|
|
UINT16 ApicID[DEBUG_CPU_MAX_COUNT]; ///< Record the local apic id for each processor
|
|
|
|
} DEBUG_CPU_DATA;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
SPIN_LOCK MpContextSpinLock; ///< Lock for writting MP context
|
|
|
|
SPIN_LOCK DebugPortSpinLock; ///< Lock for access debug port
|
2013-01-25 03:36:18 +01:00
|
|
|
SPIN_LOCK MailboxSpinLock; ///< Lock for accessing mail box
|
2010-09-12 08:43:36 +02:00
|
|
|
UINT8 CpuBreakMask[DEBUG_CPU_MAX_COUNT/8]; ///< Bitmask of all breaking CPUs
|
|
|
|
UINT8 CpuStopStatusMask[DEBUG_CPU_MAX_COUNT/8]; ///< Bitmask of CPU stop status
|
|
|
|
UINT32 ViewPointIndex; ///< Current view point to be debugged
|
|
|
|
UINT32 BspIndex; ///< Processor index value of BSP
|
|
|
|
UINT32 BreakAtCpuIndex; ///< Processor index value of the current breaking CPU
|
|
|
|
UINT32 DebugTimerInitCount; ///< Record BSP's init timer count
|
|
|
|
BOOLEAN IpiSentByAp; ///< TRUR: IPI is sent by AP. TALSE: IPI is sent by BSP
|
2012-06-11 04:15:11 +02:00
|
|
|
BOOLEAN RunCommandSet; ///< TRUE: RUN commmand is executing. FALSE : RUN command has been executed.
|
2010-09-12 08:43:36 +02:00
|
|
|
} DEBUG_MP_CONTEXT;
|
|
|
|
|
|
|
|
extern DEBUG_MP_CONTEXT volatile mDebugMpContext;
|
|
|
|
extern DEBUG_CPU_DATA volatile mDebugCpuData;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Break the other processor by send IPI.
|
|
|
|
|
|
|
|
@param[in] CurrentProcessorIndex Current processor index value.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
HaltOtherProcessors (
|
|
|
|
IN UINT32 CurrentProcessorIndex
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get the current processor's index.
|
|
|
|
|
|
|
|
@return Processor index value.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT32
|
|
|
|
GetProcessorIndex (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2013-01-25 03:36:18 +01:00
|
|
|
Acquire a spin lock when Multi-processor supported.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
It will block in the function if cannot get the access control.
|
2013-01-25 03:36:18 +01:00
|
|
|
If Multi-processor is not supported, return directly.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
2013-01-25 03:36:18 +01:00
|
|
|
@param[in, out] MpSpinLock A pointer to the spin lock.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
2013-01-25 03:36:18 +01:00
|
|
|
AcquireMpSpinLock (
|
|
|
|
IN OUT SPIN_LOCK *MpSpinLock
|
2010-09-12 08:43:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2013-01-25 03:36:18 +01:00
|
|
|
Release a spin lock when Multi-processor supported.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
2013-01-25 03:36:18 +01:00
|
|
|
@param[in, out] MpSpinLock A pointer to the spin lock.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
2013-01-25 03:36:18 +01:00
|
|
|
ReleaseMpSpinLock (
|
|
|
|
IN OUT SPIN_LOCK *MpSpinLock
|
2010-09-12 08:43:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Check if the specified processor is BSP or not.
|
|
|
|
|
|
|
|
@param[in] ProcessorIndex Processor index value.
|
|
|
|
|
|
|
|
@retval TRUE It is BSP.
|
|
|
|
@retval FALSE It isn't BSP.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
2018-02-02 08:34:48 +01:00
|
|
|
DebugAgentIsBsp (
|
2010-09-12 08:43:36 +02:00
|
|
|
IN UINT32 ProcessorIndex
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set processor stop flag bitmask in MP context.
|
|
|
|
|
|
|
|
@param[in] ProcessorIndex Processor index value.
|
|
|
|
@param[in] StopFlag TRUE means set stop flag.
|
|
|
|
FALSE means clean break flag.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetCpuStopFlagByIndex (
|
|
|
|
IN UINT32 ProcessorIndex,
|
|
|
|
IN BOOLEAN StopFlag
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set processor break flag bitmask in MP context.
|
|
|
|
|
|
|
|
@param[in] ProcessorIndex Processor index value.
|
|
|
|
@param[in] BreakFlag TRUE means set break flag.
|
|
|
|
FALSE means clean break flag.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetCpuBreakFlagByIndex (
|
|
|
|
IN UINT32 ProcessorIndex,
|
|
|
|
IN BOOLEAN BreakFlag
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Check if processor is stopped already.
|
|
|
|
|
|
|
|
@param[in] ProcessorIndex Processor index value.
|
|
|
|
|
|
|
|
@retval TRUE Processor is stopped already.
|
|
|
|
@retval FALSE Processor isn't stopped.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
IsCpuStopped (
|
|
|
|
IN UINT32 ProcessorIndex
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the run command flag.
|
|
|
|
|
|
|
|
@param[in] RunningFlag TRUE means run command flag is set.
|
|
|
|
FALSE means run command flag is cleared.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetCpuRunningFlag (
|
|
|
|
IN BOOLEAN RunningFlag
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the current view point to be debugged.
|
|
|
|
|
|
|
|
@param[in] ProcessorIndex Processor index value.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetDebugViewPoint (
|
|
|
|
IN UINT32 ProcessorIndex
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2012-06-11 04:15:11 +02:00
|
|
|
Set the IPI send by BPS/AP flag.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
@param[in] IpiSentByApFlag TRUE means this IPI is sent by AP.
|
|
|
|
FALSE means this IPI is sent by BSP.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetIpiSentByApFlag (
|
|
|
|
IN BOOLEAN IpiSentByApFlag
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2012-06-11 04:15:11 +02:00
|
|
|
Check the next pending breaking CPU.
|
2010-09-12 08:43:36 +02:00
|
|
|
|
|
|
|
@retval others There is at least one processor broken, the minimum
|
|
|
|
index number of Processor returned.
|
|
|
|
@retval -1 No any processor broken.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT32
|
2012-06-11 04:15:11 +02:00
|
|
|
FindNextPendingBreakCpu (
|
2010-09-12 08:43:36 +02:00
|
|
|
VOID
|
|
|
|
);
|
2018-06-27 15:14:00 +02:00
|
|
|
|
2010-09-12 08:43:36 +02:00
|
|
|
/**
|
|
|
|
Check if all processors are in running status.
|
|
|
|
|
|
|
|
@retval TRUE All processors run.
|
|
|
|
@retval FALSE At least one processor does not run.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
IsAllCpuRunning (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2012-06-11 04:15:11 +02:00
|
|
|
/**
|
|
|
|
Check if the current processor is the first breaking processor.
|
|
|
|
|
2018-06-27 15:14:00 +02:00
|
|
|
If yes, halt other processors.
|
|
|
|
|
2012-06-11 04:15:11 +02:00
|
|
|
@param[in] ProcessorIndex Processor index value.
|
2018-06-27 15:14:00 +02:00
|
|
|
|
2012-06-11 04:15:11 +02:00
|
|
|
@return TRUE This processor is the first breaking processor.
|
|
|
|
@return FALSE This processor is not the first breaking processor.
|
2018-06-27 15:14:00 +02:00
|
|
|
|
2012-06-11 04:15:11 +02:00
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
IsFirstBreakProcessor (
|
|
|
|
IN UINT32 ProcessorIndex
|
|
|
|
);
|
2018-06-27 15:14:00 +02:00
|
|
|
|
2010-09-12 08:43:36 +02:00
|
|
|
#endif
|
|
|
|
|