diff options
author | Yao, Jiewen <jiewen.yao@intel.com> | 2015-02-11 04:41:46 +0000 |
---|---|---|
committer | jyao1 <jyao1@Edk2> | 2015-02-11 04:41:46 +0000 |
commit | d8043ce905a5832f911361ef30be28765afbdc6b (patch) | |
tree | 4b4f7171c97efc733c95cc3abf65af351017c955 /IntelFspWrapperPkg/FspInitPei/SecMain.c | |
parent | d5fb1edfb16a2af29486ffbf5aa32a036da9caa4 (diff) | |
download | edk2-platforms-d8043ce905a5832f911361ef30be28765afbdc6b.tar.xz |
Update IntelFspWrapperPkg according to FSP1.1.
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: "Yao, Jiewen" <jiewen.yao@intel.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16826 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'IntelFspWrapperPkg/FspInitPei/SecMain.c')
-rw-r--r-- | IntelFspWrapperPkg/FspInitPei/SecMain.c | 43 |
1 files changed, 42 insertions, 1 deletions
diff --git a/IntelFspWrapperPkg/FspInitPei/SecMain.c b/IntelFspWrapperPkg/FspInitPei/SecMain.c index 10550e74de..4d0878a9df 100644 --- a/IntelFspWrapperPkg/FspInitPei/SecMain.c +++ b/IntelFspWrapperPkg/FspInitPei/SecMain.c @@ -1,7 +1,7 @@ /** @file
C functions in SEC
- Copyright (c) 2014, Intel Corporation. All rights reserved.<BR>
+ Copyright (c) 2014 - 2015, 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
@@ -28,6 +28,10 @@ EFI_PEI_PPI_DESCRIPTOR mPeiSecMainPpi[] = { },
};
+FSP_INIT_DONE_PPI gFspInitDonePpi = {
+ FspInitDoneGetFspHobList
+};
+
//
// These are IDT entries pointing to 10:FFFFFFE4h.
//
@@ -267,3 +271,40 @@ SecStartupPhase2( //
return ;
}
+
+/**
+ Return Hob list produced by FSP.
+
+ @param[in] PeiServices The pointer to the PEI Services Table.
+ @param[in] This The pointer to this instance of this PPI.
+ @param[out] FspHobList The pointer to Hob list produced by FSP.
+
+ @return EFI_SUCCESS FReturn Hob list produced by FSP successfully.
+**/
+EFI_STATUS
+EFIAPI
+FspInitDoneGetFspHobList (
+ IN CONST EFI_PEI_SERVICES **PeiServices,
+ IN FSP_INIT_DONE_PPI *This,
+ OUT VOID **FspHobList
+ )
+{
+ VOID *TopOfTemporaryRamPpi;
+ EFI_STATUS Status;
+
+ Status = (*PeiServices)->LocatePpi (
+ PeiServices,
+ &gTopOfTemporaryRamPpiGuid,
+ 0,
+ NULL,
+ (VOID **) &TopOfTemporaryRamPpi
+ );
+ if (EFI_ERROR (Status)) {
+ return EFI_NOT_FOUND;
+ }
+
+ *FspHobList = (VOID *)(UINTN)(*(UINT32 *)((UINTN)TopOfTemporaryRamPpi - sizeof(UINT32)));
+
+ return EFI_SUCCESS;
+}
+
|