]> git.proxmox.com Git - mirror_edk2.git/commitdiff
Port AcpiResetDxe from EDK to EDKII to enable reset function on DUET above legacy...
authorniruiyu <niruiyu@6f19259b-4bc3-4df7-8a09-765794883524>
Sun, 21 Feb 2010 09:30:01 +0000 (09:30 +0000)
committerniruiyu <niruiyu@6f19259b-4bc3-4df7-8a09-765794883524>
Sun, 21 Feb 2010 09:30:01 +0000 (09:30 +0000)
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@10034 6f19259b-4bc3-4df7-8a09-765794883524

DuetPkg/AcpiResetDxe/Reset.c [new file with mode: 0644]
DuetPkg/AcpiResetDxe/Reset.h [new file with mode: 0644]
DuetPkg/AcpiResetDxe/Reset.inf [new file with mode: 0644]
DuetPkg/AcpiResetDxe/ResetEntry.c [new file with mode: 0644]
DuetPkg/DuetPkg.dsc
DuetPkg/DuetPkg.fdf
DuetPkg/DxeIpl/LegacyTable.c
DuetPkg/Include/Guid/AcpiDescription.h

diff --git a/DuetPkg/AcpiResetDxe/Reset.c b/DuetPkg/AcpiResetDxe/Reset.c
new file mode 100644 (file)
index 0000000..fe2d0a8
--- /dev/null
@@ -0,0 +1,194 @@
+/*++ @file\r
+  Reset Architectural Protocol implementation.\r
+\r
+Copyright (c) 2006 - 2010, 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
+http://opensource.org/licenses/bsd-license.php                                            \r
+                                                                                          \r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     \r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
+\r
+--*/\r
+\r
+#include "Reset.h"\r
+\r
+/**\r
+  Use ACPI method to reset the sytem. If fail, use legacy 8042 method to reset the system\r
+\r
+  @param[in] AcpiDescription   Global variable to record reset info\r
+\r
+**/\r
+VOID\r
+SystemReset (\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  )\r
+{\r
+  UINT8   Dev;\r
+  UINT8   Func;\r
+  UINT8   Register;\r
+\r
+  if ((AcpiDescription->RESET_REG.Address != 0) &&\r
+      ((AcpiDescription->RESET_REG.AddressSpaceId == EFI_ACPI_3_0_SYSTEM_IO) ||\r
+       (AcpiDescription->RESET_REG.AddressSpaceId == EFI_ACPI_3_0_SYSTEM_MEMORY) ||\r
+       (AcpiDescription->RESET_REG.AddressSpaceId == EFI_ACPI_3_0_PCI_CONFIGURATION_SPACE))) {\r
+    //\r
+    // Use ACPI System Reset\r
+    //\r
+    switch (AcpiDescription->RESET_REG.AddressSpaceId) {\r
+    case EFI_ACPI_3_0_SYSTEM_IO:\r
+      IoWrite8 ((UINTN) AcpiDescription->RESET_REG.Address, AcpiDescription->RESET_VALUE);\r
+      break;\r
+    case EFI_ACPI_3_0_SYSTEM_MEMORY:\r
+      MmioWrite8 ((UINTN) AcpiDescription->RESET_REG.Address, AcpiDescription->RESET_VALUE);\r
+      break;\r
+    case EFI_ACPI_3_0_PCI_CONFIGURATION_SPACE:\r
+      Register = (UINT8) AcpiDescription->RESET_REG.Address;\r
+      Func     = (UINT8) (RShiftU64 (AcpiDescription->RESET_REG.Address, 16) & 0x7);\r
+      Dev      = (UINT8) (RShiftU64 (AcpiDescription->RESET_REG.Address, 32) & 0x1F);\r
+      PciWrite8 (PCI_LIB_ADDRESS (0, Dev, Func, Register), AcpiDescription->RESET_VALUE);\r
+      break;\r
+    }\r
+  }\r
+\r
+  //\r
+  // If system comes here, means ACPI reset fail, do Legacy System Reset, assume 8042 available\r
+  //\r
+  Register = 0xfe;\r
+  IoWrite8 (0x64, Register);\r
+\r
+  //\r
+  // System should reset now\r
+  //\r
+\r
+  return ;\r
+}\r
+\r
+/**\r
+  Use ACPI method to shutdown the sytem\r
+\r
+  @param[in] AcpiDescription   Global variable to record reset info\r
+\r
+  @retval EFI_UNSUPPORTED      Shutdown fails\r
+\r
+**/\r
+EFI_STATUS\r
+SystemShutdown (\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  )\r
+{\r
+  UINT16  Value;\r
+\r
+  //\r
+  // 1. Write SLP_TYPa\r
+  //\r
+  if ((AcpiDescription->PM1a_CNT_BLK.Address != 0) && (AcpiDescription->SLP_TYPa != 0)) {\r
+    switch (AcpiDescription->PM1a_CNT_BLK.AddressSpaceId) {\r
+    case EFI_ACPI_3_0_SYSTEM_IO:\r
+      Value = IoRead16 ((UINTN) AcpiDescription->PM1a_CNT_BLK.Address);\r
+      Value = (Value & 0xc3ff) | 0x2000 | (AcpiDescription->SLP_TYPa << 10);\r
+      IoWrite16 ((UINTN) AcpiDescription->PM1a_CNT_BLK.Address, Value);\r
+      break;\r
+    case EFI_ACPI_3_0_SYSTEM_MEMORY:\r
+      Value = MmioRead16 ((UINTN) AcpiDescription->PM1a_CNT_BLK.Address);\r
+      Value = (Value & 0xc3ff) | 0x2000 | (AcpiDescription->SLP_TYPa << 10);\r
+      MmioWrite16 ((UINTN) AcpiDescription->PM1a_CNT_BLK.Address, Value);\r
+      break;\r
+    }\r
+  }\r
+\r
+  //\r
+  // 2. Write SLP_TYPb\r
+  //\r
+  if ((AcpiDescription->PM1b_CNT_BLK.Address != 0) && (AcpiDescription->SLP_TYPb != 0)) {\r
+    switch (AcpiDescription->PM1b_CNT_BLK.AddressSpaceId) {\r
+    case EFI_ACPI_3_0_SYSTEM_IO:\r
+      Value = IoRead16 ((UINTN) AcpiDescription->PM1b_CNT_BLK.Address);\r
+      Value = (Value & 0xc3ff) | 0x2000 | (AcpiDescription->SLP_TYPb << 10);\r
+      IoWrite16 ((UINTN) AcpiDescription->PM1b_CNT_BLK.Address, Value);\r
+      break;\r
+    case EFI_ACPI_3_0_SYSTEM_MEMORY:\r
+      Value = MmioRead16 ((UINTN) AcpiDescription->PM1b_CNT_BLK.Address);\r
+      Value = (Value & 0xc3ff) | 0x2000 | (AcpiDescription->SLP_TYPb << 10);\r
+      MmioWrite16 ((UINTN) AcpiDescription->PM1b_CNT_BLK.Address, Value);\r
+      break;\r
+    }\r
+  }\r
+\r
+  //\r
+  // Done, if code runs here, mean not shutdown correctly\r
+  //\r
+  return EFI_UNSUPPORTED;\r
+}\r
+\r
+/**\r
+  Reset the system.\r
+\r
+  @param[in] ResetType       Warm or cold\r
+  @param[in] ResetStatus     Possible cause of reset\r
+  @param[in] DataSize        Size of ResetData in bytes\r
+  @param[in] ResetData       Optional Unicode string\r
+  @param[in] AcpiDescription Global variable to record reset info\r
+\r
+**/\r
+VOID\r
+EFIAPI\r
+AcpiResetSystem (\r
+  IN EFI_RESET_TYPE   ResetType,\r
+  IN EFI_STATUS       ResetStatus,\r
+  IN UINTN            DataSize,\r
+  IN CHAR16           *ResetData, OPTIONAL\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  )\r
+{\r
+  EFI_STATUS  Status;\r
+\r
+  switch (ResetType) {\r
+  case EfiResetWarm:\r
+  case EfiResetCold:\r
+    SystemReset (AcpiDescription);\r
+    break;\r
+\r
+  case EfiResetShutdown:\r
+    Status = SystemShutdown (AcpiDescription);\r
+    if (EFI_ERROR (Status)) {\r
+      SystemReset (AcpiDescription);\r
+    }\r
+    break;\r
+\r
+  default:\r
+    return ;\r
+  }\r
+\r
+  //\r
+  // Given we should have reset getting here would be bad\r
+  //\r
+  ASSERT (FALSE);\r
+}\r
+\r
+BOOLEAN\r
+GetAcpiDescription (\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  )\r
+{\r
+  EFI_HOB_GUID_TYPE       *HobAcpiDescription;\r
+  //\r
+  // Get AcpiDescription Hob\r
+  //\r
+  HobAcpiDescription = GetFirstGuidHob (&gEfiAcpiDescriptionGuid);\r
+  if (HobAcpiDescription == NULL) {\r
+    return FALSE;\r
+  }\r
+\r
+  //\r
+  // Copy it to Runtime Memory\r
+  //\r
+  ASSERT (sizeof (EFI_ACPI_DESCRIPTION) == GET_GUID_HOB_DATA_SIZE (HobAcpiDescription));\r
+  CopyMem (AcpiDescription, GET_GUID_HOB_DATA (HobAcpiDescription), sizeof (EFI_ACPI_DESCRIPTION));\r
+\r
+  DEBUG ((EFI_D_ERROR, "ACPI Reset Base - %lx\n", AcpiDescription->RESET_REG.Address));\r
+  DEBUG ((EFI_D_ERROR, "ACPI Reset Value - %02x\n", (UINTN)AcpiDescription->RESET_VALUE));\r
+  DEBUG ((EFI_D_ERROR, "IAPC support - %x\n", (UINTN)(AcpiDescription->IAPC_BOOT_ARCH)));\r
+  return TRUE;\r
+}\r
diff --git a/DuetPkg/AcpiResetDxe/Reset.h b/DuetPkg/AcpiResetDxe/Reset.h
new file mode 100644 (file)
index 0000000..448c103
--- /dev/null
@@ -0,0 +1,74 @@
+/*++ @file\r
+  Some definitions for reset.\r
+\r
+Copyright (c) 2006 - 2010, 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
+http://opensource.org/licenses/bsd-license.php                                            \r
+                                                                                          \r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     \r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
+\r
+--*/\r
+\r
+#ifndef _ACPI_RESET_H\r
+#define _ACPI_RESET_H\r
+\r
+#include <PiDxe.h>\r
+\r
+#include <Library/BaseLib.h>\r
+#include <Library/IoLib.h>\r
+#include <Library/PciLib.h>\r
+#include <Library/HobLib.h>\r
+#include <Library/DebugLib.h>\r
+#include <Library/BaseMemoryLib.h>\r
+#include <Library/UefiBootServicesTableLib.h>\r
+\r
+#include <Protocol/Reset.h>\r
+#include <Guid/AcpiDescription.h>\r
+\r
+/**\r
+  Initialize the state information for the Reset Architectural Protocol.\r
+\r
+  @param[in] ImageHandle  Image handle of the loaded driver\r
+  @param[in] SystemTable  Pointer to the System Table\r
+\r
+  @retval EFI_SUCCESS           Thread can be successfully created\r
+  @retval EFI_UNSUPPORTED       Cannot find the info to reset system\r
+\r
+**/\r
+EFI_STATUS\r
+EFIAPI\r
+InitializeReset (\r
+  IN EFI_HANDLE        ImageHandle,\r
+  IN EFI_SYSTEM_TABLE  *SystemTable\r
+  )\r
+;\r
+\r
+/**\r
+  Reset the system.\r
+\r
+  @param[in] ResetType       Warm or cold\r
+  @param[in] ResetStatus     Possible cause of reset\r
+  @param[in] DataSize        Size of ResetData in bytes\r
+  @param[in] ResetData       Optional Unicode string\r
+\r
+**/\r
+VOID\r
+EFIAPI\r
+AcpiResetSystem (\r
+  IN EFI_RESET_TYPE   ResetType,\r
+  IN EFI_STATUS       ResetStatus,\r
+  IN UINTN            DataSize,\r
+  IN CHAR16           *ResetData, OPTIONAL\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  )\r
+;\r
+\r
+BOOLEAN\r
+GetAcpiDescription (\r
+  IN EFI_ACPI_DESCRIPTION *AcpiDescription\r
+  );\r
+\r
+#endif\r
diff --git a/DuetPkg/AcpiResetDxe/Reset.inf b/DuetPkg/AcpiResetDxe/Reset.inf
new file mode 100644 (file)
index 0000000..3af6bec
--- /dev/null
@@ -0,0 +1,54 @@
+#/** @file\r
+#  Component description file for AcpiResetDxe module.\r
+#\r
+# Copyright (c) 2006 - 2010, 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
+# http://opensource.org/licenses/bsd-license.php                                            \r
+#                                                                                           \r
+# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     \r
+# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
+#\r
+#\r
+#--*/\r
+[Defines]\r
+  INF_VERSION                    = 0x00010005\r
+  BASE_NAME                      = AcpiReset\r
+  FILE_GUID                      = 6F0198AA-1F1D-426D-AE3E-39AB633FCC28\r
+  MODULE_TYPE                    = DXE_RUNTIME_DRIVER\r
+  VERSION_STRING                 = 1.0\r
+  ENTRY_POINT                    = InitializeReset\r
+\r
+[Packages]\r
+  MdePkg/MdePkg.dec\r
+  DuetPkg/DuetPkg.dec\r
+\r
+[LibraryClasses]\r
+  DebugLib\r
+  UefiBootServicesTableLib\r
+  UefiDriverEntryPoint\r
+  IoLib\r
+  PciLib\r
+  HobLib\r
+  BaseLib\r
+  BaseMemoryLib\r
+\r
+[Sources]\r
+  Reset.c\r
+  Reset.h\r
+  ResetEntry.c\r
+\r
+[Protocols]\r
+  gEfiResetArchProtocolGuid\r
+\r
+[Guids]\r
+  gEfiAcpiDescriptionGuid\r
+\r
+[Depex]\r
+  TRUE\r
+\r
+[BuildOptions]\r
+  MSFT:*_*_IA32_CC_FLAGS  = /Od\r
+\r
+\r
diff --git a/DuetPkg/AcpiResetDxe/ResetEntry.c b/DuetPkg/AcpiResetDxe/ResetEntry.c
new file mode 100644 (file)
index 0000000..3da08a1
--- /dev/null
@@ -0,0 +1,88 @@
+/*++ @file\r
+  Entrypoint of AcpiResetDxe driver.\r
+\r
+Copyright (c) 2010, 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
+http://opensource.org/licenses/bsd-license.php                                            \r
+                                                                                          \r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     \r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
+--*/\r
+\r
+#include "Reset.h"\r
+\r
+EFI_ACPI_DESCRIPTION  mAcpiDescription;\r
+\r
+/**\r
+  Reset the system.\r
+\r
+  @param[in] ResetType       Warm or cold\r
+  @param[in] ResetStatus     Possible cause of reset\r
+  @param[in] DataSize        Size of ResetData in bytes\r
+  @param[in] ResetData       Optional Unicode string\r
+\r
+**/\r
+VOID\r
+EFIAPI\r
+EfiAcpiResetSystem (\r
+  IN EFI_RESET_TYPE   ResetType,\r
+  IN EFI_STATUS       ResetStatus,\r
+  IN UINTN            DataSize,\r
+  IN CHAR16           *ResetData OPTIONAL\r
+  )\r
+{\r
+  AcpiResetSystem (ResetType, ResetStatus, DataSize, ResetData, &mAcpiDescription);\r
+}\r
+\r
+/**\r
+  Initialize the state information for the Reset Architectural Protocol.\r
+\r
+  @param[in] ImageHandle  Image handle of the loaded driver\r
+  @param[in] SystemTable  Pointer to the System Table\r
+\r
+  @retval EFI_SUCCESS           Thread can be successfully created\r
+  @retval EFI_UNSUPPORTED       Cannot find the info to reset system\r
+\r
+**/\r
+EFI_STATUS\r
+EFIAPI\r
+InitializeReset (\r
+  IN EFI_HANDLE        ImageHandle,\r
+  IN EFI_SYSTEM_TABLE  *SystemTable\r
+  )\r
+{\r
+  EFI_STATUS            Status;\r
+  EFI_HANDLE            Handle;\r
+  //\r
+  // Initialize AcpiDescription\r
+  //\r
+  if (!GetAcpiDescription (&mAcpiDescription)) {\r
+    return EFI_UNSUPPORTED;\r
+  }\r
+\r
+  //\r
+  // Make sure the Reset Architectural Protocol is not already installed in the system\r
+  //\r
+  ASSERT_PROTOCOL_ALREADY_INSTALLED (NULL, &gEfiResetArchProtocolGuid);\r
+\r
+  //\r
+  // Hook the runtime service table\r
+  //\r
+  SystemTable->RuntimeServices->ResetSystem = EfiAcpiResetSystem;\r
+\r
+  //\r
+  // Now install the Reset RT AP on a new handle\r
+  //\r
+  Handle = NULL;\r
+  Status = gBS->InstallMultipleProtocolInterfaces (\r
+                  &Handle,\r
+                  &gEfiResetArchProtocolGuid,\r
+                  NULL,\r
+                  NULL\r
+                  );\r
+  ASSERT_EFI_ERROR (Status);\r
+\r
+  return Status;\r
+}\r
index b2657cfb383f410322f47ae160e0cdc094d636ec..9707dee323dd54da590e3b16015a28a9dd3f736c 100644 (file)
@@ -57,6 +57,8 @@
   PeCoffExtraActionLib|MdePkg/Library/BasePeCoffExtraActionLibNull/BasePeCoffExtraActionLibNull.inf\r
   OemHookStatusCodeLib|MdeModulePkg/Library/OemHookStatusCodeLibNull/OemHookStatusCodeLibNull.inf\r
   IoLib|MdePkg/Library/BaseIoLibIntrinsic/BaseIoLibIntrinsic.inf\r
