Use the command to load and start a ARM Executable File from mass storage. This is basically just an ELF file. The program is copied to memory and the Entrypoint is called. Control is not expected to return back to the Shell. This has only been tested on AArch64 with a limited set of AXF binaries. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Harry Liebel <Harry.Liebel@arm.com> Reviewed-By: Olivier Martin <olivier.martin@arm.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16247 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| *
 | |
| *  Copyright (c) 2014, ARM Limited. All rights reserved.
 | |
| *
 | |
| *  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 ELF_LOADER_H
 | |
| #define ELF_LOADER_H
 | |
| 
 | |
| /**
 | |
|   Check that the ELF File Header is valid and Machine type supported.
 | |
| 
 | |
|   Not all information is checked in the ELF header, only the stuff that
 | |
|   matters to us in our simplified ELF loader.
 | |
| 
 | |
|   @param[in] ElfImage  Address of the ELF file to check.
 | |
| 
 | |
|   @retval EFI_SUCCESS on success.
 | |
|   @retval EFI_INVALID_PARAMETER if the header is invalid.
 | |
|   @retval EFI_UNSUPPORTED if the file type/platform is not supported.
 | |
| **/
 | |
| EFI_STATUS
 | |
| ElfCheckFile (
 | |
|   IN  CONST VOID *ElfImage
 | |
|   );
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Load a ELF file.
 | |
| 
 | |
|   @param[in]  ElfImage      Address of the ELF file in memory.
 | |
| 
 | |
|   @param[out] EntryPoint    Will be filled with the ELF entry point address.
 | |
| 
 | |
|   @param[out] ImageSize     Will be filled with the ELF size in memory. This will
 | |
|                             effectively be equal to the sum of the segments sizes.
 | |
| 
 | |
|   This function assumes the header is valid and supported as checked with
 | |
|   ElfCheckFile().
 | |
| 
 | |
|   NOTE:
 | |
|    - We don't currently take the segment permissions into account (indicated by
 | |
|      the program headers). It can be used to allocate pages with the right
 | |
|      read/write/exec permissions.
 | |
| 
 | |
|   @retval EFI_SUCCESS on success.
 | |
|   @retval EFI_INVALID_PARAMETER if the ELF file is invalid.
 | |
| **/
 | |
| EFI_STATUS
 | |
| ElfLoadFile (
 | |
|   IN  CONST VOID   *ElfImage,
 | |
|   OUT VOID        **EntryPoint,
 | |
|   OUT LIST_ENTRY   *LoadList
 | |
|   );
 | |
| 
 | |
| #endif // ELF_LOADER_H
 |