/** @file
|
*
|
* Copyright (c) 2014, ARM Limited. All rights reserved.
|
*
|
* SPDX-License-Identifier: BSD-2-Clause-Patent
|
*
|
**/
|
|
#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
|