+  PciLib|MdePkg/Library/BasePciLibCf8/BasePciLibCf8.inf\r
+  PciCf8Lib|MdePkg/Library/BasePciCf8Lib/BasePciCf8Lib.inf\r
   TimerLib|DuetPkg/Library/DuetTimerLib/DuetTimerLib.inf\r
   UefiUsbLib|MdePkg/Library/UefiUsbLib/UefiUsbLib.inf\r
   HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf\r
   UefiCpuPkg/CpuIo2Dxe/CpuIo2Dxe.inf\r
   DuetPkg/CpuDxe/Cpu.inf\r
   PcAtChipsetPkg/8259InterruptControllerDxe/8259.inf\r
-  PcAtChipsetPkg/KbcResetDxe/Reset.inf\r
+  DuetPkg/AcpiResetDxe/Reset.inf\r
   DuetPkg/LegacyMetronome/Metronome.inf\r
 \r
   PcAtChipsetPkg/PcatRealTimeClockRuntimeDxe/PcatRealTimeClockRuntimeDxe.inf\r
index 822116c082323fd3fe1d84132ef2e96abd07ffe1..a811bb83a2d0d62aed294f4b138ec5693968446a 100644 (file)
@@ -87,7 +87,7 @@ INF  UefiCpuPkg/CpuIo2Dxe/CpuIo2Dxe.inf
 INF  DuetPkg/CpuDxe/Cpu.inf\r
 \r
 INF  PcAtChipsetPkg/8259InterruptControllerDxe/8259.inf\r
