DSDT supported !

This commit is contained in:
Adrien Bourmault 2020-02-09 16:52:41 +01:00
parent 821019e0d8
commit 25b913d140
3 changed files with 134 additions and 21 deletions

View File

@ -45,7 +45,7 @@ struct RSDPLegacy {
//
// ACPI 2.0 descriptor
//
struct RSDPDescriptor {
struct RSDPDescriptor_t {
// RSDT ACPI 1.0 and above
struct RSDPLegacy legacy;
@ -59,7 +59,7 @@ struct RSDPDescriptor {
//
// ACPI System Description Table
//
struct SDTHeader {
struct SDTHeader_t {
char signature[4];
uint length;
uchar revision;
@ -69,7 +69,19 @@ struct SDTHeader {
uint OEMRevision;
uint creatorID;
uint creatorRevision;
uint sdtTablePtr;
uint sdtEntry;
};
//
// GAS type, used by ACPI tables to inform about registers
//
struct GenericAddressStructure
{
uchar addressSpace;
uchar width;
uchar offset;
uchar accessSize;
ulong address;
};
//
@ -103,13 +115,89 @@ enum {
#define N_SDT_TYPES 23
//----------------------------------------------------------------------------//
// FADT related
//
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;
};
//----------------------------------------------------------------------------//
void IoInitAcpi(void);
SDTHeader *IoGetAcpiTable(ulong id);
SDTHeader_t *IoGetAcpiTable(ulong id);
//----------------------------------------------------------------------------//

View File

@ -56,8 +56,9 @@ typedef struct IdtPtr_t IdtPtr_t;
typedef struct ISRList_t ISRList_t;
typedef struct ISRFrame_t ISRFrame_t;
typedef struct RSDPDescriptor RSDPDescriptor;
typedef struct SDTHeader SDTHeader;
typedef struct RSDPDescriptor_t RSDPDescriptor_t;
typedef struct SDTHeader_t SDTHeader_t;
typedef struct FADT_t FADT_t;
typedef struct MemoryMap_t MemoryMap_t;
typedef struct MapEntry_t MapEntry_t;

View File

@ -61,7 +61,7 @@ static char *SDTChar[N_SDT_TYPES] = {
};
// ACPI Tables Directory
static SDTHeader *SDTDirectory[N_SDT_TYPES] = {0};
static SDTHeader_t *SDTDirectory[N_SDT_TYPES] = {0};
//
// Returns the checksum of the given structure
@ -81,7 +81,7 @@ static char DoChecksum(const void *ptr, const size_t size,
//
// Returns the address of the RSDP
//
static inline RSDPDescriptor *IoFindRSDP()
static inline RSDPDescriptor_t *IoFindRSDP()
{
char *rsdp = NULL;
@ -92,7 +92,7 @@ static inline RSDPDescriptor *IoFindRSDP()
rsdp++) {
if (!strncmp(rsdp, "RSD PTR", 6)) {
return (RSDPDescriptor *)rsdp;
return (RSDPDescriptor_t *)rsdp;
}
}
@ -102,7 +102,7 @@ static inline RSDPDescriptor *IoFindRSDP()
rsdp++) {
if (!strncmp(rsdp, "RSD PTR", 6)) {
return (RSDPDescriptor *)rsdp;
return (RSDPDescriptor_t *)rsdp;
}
}
@ -116,12 +116,12 @@ static inline void IoInitRSDP(void)
{
char checksum = 1;
RSDPDescriptor *rsdp = IoFindRSDP();
RSDPDescriptor_t *rsdp = IoFindRSDP();
if (!rsdp)
KeStartPanic("ACPI RSDP not found in memory");
// Checksum calculation
checksum = DoChecksum(rsdp, (size_t)sizeof(RSDPDescriptor),
checksum = DoChecksum(rsdp, (size_t)sizeof(RSDPDescriptor_t),
(size_t)sizeof(struct RSDPLegacy),
!rsdp->legacy.revision
);
@ -152,7 +152,7 @@ static inline void IoInitRXSDT(void)
{
char checksum = 1;
SDTHeader *rxsdt = SDTDirectory[SDT_RSDT];
SDTHeader_t *rxsdt = SDTDirectory[SDT_RSDT];
if (IoACPIVersion == 2) {
rxsdt = SDTDirectory[SDT_XSDT];
@ -189,8 +189,8 @@ static inline void IoInitRXSDT(void)
//
static inline void IoSearchAcpiTables(void)
{
SDTHeader *xrsdt = SDTDirectory[SDT_RSDT];
SDTHeader *table = NULL;
SDTHeader_t *xrsdt = SDTDirectory[SDT_RSDT];
SDTHeader_t *table = NULL;
uint *curInt = NULL;
ulong *curLong = NULL;
register char checksum;
@ -205,15 +205,16 @@ static inline void IoSearchAcpiTables(void)
DebugLog("ACPI detected %d entries\n", entries);
curInt = (uint*)&(xrsdt->sdtTablePtr);
curLong = (ulong*)&(xrsdt->sdtTablePtr);
curInt = (uint*)&(xrsdt->sdtEntry);
curLong = (ulong*)&(xrsdt->sdtEntry);
// Parsing R/XSDT
for (int i = 0; i < entries; i++) {
if (IoACPIVersion == 1)
table = (SDTHeader *)(ulong)curInt[i];
table = (SDTHeader_t *)(ulong)curInt[i];
else
table = (SDTHeader *)(ulong)curLong[i];
table = (SDTHeader_t *)(ulong)curLong[i];
//KernLog("\tACPI RSDT[%d] %p\n", i, table);
if (MmIsBusyZone(table)) {
@ -233,8 +234,30 @@ static inline void IoSearchAcpiTables(void)
}
}
}
}
// Parsing FADT
FADT_t *fadt = (FADT_t *)IoGetAcpiTable(SDT_FADT);
SDTHeader_t *dsdt;
if (IoACPIVersion == 1) {
dsdt = (SDTHeader_t *)(ulong)fadt->dsdtAddress;
} else {
dsdt = (SDTHeader_t *)(ulong)fadt->xDsdtAddress;
}
checksum = DoChecksum(dsdt, (size_t)dsdt->length, 0, 0);
if (!checksum) {
if (!strncmp(dsdt->signature, SDTChar[SDT_DSDT], 3)) {
DebugLog("ACPI System Table %s (OEM %s) length %d [%p]\n",
SDTChar[SDT_DSDT],
dsdt->OEMID,
dsdt->length,
dsdt
);
SDTDirectory[SDT_DSDT] = dsdt;
}
}
}
// -------------------------------------------------------------------------- //
@ -275,13 +298,14 @@ void IoInitAcpi(void)
IoSearchAcpiTables();
}
// -------------------------------------------------------------------------- //
//
// Returns the addr of the submitted SDT
//
// Arg must be a member of the enum in acpi.h
//
SDTHeader *IoGetAcpiTable(ulong id)
SDTHeader_t *IoGetAcpiTable(ulong id)
{
return SDTDirectory[id];
}