os-k/include/kernel/io/acpi.h

223 lines
5.8 KiB
C
Raw Normal View History

2020-02-02 13:33:57 +01:00
//----------------------------------------------------------------------------//
2020-09-27 17:33:48 +02:00
// OS on Kaleid //
2020-02-02 13:33:57 +01:00
// //
// Desc: ACPI, Hardware detection related //
// //
// //
2021-02-18 19:54:35 +01:00
// Copyright © 2018-2021 The OS/K Team //
2020-02-02 13:33:57 +01:00
// //
// This file is part of OS/K. //
// //
// OS/K is free software: you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation, either version 3 of the License, or //
// any later version. //
// //
// OS/K is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY//without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with OS/K. If not, see <https://www.gnu.org/licenses/>. //
//----------------------------------------------------------------------------//
#ifndef _KERNEL_H
#include <kernel.h>
#endif
#ifndef _IO_ACPI_H
#define _IO_ACPI_H
//----------------------------------------------------------------------------//
2020-02-03 11:58:34 +01:00
//
2020-02-03 15:34:20 +01:00
// ACPI 1.0 descriptor
2020-02-03 11:58:34 +01:00
//
2020-02-03 15:34:20 +01:00
struct RSDPLegacy {
2020-02-03 11:58:34 +01:00
char signature[8];
uchar checksum;
char OEMID[6];
uchar revision;
uint rsdtAddress;
2020-02-03 15:34:20 +01:00
} __attribute__ ((packed));
//
// ACPI 2.0 descriptor
//
2020-02-09 16:52:41 +01:00
struct RSDPDescriptor_t {
2020-02-03 15:34:20 +01:00
// RSDT ACPI 1.0 and above
struct RSDPLegacy legacy;
// RSDT ACPI 2.0
2020-02-03 11:58:34 +01:00
uint length;
ulong xsdtAddress;
uchar extendedChecksum;
uchar reserved[3];
} __attribute__ ((packed));
2020-02-03 15:34:20 +01:00
//
// ACPI System Description Table
//
2020-02-09 16:52:41 +01:00
struct SDTHeader_t {
2020-02-03 15:34:20 +01:00
char signature[4];
uint length;
uchar revision;
uchar checksum;
char OEMID[6];
char OEMTableID[8];
uint OEMRevision;
uint creatorID;
uint creatorRevision;
2020-02-09 16:52:41 +01:00
uint sdtEntry;
2020-02-13 13:40:07 +01:00
} __attribute__ ((packed));
2020-02-09 16:52:41 +01:00
//
// GAS type, used by ACPI tables to inform about registers
//
struct GenericAddressStructure
{
uchar addressSpace;
uchar width;
uchar offset;
uchar accessSize;
ulong address;
2020-02-13 13:40:07 +01:00
} __attribute__ ((packed));
2020-02-03 15:34:20 +01:00
//
// ACPI table types id
//
enum {
SDT_MADT,
SDT_BERT,
SDT_CPEP,
SDT_DSDT,
SDT_ECDT,
SDT_EINJ,
SDT_ERST,
SDT_FADT,
SDT_FACS,
SDT_HEST,
SDT_MSCT,
SDT_MPST,
SDT_OEMx,
SDT_PMTT,
SDT_PSDT,
SDT_RASF,
SDT_RSDT,
SDT_SBST,
SDT_SLIT,
SDT_SRAT,
SDT_SSDT,
SDT_XSDT,
2020-02-09 20:55:13 +01:00
SDT_HEPT,
SDT_MCFG
};
2020-02-09 20:55:13 +01:00
#define N_SDT_TYPES 24
2020-02-09 16:52:41 +01:00
//----------------------------------------------------------------------------//
// FADT related
//
2020-02-09 16:52:41 +01:00
struct FADT_t
{
char signature[4];
uint length;
uchar revision;
uchar checksum;
char OEMID[6];
char OEMTableID[8];
uint OEMRevision;
uint creatorID;
uint creatorRevision;
uint firmwareCtrlAddress;
uint dsdtAddress;
uchar reserved; // legacy
uchar preferredPowerManagementProfile;
ushort SCIInterrupt;
uint SMICommandPort;
uchar acpiEnable;
uchar acpiDisable;
uchar S4BIOSREQ;
uchar PSTATEControl;
uint PM1aEventBlock;
uint PM1bEventBlock;
uint PM1aControlBlock;
uint PM1bControlBlock;
uint PM2ControlBlock;
uint PMTimerBlock;
uint GPE0Block;
uint GPE1Block;
uchar PM1EventLength;
uchar PM1ControlLength;
uchar PM2ControlLength;
uchar PMTimerLength;
uchar GPE0Length;
uchar GPE1Length;
uchar GPE1Base;
uchar CStateControl;
ushort worstC2Latency;
ushort worstC3Latency;
ushort flushSize;
ushort flushStride;
uchar dutyOffset;
uchar dutyWidth;
uchar dayAlarm;
uchar monthAlarm;
uchar century;
// reserved in ACPI1, available since ACPI2
ushort bootArchitectureFlags;
uchar reserved2; // legacy
uint flags;
struct GenericAddressStructure resetReg;
uchar resetValue;
uchar reserved3[3];
// 64bit pointers, available since ACPI2
ulong xFirmwareControlAddress;
ulong xDsdtAddress;
struct GenericAddressStructure xPM1aEventBlock;
struct GenericAddressStructure xPM1bEventBlock;
struct GenericAddressStructure xPM1aControlBlock;
struct GenericAddressStructure xPM1bControlBlock;
struct GenericAddressStructure xPM2ControlBlock;
struct GenericAddressStructure xPMTimerBlock;
struct GenericAddressStructure xGPE0Block;
struct GenericAddressStructure xGPE1Block;
2020-02-13 13:40:07 +01:00
} __attribute__ ((packed));
2020-02-03 11:58:34 +01:00
//----------------------------------------------------------------------------//
2020-02-12 13:15:10 +01:00
struct MCFG_t {
char signature[4];
uint length;
uchar revision;
uchar checksum;
char OEMID[6];
char OEMTableID[8];
uint OEMRevision;
uint creatorID;
uint creatorRevision;
ulong reserved;
2020-02-11 23:47:02 +01:00
void* pciConfigBaseAddress;
2020-02-12 13:15:10 +01:00
} __attribute__ ((packed));
//----------------------------------------------------------------------------//
2020-02-03 17:43:05 +01:00
void IoInitAcpi(void);
2020-02-02 13:33:57 +01:00
2020-02-09 16:52:41 +01:00
SDTHeader_t *IoGetAcpiTable(ulong id);
2020-02-02 13:33:57 +01:00
//----------------------------------------------------------------------------//
#endif