MdeModulePkg: Apply uncrustify changes
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the MdeModulePkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Liming Gao <gaoliming@byosoft.com.cn>
This commit is contained in:
committed by
mergify[bot]
parent
7c7184e201
commit
1436aea4d5
@@ -17,21 +17,21 @@ SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||
// based on whether or not a debugger is present, and other
|
||||
// platform-specific configurations.
|
||||
//
|
||||
#define VM_STACK_SIZE (1024 * 4)
|
||||
#define VM_STACK_SIZE (1024 * 4)
|
||||
|
||||
#define STACK_REMAIN_SIZE (1024 * 4)
|
||||
#define STACK_REMAIN_SIZE (1024 * 4)
|
||||
|
||||
//
|
||||
// This is instruction buffer used to create EBC thunk
|
||||
//
|
||||
#define EBC_ENTRYPOINT_SIGNATURE 0xAFAFAFAF
|
||||
#define EBC_LL_EBC_ENTRYPOINT_SIGNATURE 0xFAFAFAFA
|
||||
#define EBC_ENTRYPOINT_SIGNATURE 0xAFAFAFAF
|
||||
#define EBC_LL_EBC_ENTRYPOINT_SIGNATURE 0xFAFAFAFA
|
||||
UINT8 mInstructionBufferTemplate[] = {
|
||||
//
|
||||
// Add a magic code here to help the VM recognize the thunk..
|
||||
// mov eax, 0xca112ebc => B8 BC 2E 11 CA
|
||||
//
|
||||
0xB8, 0xBC, 0x2E, 0x11, 0xCA,
|
||||
0xB8, 0xBC, 0x2E, 0x11, 0xCA,
|
||||
//
|
||||
// Add code bytes to load up a processor register with the EBC entry point.
|
||||
// mov eax, EbcEntryPoint => B8 XX XX XX XX (To be fixed at runtime)
|
||||
@@ -39,24 +39,24 @@ UINT8 mInstructionBufferTemplate[] = {
|
||||
// entry point.
|
||||
//
|
||||
0xB8,
|
||||
(UINT8)(EBC_ENTRYPOINT_SIGNATURE & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 8) & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 16) & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 24) & 0xFF),
|
||||
(UINT8)(EBC_ENTRYPOINT_SIGNATURE & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 8) & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 16) & 0xFF),
|
||||
(UINT8)((EBC_ENTRYPOINT_SIGNATURE >> 24) & 0xFF),
|
||||
//
|
||||
// Stick in a load of ecx with the address of appropriate VM function.
|
||||
// mov ecx, EbcLLEbcInterpret => B9 XX XX XX XX (To be fixed at runtime)
|
||||
//
|
||||
0xB9,
|
||||
(UINT8)(EBC_LL_EBC_ENTRYPOINT_SIGNATURE & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 8) & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 16) & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 24) & 0xFF),
|
||||
(UINT8)(EBC_LL_EBC_ENTRYPOINT_SIGNATURE & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 8) & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 16) & 0xFF),
|
||||
(UINT8)((EBC_LL_EBC_ENTRYPOINT_SIGNATURE >> 24) & 0xFF),
|
||||
//
|
||||
// Stick in jump opcode bytes
|
||||
// jmp ecx => FF E1
|
||||
//
|
||||
0xFF, 0xE1,
|
||||
0xFF, 0xE1,
|
||||
};
|
||||
|
||||
/**
|
||||
@@ -102,60 +102,62 @@ EbcLLExecuteEbcImageEntryPoint (
|
||||
**/
|
||||
VOID
|
||||
EbcLLCALLEX (
|
||||
IN VM_CONTEXT *VmPtr,
|
||||
IN UINTN FuncAddr,
|
||||
IN UINTN NewStackPointer,
|
||||
IN VOID *FramePtr,
|
||||
IN UINT8 Size
|
||||
IN VM_CONTEXT *VmPtr,
|
||||
IN UINTN FuncAddr,
|
||||
IN UINTN NewStackPointer,
|
||||
IN VOID *FramePtr,
|
||||
IN UINT8 Size
|
||||
)
|
||||
{
|
||||
UINTN IsThunk;
|
||||
UINTN TargetEbcAddr;
|
||||
UINT8 InstructionBuffer[sizeof(mInstructionBufferTemplate)];
|
||||
UINTN Index;
|
||||
UINTN IndexOfEbcEntrypoint;
|
||||
UINTN IsThunk;
|
||||
UINTN TargetEbcAddr;
|
||||
UINT8 InstructionBuffer[sizeof (mInstructionBufferTemplate)];
|
||||
UINTN Index;
|
||||
UINTN IndexOfEbcEntrypoint;
|
||||
|
||||
IsThunk = 1;
|
||||
TargetEbcAddr = 0;
|
||||
IsThunk = 1;
|
||||
TargetEbcAddr = 0;
|
||||
IndexOfEbcEntrypoint = 0;
|
||||
|
||||
//
|
||||
// Processor specific code to check whether the callee is a thunk to EBC.
|
||||
//
|
||||
CopyMem (InstructionBuffer, (VOID *)FuncAddr, sizeof(InstructionBuffer));
|
||||
CopyMem (InstructionBuffer, (VOID *)FuncAddr, sizeof (InstructionBuffer));
|
||||
//
|
||||
// Fill the signature according to mInstructionBufferTemplate
|
||||
//
|
||||
for (Index = 0; Index < sizeof(mInstructionBufferTemplate) - sizeof(UINTN); Index++) {
|
||||
for (Index = 0; Index < sizeof (mInstructionBufferTemplate) - sizeof (UINTN); Index++) {
|
||||
if (*(UINTN *)&mInstructionBufferTemplate[Index] == EBC_ENTRYPOINT_SIGNATURE) {
|
||||
*(UINTN *)&InstructionBuffer[Index] = EBC_ENTRYPOINT_SIGNATURE;
|
||||
IndexOfEbcEntrypoint = Index;
|
||||
IndexOfEbcEntrypoint = Index;
|
||||
}
|
||||
|
||||
if (*(UINTN *)&mInstructionBufferTemplate[Index] == EBC_LL_EBC_ENTRYPOINT_SIGNATURE) {
|
||||
*(UINTN *)&InstructionBuffer[Index] = EBC_LL_EBC_ENTRYPOINT_SIGNATURE;
|
||||
}
|
||||
}
|
||||
|
||||
//
|
||||
// Check if we need thunk to native
|
||||
//
|
||||
if (CompareMem (InstructionBuffer, mInstructionBufferTemplate, sizeof(mInstructionBufferTemplate)) != 0) {
|
||||
if (CompareMem (InstructionBuffer, mInstructionBufferTemplate, sizeof (mInstructionBufferTemplate)) != 0) {
|
||||
IsThunk = 0;
|
||||
}
|
||||
|
||||
if (IsThunk == 1){
|
||||
if (IsThunk == 1) {
|
||||
//
|
||||
// The callee is a thunk to EBC, adjust the stack pointer down 16 bytes and
|
||||
// put our return address and frame pointer on the VM stack.
|
||||
// Then set the VM's IP to new EBC code.
|
||||
//
|
||||
VmPtr->Gpr[0] -= 8;
|
||||
VmWriteMemN (VmPtr, (UINTN) VmPtr->Gpr[0], (UINTN) FramePtr);
|
||||
VmPtr->FramePtr = (VOID *) (UINTN) VmPtr->Gpr[0];
|
||||
VmPtr->Gpr[0] -= 8;
|
||||
VmWriteMem64 (VmPtr, (UINTN) VmPtr->Gpr[0], (UINT64) (UINTN) (VmPtr->Ip + Size));
|
||||
VmWriteMemN (VmPtr, (UINTN)VmPtr->Gpr[0], (UINTN)FramePtr);
|
||||
VmPtr->FramePtr = (VOID *)(UINTN)VmPtr->Gpr[0];
|
||||
VmPtr->Gpr[0] -= 8;
|
||||
VmWriteMem64 (VmPtr, (UINTN)VmPtr->Gpr[0], (UINT64)(UINTN)(VmPtr->Ip + Size));
|
||||
|
||||
CopyMem (&TargetEbcAddr, (UINT8 *)FuncAddr + IndexOfEbcEntrypoint, sizeof(UINTN));
|
||||
VmPtr->Ip = (VMIP) (UINTN) TargetEbcAddr;
|
||||
CopyMem (&TargetEbcAddr, (UINT8 *)FuncAddr + IndexOfEbcEntrypoint, sizeof (UINTN));
|
||||
VmPtr->Ip = (VMIP)(UINTN)TargetEbcAddr;
|
||||
} else {
|
||||
//
|
||||
// The callee is not a thunk to EBC, call native code,
|
||||
@@ -170,7 +172,6 @@ EbcLLCALLEX (
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
Begin executing an EBC image.
|
||||
|
||||
@@ -202,23 +203,23 @@ EbcLLCALLEX (
|
||||
UINT64
|
||||
EFIAPI
|
||||
EbcInterpret (
|
||||
IN UINTN EntryPoint,
|
||||
IN UINTN Arg1,
|
||||
IN UINTN Arg2,
|
||||
IN UINTN Arg3,
|
||||
IN UINTN Arg4,
|
||||
IN UINTN Arg5,
|
||||
IN UINTN Arg6,
|
||||
IN UINTN Arg7,
|
||||
IN UINTN Arg8,
|
||||
IN UINTN Arg9,
|
||||
IN UINTN Arg10,
|
||||
IN UINTN Arg11,
|
||||
IN UINTN Arg12,
|
||||
IN UINTN Arg13,
|
||||
IN UINTN Arg14,
|
||||
IN UINTN Arg15,
|
||||
IN UINTN Arg16
|
||||
IN UINTN EntryPoint,
|
||||
IN UINTN Arg1,
|
||||
IN UINTN Arg2,
|
||||
IN UINTN Arg3,
|
||||
IN UINTN Arg4,
|
||||
IN UINTN Arg5,
|
||||
IN UINTN Arg6,
|
||||
IN UINTN Arg7,
|
||||
IN UINTN Arg8,
|
||||
IN UINTN Arg9,
|
||||
IN UINTN Arg10,
|
||||
IN UINTN Arg11,
|
||||
IN UINTN Arg12,
|
||||
IN UINTN Arg13,
|
||||
IN UINTN Arg14,
|
||||
IN UINTN Arg15,
|
||||
IN UINTN Arg16
|
||||
)
|
||||
{
|
||||
//
|
||||
@@ -237,12 +238,12 @@ EbcInterpret (
|
||||
//
|
||||
// Now clear out our context
|
||||
//
|
||||
ZeroMem ((VOID *) &VmContext, sizeof (VM_CONTEXT));
|
||||
ZeroMem ((VOID *)&VmContext, sizeof (VM_CONTEXT));
|
||||
|
||||
//
|
||||
// Set the VM instruction pointer to the correct location in memory.
|
||||
//
|
||||
VmContext.Ip = (VMIP) Addr;
|
||||
VmContext.Ip = (VMIP)Addr;
|
||||
//
|
||||
// Initialize the stack pointer for the EBC. Get the current system stack
|
||||
// pointer and adjust it down by the max needed for the interpreter.
|
||||
@@ -255,60 +256,61 @@ EbcInterpret (
|
||||
//
|
||||
// Allocate stack pool
|
||||
//
|
||||
Status = GetEBCStack((EFI_HANDLE)-1, &VmContext.StackPool, &StackIndex);
|
||||
if (EFI_ERROR(Status)) {
|
||||
Status = GetEBCStack ((EFI_HANDLE)-1, &VmContext.StackPool, &StackIndex);
|
||||
if (EFI_ERROR (Status)) {
|
||||
return Status;
|
||||
}
|
||||
VmContext.StackTop = (UINT8*)VmContext.StackPool + (STACK_REMAIN_SIZE);
|
||||
VmContext.Gpr[0] = (UINT64)(UINTN) ((UINT8*)VmContext.StackPool + STACK_POOL_SIZE);
|
||||
|
||||
VmContext.StackTop = (UINT8 *)VmContext.StackPool + (STACK_REMAIN_SIZE);
|
||||
VmContext.Gpr[0] = (UINT64)(UINTN)((UINT8 *)VmContext.StackPool + STACK_POOL_SIZE);
|
||||
VmContext.HighStackBottom = (UINTN)VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] &= ~((VM_REGISTER)(sizeof (UINTN) - 1));
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
VmContext.Gpr[0] &= ~((VM_REGISTER)(sizeof (UINTN) - 1));
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
|
||||
//
|
||||
// Put a magic value in the stack gap, then adjust down again
|
||||
//
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) VM_STACK_KEY_VALUE;
|
||||
VmContext.StackMagicPtr = (UINTN *) (UINTN) VmContext.Gpr[0];
|
||||
VmContext.LowStackTop = (UINTN) VmContext.Gpr[0];
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)VM_STACK_KEY_VALUE;
|
||||
VmContext.StackMagicPtr = (UINTN *)(UINTN)VmContext.Gpr[0];
|
||||
VmContext.LowStackTop = (UINTN)VmContext.Gpr[0];
|
||||
|
||||
//
|
||||
// For IA32, this is where we say our return address is
|
||||
//
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg16;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg15;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg14;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg13;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg12;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg11;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg10;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg9;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg8;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg7;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg6;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg5;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg4;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg3;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg2;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) Arg1;
|
||||
VmContext.Gpr[0] -= 16;
|
||||
VmContext.StackRetAddr = (UINT64) VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg16;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg15;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg14;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg13;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg12;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg11;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg10;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg9;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg8;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg7;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg6;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg5;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg4;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg3;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg2;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)Arg1;
|
||||
VmContext.Gpr[0] -= 16;
|
||||
VmContext.StackRetAddr = (UINT64)VmContext.Gpr[0];
|
||||
|
||||
//
|
||||
// We need to keep track of where the EBC stack starts. This way, if the EBC
|
||||
@@ -333,11 +335,10 @@ EbcInterpret (
|
||||
//
|
||||
// Return the value in Gpr[7] unless there was an error
|
||||
//
|
||||
ReturnEBCStack(StackIndex);
|
||||
return (UINT64) VmContext.Gpr[7];
|
||||
ReturnEBCStack (StackIndex);
|
||||
return (UINT64)VmContext.Gpr[7];
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
Begin executing an EBC image.
|
||||
|
||||
@@ -352,9 +353,9 @@ EbcInterpret (
|
||||
UINT64
|
||||
EFIAPI
|
||||
ExecuteEbcImageEntryPoint (
|
||||
IN UINTN EntryPoint,
|
||||
IN EFI_HANDLE ImageHandle,
|
||||
IN EFI_SYSTEM_TABLE *SystemTable
|
||||
IN UINTN EntryPoint,
|
||||
IN EFI_HANDLE ImageHandle,
|
||||
IN EFI_SYSTEM_TABLE *SystemTable
|
||||
)
|
||||
{
|
||||
//
|
||||
@@ -373,7 +374,7 @@ ExecuteEbcImageEntryPoint (
|
||||
//
|
||||
// Now clear out our context
|
||||
//
|
||||
ZeroMem ((VOID *) &VmContext, sizeof (VM_CONTEXT));
|
||||
ZeroMem ((VOID *)&VmContext, sizeof (VM_CONTEXT));
|
||||
|
||||
//
|
||||
// Save the image handle so we can track the thunks created for this image
|
||||
@@ -384,7 +385,7 @@ ExecuteEbcImageEntryPoint (
|
||||
//
|
||||
// Set the VM instruction pointer to the correct location in memory.
|
||||
//
|
||||
VmContext.Ip = (VMIP) Addr;
|
||||
VmContext.Ip = (VMIP)Addr;
|
||||
|
||||
//
|
||||
// Initialize the stack pointer for the EBC. Get the current system stack
|
||||
@@ -394,33 +395,34 @@ ExecuteEbcImageEntryPoint (
|
||||
//
|
||||
// Allocate stack pool
|
||||
//
|
||||
Status = GetEBCStack(ImageHandle, &VmContext.StackPool, &StackIndex);
|
||||
if (EFI_ERROR(Status)) {
|
||||
Status = GetEBCStack (ImageHandle, &VmContext.StackPool, &StackIndex);
|
||||
if (EFI_ERROR (Status)) {
|
||||
return Status;
|
||||
}
|
||||
VmContext.StackTop = (UINT8*)VmContext.StackPool + (STACK_REMAIN_SIZE);
|
||||
VmContext.Gpr[0] = (UINT64)(UINTN) ((UINT8*)VmContext.StackPool + STACK_POOL_SIZE);
|
||||
|
||||
VmContext.StackTop = (UINT8 *)VmContext.StackPool + (STACK_REMAIN_SIZE);
|
||||
VmContext.Gpr[0] = (UINT64)(UINTN)((UINT8 *)VmContext.StackPool + STACK_POOL_SIZE);
|
||||
VmContext.HighStackBottom = (UINTN)VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
|
||||
//
|
||||
// Put a magic value in the stack gap, then adjust down again
|
||||
//
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) VM_STACK_KEY_VALUE;
|
||||
VmContext.StackMagicPtr = (UINTN *) (UINTN) VmContext.Gpr[0];
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)VM_STACK_KEY_VALUE;
|
||||
VmContext.StackMagicPtr = (UINTN *)(UINTN)VmContext.Gpr[0];
|
||||
|
||||
//
|
||||
// Align the stack on a natural boundary
|
||||
// VmContext.Gpr[0] &= ~(sizeof(UINTN) - 1);
|
||||
//
|
||||
VmContext.LowStackTop = (UINTN) VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) SystemTable;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *) (UINTN) (VmContext.Gpr[0]) = (UINTN) ImageHandle;
|
||||
VmContext.LowStackTop = (UINTN)VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)SystemTable;
|
||||
VmContext.Gpr[0] -= sizeof (UINTN);
|
||||
*(UINTN *)(UINTN)(VmContext.Gpr[0]) = (UINTN)ImageHandle;
|
||||
|
||||
VmContext.Gpr[0] -= 16;
|
||||
VmContext.StackRetAddr = (UINT64) VmContext.Gpr[0];
|
||||
VmContext.Gpr[0] -= 16;
|
||||
VmContext.StackRetAddr = (UINT64)VmContext.Gpr[0];
|
||||
//
|
||||
// VM pushes 16-bytes for return address. Simulate that here.
|
||||
//
|
||||
@@ -434,11 +436,10 @@ ExecuteEbcImageEntryPoint (
|
||||
//
|
||||
// Return the value in Gpr[7] unless there was an error
|
||||
//
|
||||
ReturnEBCStack(StackIndex);
|
||||
return (UINT64) VmContext.Gpr[7];
|
||||
ReturnEBCStack (StackIndex);
|
||||
return (UINT64)VmContext.Gpr[7];
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
Create thunks for an EBC image entry point, or an EBC protocol service.
|
||||
|
||||
@@ -458,31 +459,32 @@ ExecuteEbcImageEntryPoint (
|
||||
**/
|
||||
EFI_STATUS
|
||||
EbcCreateThunks (
|
||||
IN EFI_HANDLE ImageHandle,
|
||||
IN VOID *EbcEntryPoint,
|
||||
OUT VOID **Thunk,
|
||||
IN UINT32 Flags
|
||||
IN EFI_HANDLE ImageHandle,
|
||||
IN VOID *EbcEntryPoint,
|
||||
OUT VOID **Thunk,
|
||||
IN UINT32 Flags
|
||||
)
|
||||
{
|
||||
UINT8 *Ptr;
|
||||
UINT8 *ThunkBase;
|
||||
UINT32 Index;
|
||||
INT32 ThunkSize;
|
||||
UINT8 *Ptr;
|
||||
UINT8 *ThunkBase;
|
||||
UINT32 Index;
|
||||
INT32 ThunkSize;
|
||||
|
||||
//
|
||||
// Check alignment of pointer to EBC code
|
||||
//
|
||||
if ((UINT32) (UINTN) EbcEntryPoint & 0x01) {
|
||||
if ((UINT32)(UINTN)EbcEntryPoint & 0x01) {
|
||||
return EFI_INVALID_PARAMETER;
|
||||
}
|
||||
|
||||
ThunkSize = sizeof(mInstructionBufferTemplate);
|
||||
ThunkSize = sizeof (mInstructionBufferTemplate);
|
||||
|
||||
Ptr = EbcAllocatePoolForThunk (sizeof(mInstructionBufferTemplate));
|
||||
Ptr = EbcAllocatePoolForThunk (sizeof (mInstructionBufferTemplate));
|
||||
|
||||
if (Ptr == NULL) {
|
||||
return EFI_OUT_OF_RESOURCES;
|
||||
}
|
||||
|
||||
//
|
||||
// Print(L"Allocate TH: 0x%X\n", (UINT32)Ptr);
|
||||
//
|
||||
@@ -493,20 +495,21 @@ EbcCreateThunks (
|
||||
//
|
||||
// Give them the address of our buffer we're going to fix up
|
||||
//
|
||||
*Thunk = (VOID *) Ptr;
|
||||
*Thunk = (VOID *)Ptr;
|
||||
|
||||
//
|
||||
// Copy whole thunk instruction buffer template
|
||||
//
|
||||
CopyMem (Ptr, mInstructionBufferTemplate, sizeof(mInstructionBufferTemplate));
|
||||
CopyMem (Ptr, mInstructionBufferTemplate, sizeof (mInstructionBufferTemplate));
|
||||
|
||||
//
|
||||
// Patch EbcEntryPoint and EbcLLEbcInterpret
|
||||
//
|
||||
for (Index = 0; Index < sizeof(mInstructionBufferTemplate) - sizeof(UINTN); Index++) {
|
||||
for (Index = 0; Index < sizeof (mInstructionBufferTemplate) - sizeof (UINTN); Index++) {
|
||||
if (*(UINTN *)&Ptr[Index] == EBC_ENTRYPOINT_SIGNATURE) {
|
||||
*(UINTN *)&Ptr[Index] = (UINTN)EbcEntryPoint;
|
||||
}
|
||||
|
||||
if (*(UINTN *)&Ptr[Index] == EBC_LL_EBC_ENTRYPOINT_SIGNATURE) {
|
||||
if ((Flags & FLAG_THUNK_ENTRY_POINT) != 0) {
|
||||
*(UINTN *)&Ptr[Index] = (UINTN)EbcLLExecuteEbcImageEntryPoint;
|
||||
@@ -520,7 +523,7 @@ EbcCreateThunks (
|
||||
// Add the thunk to the list for this image. Do this last since the add
|
||||
// function flushes the cache for us.
|
||||
//
|
||||
EbcAddImageThunk (ImageHandle, (VOID *) ThunkBase, ThunkSize);
|
||||
EbcAddImageThunk (ImageHandle, (VOID *)ThunkBase, ThunkSize);
|
||||
|
||||
return EFI_SUCCESS;
|
||||
}
|
||||
|
Reference in New Issue
Block a user