mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-11-04 05:25:45 +01:00 
			
		
		
		
	git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@11105 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			602 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			602 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*++
 | 
						|
 | 
						|
Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
 | 
						|
Portions copyright (c) 2008 - 2010, Apple Inc. 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.             
 | 
						|
 | 
						|
 | 
						|
Module Name:
 | 
						|
  SecMain.h
 | 
						|
 | 
						|
Abstract:
 | 
						|
  Include file for host API based SEC
 | 
						|
 | 
						|
--*/
 | 
						|
#include <PiPei.h>
 | 
						|
 | 
						|
#include <Protocol/UnixThunk.h>
 | 
						|
#include <Ppi/StatusCode.h>
 | 
						|
 | 
						|
#include <Library/PeCoffLib.h>
 | 
						|
#include <Library/BaseLib.h>
 | 
						|
#include <Library/BaseMemoryLib.h>
 | 
						|
#include <Library/PrintLib.h>
 | 
						|
#include <Library/PcdLib.h>
 | 
						|
#include <Library/DebugLib.h>
 | 
						|
#include <Library/ReportStatusCodeLib.h>
 | 
						|
#include <Library/SecDispatchTableLib.h>
 | 
						|
 | 
						|
 | 
						|
#define STACK_SIZE                0x20000      
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  EFI_PHYSICAL_ADDRESS  Address;
 | 
						|
  UINT64                Size;
 | 
						|
} UNIX_FD_INFO;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  EFI_PHYSICAL_ADDRESS  Memory;
 | 
						|
  UINT64                Size;
 | 
						|
} UNIX_SYSTEM_MEMORY;
 | 
						|
 | 
						|
 | 
						|
