git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@10403 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			154 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  Describes the protocol interface to the EBC interpreter.
 | 
						|
 | 
						|
  Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
 | 
						|
  This program and the accompanying materials                          
 | 
						|
  are licensed and made available under the terms and conditions of the BSD License         
 | 
						|
  which accompanies this distribution.  The full text of the license may be found at        
 | 
						|
  http://opensource.org/licenses/bsd-license.php                                            
 | 
						|
 | 
						|
  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
 | 
						|
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#ifndef __EFI_EBC_PROTOCOL_H__
 | 
						|
#define __EFI_EBC_PROTOCOL_H__
 | 
						|
 | 
						|
#define EFI_EBC_INTERPRETER_PROTOCOL_GUID \
 | 
						|
  { \
 | 
						|
    0x13AC6DD1, 0x73D0, 0x11D4, {0xB0, 0x6B, 0x00, 0xAA, 0x00, 0xBD, 0x6D, 0xE7 } \
 | 
						|
  }
 | 
						|
 | 
						|
///
 | 
						|
/// Protocol Guid Name defined in spec.
 | 
						|
///
 | 
						|
#define EFI_EBC_PROTOCOL_GUID EFI_EBC_INTERPRETER_PROTOCOL_GUID
 | 
						|
 | 
						|
///
 | 
						|
/// Define for forward reference.
 | 
						|
///
 | 
						|
typedef struct _EFI_EBC_PROTOCOL EFI_EBC_PROTOCOL;
 | 
						|
 | 
						|
/**
 | 
						|
  Creates a thunk for an EBC entry point, returning the address of the thunk.
 | 
						|
  
 | 
						|
  A PE32+ EBC image, like any other PE32+ image, contains an optional header that specifies the
 | 
						|
  entry point for image execution. However, for EBC images, this is the entry point of EBC
 | 
						|
  instructions, so is not directly executable by the native processor. Therefore, when an EBC image is
 | 
						|
  loaded, the loader must call this service to get a pointer to native code (thunk) that can be executed,
 | 
						|
  which will invoke the interpreter to begin execution at the original EBC entry point.
 | 
						|
 | 
						|
  @param  This          A pointer to the EFI_EBC_PROTOCOL instance.
 | 
						|
  @param  ImageHandle   Handle of image for which the thunk is being created.
 | 
						|
  @param  EbcEntryPoint Address of the actual EBC entry point or protocol service the thunk should call.
 | 
						|
  @param  Thunk         Returned pointer to a thunk created.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS            The function completed successfully.
 | 
						|
  @retval EFI_INVALID_PARAMETER  Image entry point is not 2-byte aligned.
 | 
						|
  @retval EFI_OUT_OF_RESOURCES   Memory could not be allocated for the thunk.
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EFI_EBC_CREATE_THUNK)(
 | 
						|
  IN EFI_EBC_PROTOCOL           *This,
 | 
						|
  IN EFI_HANDLE                 ImageHandle,
 | 
						|
  IN VOID                       *EbcEntryPoint,
 | 
						|
  OUT VOID                      **Thunk
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Called prior to unloading an EBC image from memory.
 | 
						|
 | 
						|
  This function is called after an EBC image has exited, but before the image is actually unloaded. It
 | 
						|
  is intended to provide the interpreter with the opportunity to perform any cleanup that may be
 | 
						|
  necessary as a result of loading and executing the image.
 | 
						|
 | 
						|
  @param  This          A pointer to the EFI_EBC_PROTOCOL instance.
 | 
						|
  @param  ImageHandle   Image handle of the EBC image that is being unloaded from memory.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS            The function completed successfully.
 | 
						|
  @retval EFI_INVALID_PARAMETER  Image handle is not recognized as belonging 
 | 
						|
                                 to an EBC image that has been executed.
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EFI_EBC_UNLOAD_IMAGE)(
 | 
						|
  IN EFI_EBC_PROTOCOL           *This,
 | 
						|
  IN EFI_HANDLE                 ImageHandle
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  This is the prototype for the Flush callback routine. A pointer to a routine 
 | 
						|
  of this type is passed to the EBC EFI_EBC_REGISTER_ICACHE_FLUSH protocol service.
 | 
						|
 | 
						|
  @param  Start  The beginning physical address to flush from the processor's instruction cache.
 | 
						|
  @param  Length The number of bytes to flush from the processor's instruction cache.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS            The function completed successfully.
 | 
						|
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EBC_ICACHE_FLUSH)(
 | 
						|
  IN EFI_PHYSICAL_ADDRESS     Start,
 | 
						|
  IN UINT64                   Length
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Registers a callback function that the EBC interpreter calls to flush 
 | 
						|
  the processor instruction cache following creation of thunks.
 | 
						|
 | 
						|
  @param  This       A pointer to the EFI_EBC_PROTOCOL instance.
 | 
						|
  @param  Flush      Pointer to a function of type EBC_ICACH_FLUSH.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS            The function completed successfully.
 | 
						|
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EFI_EBC_REGISTER_ICACHE_FLUSH)(
 | 
						|
  IN EFI_EBC_PROTOCOL           *This,
 | 
						|
  IN EBC_ICACHE_FLUSH           Flush
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Called to get the version of the interpreter.
 | 
						|
 | 
						|
  This function is called to get the version of the loaded EBC interpreter. The value and format of the
 | 
						|
  returned version is identical to that returned by the EBC BREAK 1 instruction.
 | 
						|
 | 
						|
  @param  This       A pointer to the EFI_EBC_PROTOCOL instance.  
 | 
						|
  @param  Version    Pointer to where to store the returned version of the interpreter.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS            The function completed successfully.
 | 
						|
  @retval EFI_INVALID_PARAMETER  Version pointer is NULL.
 | 
						|
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EFI_EBC_GET_VERSION)(
 | 
						|
  IN EFI_EBC_PROTOCOL           *This,
 | 
						|
  IN OUT UINT64                 *Version
 | 
						|
  );
 | 
						|
 | 
						|
///
 | 
						|
/// The EFI EBC protocol provides services to load and execute EBC images, which will typically be
 | 
						|
/// loaded into option ROMs. The image loader will load the EBC image, perform standard relocations,
 | 
						|
/// and invoke the CreateThunk() service to create a thunk for the EBC image's entry point. The
 | 
						|
/// image can then be run using the standard EFI start image services.
 | 
						|
///
 | 
						|
struct _EFI_EBC_PROTOCOL {
 | 
						|
  EFI_EBC_CREATE_THUNK          CreateThunk;
 | 
						|
  EFI_EBC_UNLOAD_IMAGE          UnloadImage;
 | 
						|
  EFI_EBC_REGISTER_ICACHE_FLUSH RegisterICacheFlush;
 | 
						|
  EFI_EBC_GET_VERSION           GetVersion;
 | 
						|
};
 | 
						|
 | 
						|
//
 | 
						|
// Extern the global EBC protocol GUID
 | 
						|
//
 | 
						|
extern EFI_GUID gEfiEbcProtocolGuid;
 | 
						|
 | 
						|
#endif
 |