summaryrefslogtreecommitdiffhomepage
path: root/dev/modules/HPET/Defines.h
blob: 36df3ebdba4a175ce84707ffe935de89caf39df1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* -------------------------------------------

	Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved.

	File: HPET.h
	Purpose: HPET builtin.

	Revision History:

------------------------------------------- */

#pragma once

#include <NewKit/Defines.h>
#include <modules/ACPI/ACPI.h>

namespace NeOS
{
	struct PACKED HPETAddressStructure final
	{
		NeOS::UInt8	 AddressSpaceId; // 0 - system memory, 1 - system I/O
		NeOS::UInt8	 RegisterBitWidth;
		NeOS::UInt8	 RegisterBitOffset;
		NeOS::UInt8	 Reserved;
		NeOS::UInt64 Address;
	};

	struct PACKED HPETHeader final : public SDT
	{
		NeOS::UInt8			 HardwareRevId;
		NeOS::UInt8			 ComparatorCount : 5;
		NeOS::UInt8			 CounterSize : 1;
		NeOS::UInt8			 Reserved : 1;
		NeOS::UInt8			 LegacyReplacement : 1;
		NeOS::UInt16		 PciVendorId;
		HPETAddressStructure Address;
		NeOS::UInt8			 HpetNumber;
		NeOS::UInt16		 MinimumTick;
		NeOS::UInt8			 PageProtection;
	};

} // namespace NeOS