mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-24 21:50:26 +00:00 
			
		
		
		
	 495809a614
			
		
	
	
		495809a614
		
	
	
	
	
		
			
			This patch substitutes the macros that were renamed in the first patch with the new, shared alignment macros. Cc: Jian J Wang <jian.j.wang@intel.com> Cc: Hao A Wu <hao.a.wu@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Vitaly Cheptsov <vit9696@protonmail.com> Signed-off-by: Marvin Häuser <mhaeuser@posteo.de> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Reviewed-by: Hao A Wu <hao.a.wu@intel.com> Reviewed-by: Michael D Kinney <michael.d.kinney@intel.com>
		
			
				
	
	
		
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   Header file for Virtual Machine support. Contains EBC defines that can
 | |
|   be of use to a disassembler for the most part. Also provides function
 | |
|   prototypes for VM functions.
 | |
| 
 | |
| Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR>
 | |
| SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef _EBC_EXECUTE_H_
 | |
| #define _EBC_EXECUTE_H_
 | |
| 
 | |
| //
 | |
| // Macros to check and set alignment
 | |
| //
 | |
| #define ASSERT_ALIGNED(addr, size)  ASSERT (ADDRESS_IS_ALIGNED (addr, size))
 | |
| 
 | |
| //
 | |
| // Debug macro
 | |
| //
 | |
| #define EBCMSG(s)  gST->ConOut->OutputString (gST->ConOut, s)
 | |
| 
 | |
| /**
 | |
|   Execute an EBC image from an entry point or from a published protocol.
 | |
| 
 | |
|   @param  VmPtr             A pointer to a VM context.
 | |
| 
 | |
|   @retval EFI_UNSUPPORTED   At least one of the opcodes is not supported.
 | |
|   @retval EFI_SUCCESS       All of the instructions are executed successfully.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EbcExecute (
 | |
|   IN VM_CONTEXT  *VmPtr
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Returns the version of the EBC virtual machine.
 | |
| 
 | |
|   @return The 64-bit version of EBC virtual machine.
 | |
| 
 | |
| **/
 | |
| UINT64
 | |
| GetVmVersion (
 | |
|   VOID
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Writes UINTN data to memory address.
 | |
| 
 | |
|   This routine is called by the EBC data
 | |
|   movement instructions that write to memory. Since these writes
 | |
|   may be to the stack, which looks like (high address on top) this,
 | |
| 
 | |
|   [EBC entry point arguments]
 | |
|   [VM stack]
 | |
|   [EBC stack]
 | |
| 
 | |
|   we need to detect all attempts to write to the EBC entry point argument
 | |
|   stack area and adjust the address (which will initially point into the
 | |
|   VM stack) to point into the EBC entry point arguments.
 | |
| 
 | |
|   @param  VmPtr             A pointer to a VM context.
 | |
|   @param  Addr              Address to write to.
 | |
|   @param  Data              Value to write to Addr.
 | |
| 
 | |
|   @retval EFI_SUCCESS       The instruction is executed successfully.
 | |
|   @retval Other             Some error occurs when writing data to the address.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| VmWriteMemN (
 | |
|   IN VM_CONTEXT  *VmPtr,
 | |
|   IN UINTN       Addr,
 | |
|   IN UINTN       Data
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Writes 64-bit data to memory address.
 | |
| 
 | |
|   This routine is called by the EBC data
 | |
|   movement instructions that write to memory. Since these writes
 | |
|   may be to the stack, which looks like (high address on top) this,
 | |
| 
 | |
|   [EBC entry point arguments]
 | |
|   [VM stack]
 | |
|   [EBC stack]
 | |
| 
 | |
|   we need to detect all attempts to write to the EBC entry point argument
 | |
|   stack area and adjust the address (which will initially point into the
 | |
|   VM stack) to point into the EBC entry point arguments.
 | |
| 
 | |
|   @param  VmPtr             A pointer to a VM context.
 | |
|   @param  Addr              Address to write to.
 | |
|   @param  Data              Value to write to Addr.
 | |
| 
 | |
|   @retval EFI_SUCCESS       The instruction is executed successfully.
 | |
|   @retval Other             Some error occurs when writing data to the address.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| VmWriteMem64 (
 | |
|   IN VM_CONTEXT  *VmPtr,
 | |
|   IN UINTN       Addr,
 | |
|   IN UINT64      Data
 | |
|   );
 | |
| 
 | |
| /**
 | |
|   Given a pointer to a new VM context, execute one or more instructions. This
 | |
|   function is only used for test purposes via the EBC VM test protocol.
 | |
| 
 | |
|   @param  This              A pointer to the EFI_EBC_VM_TEST_PROTOCOL structure.
 | |
|   @param  VmPtr             A pointer to a VM context.
 | |
|   @param  InstructionCount  A pointer to a UINTN value holding the number of
 | |
|                             instructions to execute. If it holds value of 0,
 | |
|                             then the instruction to be executed is 1.
 | |
| 
 | |
|   @retval EFI_UNSUPPORTED   At least one of the opcodes is not supported.
 | |
|   @retval EFI_SUCCESS       All of the instructions are executed successfully.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| EbcExecuteInstructions (
 | |
|   IN EFI_EBC_VM_TEST_PROTOCOL  *This,
 | |
|   IN VM_CONTEXT                *VmPtr,
 | |
|   IN OUT UINTN                 *InstructionCount
 | |
|   );
 | |
| 
 | |
| #endif // ifndef _EBC_EXECUTE_H_
 |