#define MAX_IMAGE_CONTEXT_TO_MOD_HANDLE_ARRAY_SIZE 0x100
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  PE_COFF_LOADER_IMAGE_CONTEXT   *ImageContext;
 | 
						|
  VOID                           *ModHandle;
 | 
						|
} IMAGE_CONTEXT_TO_MOD_HANDLE;
 | 
						|
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixPeiLoadFile (
 | 
						|
  VOID                  *Pe32Data,  // TODO: add IN/OUT modifier to Pe32Data
 | 
						|
  EFI_PHYSICAL_ADDRESS  *ImageAddress,  // TODO: add IN/OUT modifier to ImageAddress
 | 
						|
  UINT64                *ImageSize,  // TODO: add IN/OUT modifier to ImageSize
 | 
						|
  EFI_PHYSICAL_ADDRESS  *EntryPoint  // TODO: add IN/OUT modifier to EntryPoint
 | 
						|
  );
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecUnixPeiLoadFile (
 | 
						|
  VOID                  *Pe32Data,  // TODO: add IN/OUT modifier to Pe32Data
 | 
						|
  EFI_PHYSICAL_ADDRESS  *ImageAddress,  // TODO: add IN/OUT modifier to ImageAddress
 | 
						|
  UINT64                *ImageSize,  // TODO: add IN/OUT modifier to ImageSize
 | 
						|
  EFI_PHYSICAL_ADDRESS  *EntryPoint  // TODO: add IN/OUT modifier to EntryPoint
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Pe32Data      - TODO: add argument description
 | 
						|
  ImageAddress  - TODO: add argument description
 | 
						|
  ImageSize     - TODO: add argument description
 | 
						|
  EntryPoint    - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixPeiAutoScan (
 | 
						|
  IN  UINTN                 Index,
 | 
						|
  OUT EFI_PHYSICAL_ADDRESS  *MemoryBase,
 | 
						|
  OUT UINT64                *MemorySize
 | 
						|
  );
 | 
						|
  
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecUnixPeiAutoScan (
 | 
						|
  IN  UINTN                 Index,
 | 
						|
  OUT EFI_PHYSICAL_ADDRESS  *MemoryBase,
 | 
						|
  OUT UINT64                *MemorySize
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Index       - TODO: add argument description
 | 
						|
  MemoryBase  - TODO: add argument description
 | 
						|
  MemorySize  - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
VOID *
 | 
						|
EFIAPI
 | 
						|
SecUnixUnixThunkAddress (
 | 
						|
  VOID
 | 
						|
  );
 | 
						|
  
 | 
						|
VOID *
 | 
						|
EFIAPI
 | 
						|
GasketSecUnixUnixThunkAddress (
 | 
						|
  VOID
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  InterfaceSize - TODO: add argument description
 | 
						|
  InterfaceBase - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixUnixFwhAddress (
 | 
						|
  IN OUT UINT64                *FwhSize,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FwhBase
 | 
						|
  );
 | 
						|
  
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecUnixUnixFwhAddress (
 | 
						|
  IN OUT UINT64                *FwhSize,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FwhBase
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  FwhSize - TODO: add argument description
 | 
						|
  FwhBase - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecPeiReportStatusCode (
 | 
						|
  IN CONST EFI_PEI_SERVICES     **PeiServices,
 | 
						|
  IN EFI_STATUS_CODE_TYPE       CodeType,
 | 
						|
  IN EFI_STATUS_CODE_VALUE      Value,
 | 
						|
  IN UINT32                     Instance,
 | 
						|
  IN CONST EFI_GUID             *CallerId,
 | 
						|
  IN CONST EFI_STATUS_CODE_DATA *Data OPTIONAL
 | 
						|
  );
 | 
						|
  
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecPeiReportStatusCode (
 | 
						|
  IN CONST EFI_PEI_SERVICES     **PeiServices,
 | 
						|
  IN EFI_STATUS_CODE_TYPE       CodeType,
 | 
						|
  IN EFI_STATUS_CODE_VALUE      Value,
 | 
						|
  IN UINT32                     Instance,
 | 
						|
  IN CONST EFI_GUID             *CallerId,
 | 
						|
  IN CONST EFI_STATUS_CODE_DATA *Data OPTIONAL
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  PeiServices - TODO: add argument description
 | 
						|
  CodeType    - TODO: add argument description
 | 
						|
  Value       - TODO: add argument description
 | 
						|
  Instance    - TODO: add argument description
 | 
						|
  CallerId    - TODO: add argument description
 | 
						|
  Data        - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
int
 | 
						|
main (
 | 
						|
  IN  int   Argc,
 | 
						|
  IN  char  **Argv,
 | 
						|
  IN  char  **Envp
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Argc  - TODO: add argument description
 | 
						|
  Argv  - TODO: add argument description
 | 
						|
  Envp  - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
VOID
 | 
						|
SecLoadFromCore (
 | 
						|
  IN  UINTN   LargestRegion,
 | 
						|
  IN  UINTN   LargestRegionSize,
 | 
						|
  IN  UINTN   BootFirmwareVolumeBase,
 | 
						|
  IN  VOID    *PeiCoreFile
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  LargestRegion           - TODO: add argument description
 | 
						|
  LargestRegionSize       - TODO: add argument description
 | 
						|
  BootFirmwareVolumeBase  - TODO: add argument description
 | 
						|
  PeiCoreFile             - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
SecLoadFile (
 | 
						|
  IN  VOID                    *Pe32Data,
 | 
						|
  IN  EFI_PHYSICAL_ADDRESS    *ImageAddress,
 | 
						|
  IN  UINT64                  *ImageSize,
 | 
						|
  IN  EFI_PHYSICAL_ADDRESS    *EntryPoint
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Pe32Data      - TODO: add argument description
 | 
						|
  ImageAddress  - TODO: add argument description
 | 
						|
  ImageSize     - TODO: add argument description
 | 
						|
  EntryPoint    - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
SecFfsFindPeiCore (
 | 
						|
  IN  EFI_FIRMWARE_VOLUME_HEADER  *FwVolHeader,
 | 
						|
  OUT VOID                        **Pe32Data
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  FwVolHeader - TODO: add argument description
 | 
						|
  Pe32Data    - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
SecFfsFindNextFile (
 | 
						|
  IN EFI_FV_FILETYPE             SearchType,
 | 
						|
  IN EFI_FIRMWARE_VOLUME_HEADER  *FwVolHeader,
 | 
						|
  IN OUT EFI_FFS_FILE_HEADER     **FileHeader
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  SearchType  - TODO: add argument description
 | 
						|
  FwVolHeader - TODO: add argument description
 | 
						|
  FileHeader  - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
SecFfsFindSectionData (
 | 
						|
  IN EFI_SECTION_TYPE      SectionType,
 | 
						|
  IN EFI_FFS_FILE_HEADER   *FfsFileHeader,
 | 
						|
  IN OUT VOID              **SectionData
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  SectionType   - TODO: add argument description
 | 
						|
  FfsFileHeader - TODO: add argument description
 | 
						|
  SectionData   - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixPeCoffLoaderLoadAsDll (
 | 
						|
  IN CHAR8    *PdbFileName,
 | 
						|
  IN VOID     **ImageEntryPoint,
 | 
						|
  OUT VOID    **ModHandle
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  PdbFileName     - TODO: add argument description
 | 
						|
  ImageEntryPoint - TODO: add argument description
 | 
						|
  ModHandle       - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixPeCoffLoaderFreeLibrary (
 | 
						|
  OUT VOID    *ModHandle
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  ModHandle - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecUnixFdAddress (
 | 
						|
  IN     UINTN                 Index,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FdBase,
 | 
						|
  IN OUT UINT64                *FdSize,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FixUp
 | 
						|
  )
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecUnixFdAddress (
 | 
						|
  IN     UINTN                 Index,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FdBase,
 | 
						|
  IN OUT UINT64                *FdSize,
 | 
						|
  IN OUT EFI_PHYSICAL_ADDRESS  *FixUp
 | 
						|
  )
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
GetImageReadFunction (
 | 
						|
  IN PE_COFF_LOADER_IMAGE_CONTEXT          *ImageContext,
 | 
						|
  IN EFI_PHYSICAL_ADDRESS                  *TopOfMemory
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  ImageContext  - TODO: add argument description
 | 
						|
  TopOfMemory   - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecImageRead (
 | 
						|
  IN     VOID    *FileHandle,
 | 
						|
  IN     UINTN   FileOffset,
 | 
						|
  IN OUT UINTN   *ReadSize,
 | 
						|
  OUT    VOID    *Buffer
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  FileHandle  - TODO: add argument description
 | 
						|
  FileOffset  - TODO: add argument description
 | 
						|
  ReadSize    - TODO: add argument description
 | 
						|
  Buffer      - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
CHAR16                            *
 | 
						|
AsciiToUnicode (
 | 
						|
  IN  CHAR8   *Ascii,
 | 
						|
  IN  UINTN   *StrLen OPTIONAL
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Ascii   - TODO: add argument description
 | 
						|
  StrLen  - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
UINTN
 | 
						|
CountSeperatorsInString (
 | 
						|
  IN  const CHAR16   *String,
 | 
						|
  IN  CHAR16   Seperator
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  TODO: Add function description
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  String    - TODO: add argument description
 | 
						|
  Seperator - TODO: add argument description
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  TODO: add return values
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SecTemporaryRamSupport (
 | 
						|
  IN CONST EFI_PEI_SERVICES   **PeiServices,
 | 
						|
  IN EFI_PHYSICAL_ADDRESS     TemporaryMemoryBase,
 | 
						|
  IN EFI_PHYSICAL_ADDRESS     PermanentMemoryBase,
 | 
						|
  IN UINTN                    CopySize
 | 
						|
  );
 | 
						|
  
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
GasketSecTemporaryRamSupport (
 | 
						|
  IN CONST EFI_PEI_SERVICES   **PeiServices,
 | 
						|
  IN EFI_PHYSICAL_ADDRESS     TemporaryMemoryBase,
 | 
						|
  IN EFI_PHYSICAL_ADDRESS     PermanentMemoryBase,
 | 
						|
  IN UINTN                    CopySize
 | 
						|
  );
 | 
						|
 | 
						|
 | 
						|
RETURN_STATUS
 | 
						|
EFIAPI
 | 
						|
SecPeCoffGetEntryPoint (
 | 
						|
  IN     VOID  *Pe32Data,
 | 
						|
  IN OUT VOID  **EntryPoint
 | 
						|
  );
 | 
						|
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
SecPeCoffRelocateImageExtraAction (
 | 
						|
  IN OUT PE_COFF_LOADER_IMAGE_CONTEXT  *ImageContext
 | 
						|
  );
 | 
						|
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
SecPeCoffLoaderUnloadImageExtraAction (
 | 
						|
  IN OUT PE_COFF_LOADER_IMAGE_CONTEXT  *ImageContext
 | 
						|
  );
 | 
						|
 | 
						|
 | 
						|
VOID SetTimer (UINT64 PeriodMs, VOID (*CallBack)(UINT64 DeltaMs));
 | 
						|
void msSleep (unsigned long Milliseconds);
 | 
						|
void GetLocalTime (EFI_TIME *Time);
 | 
						|
void TzSet (void);
 | 
						|
long GetTimeZone(void);
 | 
						|
int GetDayLight(void);
 | 
						|
int GetErrno(void);
 | 
						|
void UnixEnableInterrupt (void);
 | 
						|
void UnixDisableInterrupt (void);
 | 
						|
BOOLEAN UnixInterruptEanbled (void);
 | 
						|
 | 
						|
 | 
						|
 | 
						|
extern EFI_UNIX_THUNK_PROTOCOL  *gUnix;
 |