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
|
|
|
|
2020-02-08 11:53: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-08 11:53:20 +01:00
|
|
|
};
|
|
|
|
|
2020-02-09 20:55:13 +01:00
|
|
|
#define N_SDT_TYPES 24
|
2020-02-08 11:53:20 +01:00
|
|
|
|
2020-02-09 16:52:41 +01:00
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
// FADT related
|
|
|
|
//
|
2020-02-08 11:53:20 +01:00
|
|
|
|
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-08 11:53:20 +01:00
|
|
|
|
2020-02-03 11:58:34 +01:00
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
|
2020-02-12 13:15:10 +01:00
|
|
|
struct MCFG_t {
|
2020-02-10 02:26:55 +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-10 02:36:42 +01:00
|
|
|
ulong reserved;
|
2020-02-10 02:26:55 +01:00
|
|
|
|
2020-02-11 23:47:02 +01:00
|
|
|
void* pciConfigBaseAddress;
|
2020-02-12 13:15:10 +01:00
|
|
|
} __attribute__ ((packed));
|
2020-02-10 02:26:55 +01:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
|
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-08 11:53:20 +01:00
|
|
|
|
2020-02-02 13:33:57 +01:00
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
|
|
|
|
#endif
|