]> git.proxmox.com Git - mirror_edk2.git/blobdiff - IntelFsp2Pkg/FspSecCore/SecFspApiChk.c
IntelFsp2Pkg: Adopt FSP 2.4 MultiPhase functions.
[mirror_edk2.git] / IntelFsp2Pkg / FspSecCore / SecFspApiChk.c
index e22a88cc84d7e17dc0a3c16ccdcf3a784c3d80c7..a44fbf2a50b56c07f24064d4663044e2b868212a 100644 (file)
@@ -69,6 +69,28 @@ FspApiCallingCheck (
         Status = EFI_UNSUPPORTED;\r
       } else if (EFI_ERROR (FspUpdSignatureCheck (FspSiliconInitApiIndex, ApiParam))) {\r
         Status = EFI_INVALID_PARAMETER;\r
+      } else if (ApiIdx == FspSiliconInitApiIndex) {\r
+        //\r
+        // Reset MultiPhase NumberOfPhases to zero\r
+        //\r
+        FspData->NumberOfPhases = 0;\r
+      }\r
+    }\r
+  } else if (ApiIdx == FspMultiPhaseMemInitApiIndex) {\r
+    if ((FspData == NULL) || ((UINTN)FspData == MAX_ADDRESS) || ((UINTN)FspData == MAX_UINT32)) {\r
+      Status = EFI_UNSUPPORTED;\r
+    }\r
+  } else if (ApiIdx == FspSmmInitApiIndex) {\r
+    //\r
+    // FspSmmInitApiIndex check\r
+    //\r
+    if ((FspData == NULL) || ((UINTN)FspData == MAX_ADDRESS) || ((UINTN)FspData == MAX_UINT32)) {\r
+      Status = EFI_UNSUPPORTED;\r
+    } else {\r
+      if (FspData->Signature != FSP_GLOBAL_DATA_SIGNATURE) {\r
+        Status = EFI_UNSUPPORTED;\r
+      } else if (EFI_ERROR (FspUpdSignatureCheck (FspSmmInitApiIndex, ApiParam))) {\r
+        Status = EFI_INVALID_PARAMETER;\r
       }\r
     }\r
   } else {\r