2008-07-25 14:21:57 +02:00
|
|
|
/** @file
|
2008-10-23 09:06:27 +02:00
|
|
|
ACPI high precision event timer table definition, at www.intel.com
|
2007-07-17 07:36:16 +02:00
|
|
|
Specification name is IA-PC HPET (High Precision Event Timers) Specification.
|
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-07-17 07:36:16 +02:00
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _HIGH_PRECISION_EVENT_TIMER_TABLE_H_
|
|
|
|
#define _HIGH_PRECISION_EVENT_TIMER_TABLE_H_
|
|
|
|
|
2007-07-19 07:47:35 +02:00
|
|
|
#include <IndustryStandard/Acpi.h>
|
|
|
|
|
2007-07-17 07:36:16 +02:00
|
|
|
//
|
|
|
|
// Ensure proper structure formats
|
|
|
|
//
|
|
|
|
#pragma pack(1)
|
2008-08-14 05:21:03 +02:00
|
|
|
|
2018-05-17 14:41:38 +02:00
|
|
|
///
|
|
|
|
/// HPET Event Timer Block ID described in IA-PC HPET Specification, 3.2.4.
|
|
|
|
///
|
|
|
|
typedef union {
|
|
|
|
struct {
|
|
|
|
UINT32 Revision : 8;
|
|
|
|
UINT32 NumberOfTimers : 5;
|
|
|
|
UINT32 CounterSize : 1;
|
|
|
|
UINT32 Reserved : 1;
|
|
|
|
UINT32 LegacyRoute : 1;
|
|
|
|
UINT32 VendorId : 16;
|
|
|
|
} Bits;
|
|
|
|
UINT32 Uint32;
|
|
|
|
} EFI_ACPI_HIGH_PRECISION_EVENT_TIMER_BLOCK_ID;
|
|
|
|
|
|
|
|
|
2008-08-14 05:21:03 +02:00
|
|
|
///
|
|
|
|
/// High Precision Event Timer Table header definition.
|
|
|
|
///
|
2007-07-17 07:36:16 +02:00
|
|
|
typedef struct {
|
|
|
|
EFI_ACPI_DESCRIPTION_HEADER Header;
|
|
|
|
UINT32 EventTimerBlockId;
|
|
|
|
EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE BaseAddressLower32Bit;
|
|
|
|
UINT8 HpetNumber;
|
|
|
|
UINT16 MainCounterMinimumClockTickInPeriodicMode;
|
|
|
|
UINT8 PageProtectionAndOemAttribute;
|
|
|
|
} EFI_ACPI_HIGH_PRECISION_EVENT_TIMER_TABLE_HEADER;
|
|
|
|
|
2008-08-14 05:21:03 +02:00
|
|
|
///
|
|
|
|
/// HPET Revision (defined in spec)
|
|
|
|
///
|
2007-07-17 07:36:16 +02:00
|
|
|
#define EFI_ACPI_HIGH_PRECISION_EVENT_TIMER_TABLE_REVISION 0x01
|
|
|
|
|
|
|
|
//
|
|
|
|
// Page protection setting
|
|
|
|
// Values 3 through 15 are reserved for use by the specification
|
|
|
|
//
|
|
|
|
#define EFI_ACPI_NO_PAGE_PROTECTION 0
|
|
|
|
#define EFI_ACPI_4KB_PAGE_PROTECTION 1
|
|
|
|
#define EFI_ACPI_64KB_PAGE_PROTECTION 2
|
|
|
|
|
2008-11-11 23:21:08 +01:00
|
|
|
#pragma pack()
|
|
|
|
|
2007-07-17 07:36:16 +02:00
|
|
|
#endif
|