-INF  PcAtChipsetPkg/KbcResetDxe/Reset.inf\r
+INF  DuetPkg/AcpiResetDxe/Reset.inf\r
 INF  DuetPkg/LegacyMetronome/Metronome.inf\r
 INF  PcAtChipsetPkg/8254TimerDxe/8254Timer.inf\r
 INF  PcAtChipsetPkg/PcatRealTimeClockRuntimeDxe/PcatRealTimeClockRuntimeDxe.inf\r
index 823a25ac5a472d9171e4c0088a9a9f7a55bb1e5f..539cf25732e93544c67794e37daa53e5d88fa211 100644 (file)
@@ -1,6 +1,6 @@
 /** @file\r
 \r
-Copyright (c) 2006, Intel Corporation                                                         \r
+Copyright (c) 2006 - 2010, 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
@@ -22,7 +22,6 @@ Revision History:
 #include "HobGeneration.h"\r
 #include "Debug.h"\r
 \r
-#define ACPI_RSD_PTR      0x2052545020445352LL\r
 #define MPS_PTR           SIGNATURE_32('_','M','P','_')\r
 #define SMBIOS_PTR        SIGNATURE_32('_','S','M','_')\r
 \r
@@ -40,7 +39,7 @@ FindAcpiRsdPtr (
   // First Seach 0x0e0000 - 0x0fffff for RSD Ptr\r
   //\r
   for (Address = 0xe0000; Address < 0xfffff; Address += 0x10) {\r
-    if (*(UINT64 *)(Address) == ACPI_RSD_PTR) {\r
+    if (*(UINT64 *)(Address) == EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE) {\r
       return (VOID *)Address;\r
     }\r
   }\r
@@ -51,7 +50,7 @@ FindAcpiRsdPtr (
 \r
   Address = (*(UINT16 *)(UINTN)(EBDA_BASE_ADDRESS)) << 4;\r
   for (Index = 0; Index < 0x400 ; Index += 16) {\r
-    if (*(UINT64 *)(Address + Index) == ACPI_RSD_PTR) {\r
+    if (*(UINT64 *)(Address + Index) == EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE) {\r
       return (VOID *)Address;\r
     }\r
   }\r
@@ -107,69 +106,38 @@ FindMPSPtr (
 }\r
 \r
 #pragma pack(1)\r
-typedef struct {\r
-  UINT8           Signature[8];\r
-  UINT8           Checksum;\r
-  UINT8           OemId[6];\r
-  UINT8           Revision;\r
-  UINT32          RsdtAddress;\r
-  UINT32          Length;\r
-  UINT64          XsdtAddress;\r
-  UINT8           ExtendedChecksum;\r
-  UINT8           Reserved[3];\r
-} RSDP_TABLE;\r
-\r
-typedef struct {\r
-  UINT32          Signature;\r
-  UINT32          Length;\r
-  UINT8           Revision;\r
-  UINT8           Checksum;\r
-  UINT8           OemId[6];\r
-  UINT8           OemTableId[8];\r
-  UINT32          OemRevision;\r
-  UINT8           CreatorId[4];\r
-  UINT32          CreatorRevision;\r
-} DESCRIPTION_HEADER;\r
 \r
 typedef struct {\r
-  DESCRIPTION_HEADER    Header;\r
-  UINT32                Entry;\r
+  EFI_ACPI_DESCRIPTION_HEADER  Header;\r
+  UINT32                       Entry;\r
 } RSDT_TABLE;\r
 \r
 typedef struct {\r
-  DESCRIPTION_HEADER    Header;\r
-  UINT64                Entry;\r
+  EFI_ACPI_DESCRIPTION_HEADER  Header;\r
+  UINT64                       Entry;\r
 } XSDT_TABLE;\r
 \r
-typedef struct {\r
-  UINT8                 Address_Space_ID;\r
-  UINT8                 Register_Bit_Width;\r
-  UINT8                 Register_Bit_Offset;\r
-  UINT8                 Access_Size;\r
-  UINT64                Address;\r
-} GADDRESS_STRUCTURE;\r
-\r
 #pragma pack()\r
 \r
 VOID\r
 ScanTableInRSDT (\r
-  RSDT_TABLE            *Rsdt,\r
-  UINT32                Signature,\r
-  DESCRIPTION_HEADER    **FoundTable\r
+  RSDT_TABLE                   *Rsdt,\r
+  UINT32                       Signature,\r
+  EFI_ACPI_DESCRIPTION_HEADER  **FoundTable\r
   )\r
 {\r
-  UINTN                     Index;\r
-  UINT32                    EntryCount;\r
-  UINT32                    *EntryPtr;\r
-  DESCRIPTION_HEADER        *Table;\r
+  UINTN                         Index;\r
+  UINT32                        EntryCount;\r
+  UINT32                        *EntryPtr;\r
+  EFI_ACPI_DESCRIPTION_HEADER   *Table;\r
   \r
   *FoundTable = NULL;\r
   \r
-  EntryCount = (Rsdt->Header.Length - sizeof (DESCRIPTION_HEADER)) / sizeof(UINT32);\r
+  EntryCount = (Rsdt->Header.Length - sizeof (EFI_ACPI_DESCRIPTION_HEADER)) / sizeof(UINT32);\r
   \r
   EntryPtr = &Rsdt->Entry;\r
   for (Index = 0; Index < EntryCount; Index ++, EntryPtr ++) {\r
-    Table = (DESCRIPTION_HEADER*)((UINTN)(*EntryPtr));\r
+    Table = (EFI_ACPI_DESCRIPTION_HEADER*)((UINTN)(*EntryPtr));\r
     if (Table->Signature == Signature) {\r
       *FoundTable = Table;\r
       break;\r
@@ -181,26 +149,25 @@ ScanTableInRSDT (
 \r
 VOID\r
 ScanTableInXSDT (\r
-  XSDT_TABLE            *Xsdt,\r
-  UINT32                Signature,\r
-  DESCRIPTION_HEADER    **FoundTable\r
+  XSDT_TABLE                   *Xsdt,\r
+  UINT32                       Signature,\r
+  EFI_ACPI_DESCRIPTION_HEADER  **FoundTable\r
   )\r
 {\r
-  UINTN         Index;\r
-  UINT32        EntryCount;\r
-  UINT64        EntryPtr;\r
-  UINTN         BasePtr;\r
-  \r
-  DESCRIPTION_HEADER    *Table;\r
+  UINTN                        Index;\r
+  UINT32                       EntryCount;\r
+  UINT64                       EntryPtr;\r
+  UINTN                        BasePtr;\r
+  EFI_ACPI_DESCRIPTION_HEADER  *Table;\r
   \r
   *FoundTable = NULL;\r
   \r
-  EntryCount = (Xsdt->Header.Length - sizeof (DESCRIPTION_HEADER)) / sizeof(UINT64);\r
+  EntryCount = (Xsdt->Header.Length - sizeof (EFI_ACPI_DESCRIPTION_HEADER)) / sizeof(UINT64);\r
   \r
   BasePtr = (UINTN)(&(Xsdt->Entry));\r
   for (Index = 0; Index < EntryCount; Index ++) {\r
     CopyMem (&EntryPtr, (VOID *)(BasePtr + Index * sizeof(UINT64)), sizeof(UINT64));\r
-    Table = (DESCRIPTION_HEADER*)((UINTN)(EntryPtr));\r
+    Table = (EFI_ACPI_DESCRIPTION_HEADER*)((UINTN)(EntryPtr));\r
     if (Table->Signature == Signature) {\r
       *FoundTable = Table;\r
       break;\r
@@ -216,10 +183,10 @@ FindAcpiPtr (
   UINT32           Signature\r
   )\r
 {\r
-  DESCRIPTION_HEADER    *AcpiTable;\r
-  RSDP_TABLE            *Rsdp;\r
-  RSDT_TABLE            *Rsdt;\r
-  XSDT_TABLE            *Xsdt;\r
+  EFI_ACPI_DESCRIPTION_HEADER                    *AcpiTable;\r
+  EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER   *Rsdp;\r
+  RSDT_TABLE                                     *Rsdt;\r
+  XSDT_TABLE                                     *Xsdt;\r
  \r
   AcpiTable = NULL;\r
 \r
@@ -227,7 +194,7 @@ FindAcpiPtr (
   // Check ACPI2.0 table\r
   //\r
   if ((int)Hob->Acpi20.Table != -1) {\r
-    Rsdp = (RSDP_TABLE *)(UINTN)Hob->Acpi20.Table;\r
+    Rsdp = (EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER *)(UINTN)Hob->Acpi20.Table;\r
     Rsdt = (RSDT_TABLE *)(UINTN)Rsdp->RsdtAddress;\r
     Xsdt = NULL;\r
     if ((Rsdp->Revision >= 2) && (Rsdp->XsdtAddress < (UINT64)(UINTN)-1)) {\r
@@ -251,7 +218,7 @@ FindAcpiPtr (
   // Check ACPI1.0 table\r
   //\r
   if ((AcpiTable == NULL) && ((int)Hob->Acpi.Table != -1)) {\r
-    Rsdp = (RSDP_TABLE *)(UINTN)Hob->Acpi.Table;\r
+    Rsdp = (EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER *)(UINTN)Hob->Acpi.Table;\r
     Rsdt = (RSDT_TABLE *)(UINTN)Rsdp->RsdtAddress;\r
     //\r
     // Check Rsdt\r
@@ -265,8 +232,6 @@ FindAcpiPtr (
 }\r
 \r
 #pragma pack(1)\r
-//#define MCFG_SIGNATURE  0x4746434D\r
-#define MCFG_SIGNATURE SIGNATURE_32 ('M', 'C', 'F', 'G')\r
 typedef struct {\r
   UINT64  BaseAddress;\r
   UINT16  PciSegmentGroupNumber;\r
@@ -274,63 +239,6 @@ typedef struct {
   UINT8   EndBusNumber;\r
   UINT32  Reserved;\r
 } MCFG_STRUCTURE;\r
-\r
-#define FADT_SIGNATURE SIGNATURE_32 ('F', 'A', 'C', 'P')\r
-typedef struct {\r
-  DESCRIPTION_HEADER    Header;\r
-  UINT32                FIRMWARE_CTRL;\r
-  UINT32                DSDT;\r
-  UINT8                 INT_MODEL;\r
-  UINT8                 Preferred_PM_Profile;\r
-  UINT16                SCI_INIT;\r
-  UINT32                SMI_CMD;\r
-  UINT8                 ACPI_ENABLE;\r
-  UINT8                 ACPI_DISABLE;\r
-  UINT8                 S4BIOS_REQ;\r
-  UINT8                 PSTATE_CNT;\r
-  UINT32                PM1a_EVT_BLK;\r
-  UINT32                PM1b_EVT_BLK;\r
-  UINT32                PM1a_CNT_BLK;\r
-  UINT32                PM1b_CNT_BLK;\r
-  UINT32                PM2_CNT_BLK;\r
-  UINT32                PM_TMR_BLK;\r
-  UINT32                GPE0_BLK;\r
-  UINT32                GPE1_BLK;\r
-  UINT8                 PM1_EVT_LEN;\r
-  UINT8                 PM1_CNT_LEN;\r
-  UINT8                 PM2_CNT_LEN;\r
-  UINT8                 PM_TMR_LEN;\r
-  UINT8                 GPE0_BLK_LEN;\r
-  UINT8                 GPE1_BLK_LEN;\r
-  UINT8                 GPE1_BASE;\r
-  UINT8                 CST_CNT;\r
-  UINT16                P_LVL2_LAT;\r
-  UINT16                P_LVL3_LAT;\r
-  UINT16                FLUSH_SIZE;\r
-  UINT16                FLUSH_STRIDE;\r
-  UINT8                 DUTY_OFFSET;\r
-  UINT8                 DUTY_WIDTH;\r
-  UINT8                 DAY_ALARM;\r
-  UINT8                 MON_ALARM;\r
-  UINT8                 CENTRY;\r
-  UINT16                IAPC_BOOT_ARCH;\r
-  UINT8                 Reserved_111;\r
-  UINT32                Flags;\r
-  GADDRESS_STRUCTURE    RESET_REG;\r
-  UINT8                 RESET_VALUE;\r
-  UINT8                 Reserved_129[3];\r
-  UINT64                X_FIRMWARE_CTRL;\r
-  UINT64                X_DSDT;\r
-  GADDRESS_STRUCTURE    X_PM1a_EVT_BLK;\r
-  GADDRESS_STRUCTURE    X_PM1b_EVT_BLK;\r
-  GADDRESS_STRUCTURE    X_PM1a_CNT_BLK;\r
-  GADDRESS_STRUCTURE    X_PM1b_CNT_BLK;\r
-  GADDRESS_STRUCTURE    X_PM2_CNT_BLK;\r
-  GADDRESS_STRUCTURE    X_PM_TMR_BLK;\r
-  GADDRESS_STRUCTURE    X_GPE0_BLK;\r
-  GADDRESS_STRUCTURE    X_GPE1_BLK;\r
-} FADT_TABLE;\r
-\r
 #pragma pack()\r
 \r
 VOID\r
@@ -338,18 +246,18 @@ PrepareMcfgTable (
   IN HOB_TEMPLATE  *Hob\r
   )\r
 {\r
-  DESCRIPTION_HEADER    *McfgTable;\r
-  MCFG_STRUCTURE        *Mcfg;\r
-  UINTN                 McfgCount;\r
-  UINTN                 Index;\r
+  EFI_ACPI_DESCRIPTION_HEADER  *McfgTable;\r
+  MCFG_STRUCTURE               *Mcfg;\r
+  UINTN                        McfgCount;\r
+  UINTN                        Index;\r
 \r
-  McfgTable = FindAcpiPtr (Hob, MCFG_SIGNATURE);\r
+  McfgTable = FindAcpiPtr (Hob, EFI_ACPI_3_0_PCI_EXPRESS_MEMORY_MAPPED_CONFIGURATION_SPACE_BASE_ADDRESS_DESCRIPTION_TABLE_SIGNATURE);\r
   if (McfgTable == NULL) {\r
     return ;\r
   }\r
 \r
-  Mcfg = (MCFG_STRUCTURE *)((UINTN)McfgTable + sizeof(DESCRIPTION_HEADER) + sizeof(UINT64));\r
-  McfgCount = (McfgTable->Length - sizeof(DESCRIPTION_HEADER) - sizeof(UINT64)) / sizeof(MCFG_STRUCTURE);\r
+  Mcfg = (MCFG_STRUCTURE *)((UINTN)McfgTable + sizeof(EFI_ACPI_DESCRIPTION_HEADER) + sizeof(UINT64));\r
+  McfgCount = (McfgTable->Length - sizeof(EFI_ACPI_DESCRIPTION_HEADER) - sizeof(UINT64)) / sizeof(MCFG_STRUCTURE);\r
 \r
   //\r
   // Fill PciExpress info on Hob\r
@@ -370,10 +278,10 @@ PrepareFadtTable (
   IN HOB_TEMPLATE  *Hob\r
   )\r
 {\r
-  FADT_TABLE            *Fadt;\r
-  EFI_ACPI_DESCRIPTION  *AcpiDescription;\r
+  EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE   *Fadt;\r
+  EFI_ACPI_DESCRIPTION                        *AcpiDescription;\r
 \r
-  Fadt = FindAcpiPtr (Hob, FADT_SIGNATURE);\r
+  Fadt = FindAcpiPtr (Hob, EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE);\r
   if (Fadt == NULL) {\r
     return ;\r
   }\r
@@ -383,24 +291,31 @@ PrepareFadtTable (
   // Fill AcpiDescription according to FADT\r
   // Currently, only for PM_TMR\r
   //\r
-  AcpiDescription->PM_TMR_LEN = Fadt->PM_TMR_LEN;\r
+  AcpiDescription->PM_TMR_LEN = Fadt->PmTmrLen;\r
   AcpiDescription->TMR_VAL_EXT = (UINT8)((Fadt->Flags & 0x100) != 0);\r
-  if ((Fadt->Header.Revision >= 3) && (Fadt->Header.Length >= sizeof(FADT_TABLE))) {\r
\r
+  //\r
+  // For fields not included in ACPI 1.0 spec, we get the value based on table length\r
+  //\r
+  if (Fadt->Header.Length >= OFFSET_OF (EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE, XPmTmrBlk) + sizeof (Fadt->XPmTmrBlk)) {\r
     CopyMem (\r
       &AcpiDescription->PM_TMR_BLK,\r
-      &Fadt->X_PM_TMR_BLK,\r
-      sizeof(GADDRESS_STRUCTURE)\r
+      &Fadt->XPmTmrBlk,\r
+      sizeof(EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE)\r
       );\r
+  }\r
+  if (Fadt->Header.Length >= OFFSET_OF (EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE, ResetValue) + sizeof (Fadt->ResetValue)) {\r
     CopyMem (\r
       &AcpiDescription->RESET_REG,\r
-      &Fadt->RESET_REG,\r
-      sizeof(GADDRESS_STRUCTURE)\r
+      &Fadt->ResetReg,\r
+      sizeof(EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE)\r
       );\r
-    AcpiDescription->RESET_VALUE = Fadt->RESET_VALUE;\r
+    AcpiDescription->RESET_VALUE = Fadt->ResetValue;\r
   }\r
+\r
   if (AcpiDescription->PM_TMR_BLK.Address == 0) {\r
-    AcpiDescription->PM_TMR_BLK.Address          = Fadt->PM_TMR_BLK;\r
-    AcpiDescription->PM_TMR_BLK.AddressSpaceId   = ACPI_ADDRESS_ID_IO;\r
+    AcpiDescription->PM_TMR_BLK.Address          = Fadt->PmTmrBlk;\r
+    AcpiDescription->PM_TMR_BLK.AddressSpaceId   = EFI_ACPI_3_0_SYSTEM_IO;\r
     AcpiDescription->PM_TMR_BLK.RegisterBitWidth = (UINT8) ((AcpiDescription->TMR_VAL_EXT == 0) ? 24 : 32);\r
   }\r
 \r
index d8095b896b22afea4bcef96f915d0d17a621872b..8f0becd7cff14a6381ab5814fa9dc8280ec19cb2 100644 (file)
@@ -1,6 +1,6 @@
 /** @file\r
 \r
-Copyright (c) 2006 - 2007, Intel Corporation                                                         \r
+Copyright (c) 2006 - 2010, 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
@@ -23,31 +23,13 @@ Abstract:
 #ifndef _EFI_ACPI_DESCRIPTION_H_\r
 #define _EFI_ACPI_DESCRIPTION_H_\r
 \r
+#include <IndustryStandard/Acpi.h>\r
+\r
 #define EFI_ACPI_DESCRIPTION_GUID \\r
   { \\r
   0x3c699197, 0x93c, 0x4c69, {0xb0, 0x6b, 0x12, 0x8a, 0xe3, 0x48, 0x1d, 0xc9} \\r
   }\r
 \r
-typedef struct {\r
-  UINT8   AddressSpaceId;\r
-  UINT8   RegisterBitWidth;\r
-  UINT8   RegisterBitOffset;\r
-  UINT8   AccessSize;\r
-  UINT64  Address;\r
-} EFI_ACPI_GENERIC_ADDRESS_STRUCTURE;\r
-\r
-#define ACPI_ADDRESS_ID_MEMORY    0\r
-#define ACPI_ADDRESS_ID_IO        1\r
-#define ACPI_ADDRESS_ID_PCI       2\r
-#define ACPI_ADDRESS_ID_EC        3\r
-#define ACPI_ADDRESS_ID_SMBUS     4\r
-\r
-#define ACPI_ADDRESS_ACCESS_ANY   0\r
-#define ACPI_ADDRESS_ACCESS_BYTE  1\r
-#define ACPI_ADDRESS_ACCESS_WORD  2\r
-#define ACPI_ADDRESS_ACCESS_DWORD 3\r
-#define ACPI_ADDRESS_ACCESS_QWORD 4\r
-\r
 //\r
 // Following structure defines ACPI Description information.\r
 // This information is platform specific, may be consumed by DXE generic driver.\r
@@ -57,7 +39,7 @@ typedef struct _EFI_ACPI_DESCRIPTION {
   //\r
   // For Timer\r
   //\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM_TMR_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM_TMR_BLK;\r
   UINT8                                    PM_TMR_LEN;\r
   UINT8                                    TMR_VAL_EXT;\r
 \r
@@ -71,17 +53,17 @@ typedef struct _EFI_ACPI_DESCRIPTION {
   //\r
   // For Reset\r
   //\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       RESET_REG;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   RESET_REG;\r
   UINT8                                    RESET_VALUE;\r
 \r
   //\r
   // For Shutdown\r
   //\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM1a_EVT_BLK;\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM1b_EVT_BLK;\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM1a_CNT_BLK;\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM1b_CNT_BLK;\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       PM2_CNT_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM1a_EVT_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM1b_EVT_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM1a_CNT_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM1b_CNT_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   PM2_CNT_BLK;\r
   UINT8                                    PM1_EVT_LEN;\r
   UINT8                                    PM1_CNT_LEN;\r
   UINT8                                    PM2_CNT_LEN;\r
@@ -103,8 +85,8 @@ typedef struct _EFI_ACPI_DESCRIPTION {
   //\r
   // GPE\r
   //\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       GPE0_BLK;\r
-  EFI_ACPI_GENERIC_ADDRESS_STRUCTURE       GPE1_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   GPE0_BLK;\r
+  EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE   GPE1_BLK;\r
   UINT8                                    GPE0_BLK_LEN;\r
   UINT8                                    GPE1_BLK_LEN;\r
   UINT8                                    GPE1_BASE;\r