/*++\r
\r
-Copyright (c) 2005 - 2008, Intel Corporation \r
+Copyright (c) 2004 - 2008, Intel Corporation \r
All rights reserved. This program and the accompanying materials \r
are licensed and made available under the terms and conditions of the BSD License \r
which accompanies this distribution. The full text of the license may be found at \r
BOOLEAN mEfiAtRuntime = FALSE;\r
FVB_ENTRY *mFvbEntry;\r
\r
+#if (EFI_SPECIFICATION_VERSION >= 0x00020000)\r
static EFI_STATUS_CODE_PROTOCOL *gStatusCode = NULL;\r
+#endif\r
\r
EFI_STATUS\r
EfiConvertPointer (\r
// Update global for Runtime Services Table and IO\r
//\r
EfiConvertInternalPointer ((VOID **) &gCpuIo);\r
+#if (EFI_SPECIFICATION_VERSION >= 0x00020000)\r
if (gStatusCode != NULL) {\r
EfiConvertInternalPointer ((VOID **) &gStatusCode->ReportStatusCode);\r
EfiConvertInternalPointer ((VOID **) &gStatusCode);\r
}\r
+#endif\r
EfiConvertInternalPointer ((VOID **) &mRT);\r
\r
//\r
Status = EfiLibGetSystemConfigurationTable (&gEfiDxeServicesTableGuid, (VOID **) &gDS);\r
ASSERT_EFI_ERROR (Status);\r
\r
+#if (EFI_SPECIFICATION_VERSION >= 0x00020000)\r
Status = gBS->LocateProtocol (&gEfiStatusCodeRuntimeProtocolGuid, NULL, (VOID **)&gStatusCode);\r
if (EFI_ERROR (Status)) {\r
gStatusCode = NULL;\r
}\r
+#endif\r
\r
Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, (VOID **) &gCpuIo);\r
if (EFI_ERROR (Status)) {\r
mRT = SystemTable->RuntimeServices;\r
ASSERT (mRT != NULL);\r
\r
+#if (EFI_SPECIFICATION_VERSION >= 0x00020000)\r
Status = gBS->LocateProtocol (&gEfiStatusCodeRuntimeProtocolGuid, NULL, (VOID **)&gStatusCode);\r
if (EFI_ERROR (Status)) {\r
gStatusCode = NULL;\r
}\r
+#endif\r
\r
Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, (VOID **) &gCpuIo);\r
if (EFI_ERROR (Status)) {\r
return mRT->SetVariable (VariableName, VendorGuid, Attributes, DataSize, Data);\r
}\r
\r
+\r
#if (EFI_SPECIFICATION_VERSION >= 0x00020000)\r
\r
EFI_STATUS\r
\r
#endif\r
\r
-\r
EFI_STATUS\r
EfiGetNextHighMonotonicCount (\r
OUT UINT32 *HighCount\r
--*/\r
{\r
EFI_STATUS Status;\r
- \r
- Status = EFI_UNSUPPORTED;\r
\r
- if (mRT->Hdr.Revision >= 0x00020000) {\r
- if (gStatusCode == NULL) {\r
- if (EfiAtRuntime ()) {\r
- return EFI_UNSUPPORTED;\r
- }\r
- Status = gBS->LocateProtocol (&gEfiStatusCodeRuntimeProtocolGuid, NULL, (VOID **)&gStatusCode);\r
- if (EFI_ERROR (Status) || gStatusCode == NULL) {\r
- return EFI_UNSUPPORTED;\r
- }\r
- }\r
- Status = gStatusCode->ReportStatusCode (CodeType, Value, Instance, CallerId, Data);\r
- } else {\r
- if (mRT == NULL) {\r
- return EFI_UNSUPPORTED;\r
- }\r
- //\r
- // Check whether EFI_RUNTIME_SERVICES has Tiano Extension\r
- //\r
- Status = EFI_UNSUPPORTED;\r
-#if (EFI_SPECIFICATION_VERSION < 0x00020000)\r
- if (mRT->Hdr.Revision == EFI_SPECIFICATION_VERSION &&\r
- mRT->Hdr.HeaderSize == sizeof (EFI_RUNTIME_SERVICES) &&\r
- mRT->ReportStatusCode != NULL) {\r
+#if (EFI_SPECIFICATION_VERSION >= 0x00020000) \r
+ if (gStatusCode == NULL) {\r
+ if (EfiAtRuntime ()) {\r
+ return EFI_UNSUPPORTED;\r
+ }\r
+ Status = gBS->LocateProtocol (&gEfiStatusCodeRuntimeProtocolGuid, NULL, (VOID **)&gStatusCode);\r
+ if (EFI_ERROR (Status) || gStatusCode == NULL) {\r
+ return EFI_UNSUPPORTED;\r
+ }\r
+ }\r
+ Status = gStatusCode->ReportStatusCode (CodeType, Value, Instance, CallerId, Data);\r
+#else\r
+ if (mRT == NULL) {\r
+ return EFI_UNSUPPORTED;\r
+ }\r
+ //\r
+ // Check whether EFI_RUNTIME_SERVICES has Tiano Extension\r
+ //\r
+ Status = EFI_UNSUPPORTED;\r
+ if (mRT->Hdr.Revision == EFI_SPECIFICATION_VERSION &&\r
+ mRT->Hdr.HeaderSize == sizeof (EFI_RUNTIME_SERVICES) &&\r
+ mRT->ReportStatusCode != NULL) {\r
Status = mRT->ReportStatusCode (CodeType, Value, Instance, CallerId, Data);\r
+ }\r
#endif\r
- }\r
- }\r
return Status;\r
}\r