acpi: cleanup smbios lookup to use actual smbios structs
Signed-off-by: Andy-Python-Programmer <andypythonappdeveloper@gmail.com>
This commit is contained in:
parent
7025da44e3
commit
6a0d3ea9fe
@ -54,19 +54,23 @@ void acpi_get_smbios(void **smbios32, void **smbios64) {
|
|||||||
*smbios64 = NULL;
|
*smbios64 = NULL;
|
||||||
|
|
||||||
for (size_t i = 0xf0000; i < 0x100000; i += 16) {
|
for (size_t i = 0xf0000; i < 0x100000; i += 16) {
|
||||||
if (!memcmp((char *)i, "_SM_", 4)
|
struct smbios_entry_point_32 *ptr = (struct smbios_entry_point_32 *)i;
|
||||||
&& !acpi_checksum((void *)i, *((uint8_t *)(i + 5)))) {
|
|
||||||
|
if (!memcmp(ptr->anchor_str, "_SM_", 4) &&
|
||||||
|
!acpi_checksum((void *)ptr, ptr->length)) {
|
||||||
printv("acpi: Found SMBIOS 32-bit entry point at %x\n", i);
|
printv("acpi: Found SMBIOS 32-bit entry point at %x\n", i);
|
||||||
*smbios32 = (void *)i;
|
*smbios32 = (void *)ptr;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (size_t i = 0xf0000; i < 0x100000; i += 16) {
|
for (size_t i = 0xf0000; i < 0x100000; i += 16) {
|
||||||
if (!memcmp((char *)i, "_SM3_", 5)
|
struct smbios_entry_point_64 *ptr = (struct smbios_entry_point_64 *)i;
|
||||||
&& !acpi_checksum((void *)i, *((uint8_t *)(i + 6)))) {
|
|
||||||
|
if (!memcmp(ptr->anchor_str, "_SM3_", 5) &&
|
||||||
|
!acpi_checksum((void *)ptr, ptr->length)) {
|
||||||
printv("acpi: Found SMBIOS 64-bit entry point at %x\n", i);
|
printv("acpi: Found SMBIOS 64-bit entry point at %x\n", i);
|
||||||
*smbios64 = (void *)i;
|
*smbios64 = (void *)ptr;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -150,13 +154,14 @@ void acpi_get_smbios(void **smbios32, void **smbios64) {
|
|||||||
if (memcmp(&cur_table->VendorGuid, &smbios_guid, sizeof(EFI_GUID)) != 0)
|
if (memcmp(&cur_table->VendorGuid, &smbios_guid, sizeof(EFI_GUID)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (acpi_checksum(cur_table->VendorTable,
|
struct smbios_entry_point_32 *ptr = (struct smbios_entry_point_32 *)cur_table->VendorTable;
|
||||||
*((uint8_t *)(cur_table->VendorTable + 5))) != 0)
|
|
||||||
|
if (acpi_checksum((void *)ptr, ptr->length) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
printv("acpi: Found SMBIOS 32-bit entry point at %X\n", cur_table->VendorTable);
|
printv("acpi: Found SMBIOS 32-bit entry point at %X\n", ptr);
|
||||||
|
|
||||||
*smbios32 = cur_table->VendorTable;
|
*smbios32 = (void *)ptr;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -168,13 +173,14 @@ void acpi_get_smbios(void **smbios32, void **smbios64) {
|
|||||||
if (memcmp(&cur_table->VendorGuid, &smbios3_guid, sizeof(EFI_GUID)) != 0)
|
if (memcmp(&cur_table->VendorGuid, &smbios3_guid, sizeof(EFI_GUID)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (acpi_checksum(cur_table->VendorTable,
|
struct smbios_entry_point_64 *ptr = (struct smbios_entry_point_64 *)cur_table->VendorTable;
|
||||||
*((uint8_t *)(cur_table->VendorTable + 6))) != 0)
|
|
||||||
|
if (acpi_checksum((void *)ptr, ptr->length) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
printv("acpi: Found SMBIOS 64-bit entry point at %X\n", cur_table->VendorTable);
|
printv("acpi: Found SMBIOS 64-bit entry point at %X\n", ptr);
|
||||||
|
|
||||||
*smbios64 = cur_table->VendorTable;
|
*smbios64 = (void *)ptr;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ struct rsdp {
|
|||||||
char oem_id[6];
|
char oem_id[6];
|
||||||
uint8_t rev;
|
uint8_t rev;
|
||||||
uint32_t rsdt_addr;
|
uint32_t rsdt_addr;
|
||||||
// Rev 2 only after this comment
|
// Revision 2 only after this comment
|
||||||
uint32_t length;
|
uint32_t length;
|
||||||
uint64_t xsdt_addr;
|
uint64_t xsdt_addr;
|
||||||
uint8_t ext_checksum;
|
uint8_t ext_checksum;
|
||||||
@ -36,6 +36,59 @@ struct rsdt {
|
|||||||
char ptrs_start[];
|
char ptrs_start[];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct smbios_entry_point_32 {
|
||||||
|
char anchor_str[4];
|
||||||
|
/// This value summed with all the values of the table.
|
||||||
|
uint8_t checksum;
|
||||||
|
/// Length of the entry point table.
|
||||||
|
uint8_t length;
|
||||||
|
/// Major version of SMBIOS.
|
||||||
|
uint8_t major_version;
|
||||||
|
/// Minor version of SMBIOS.
|
||||||
|
uint8_t minor_version;
|
||||||
|
/// Size of the largest SMBIOS structure, in bytes, and encompasses the
|
||||||
|
/// structure’s formatted area and text strings
|
||||||
|
uint16_t max_structure_size;
|
||||||
|
uint8_t entry_point_revision;
|
||||||
|
char formatted_area[5];
|
||||||
|
|
||||||
|
char intermediate_anchor_str[5];
|
||||||
|
/// Checksum for values from intermediate anchor str to the
|
||||||
|
/// end of table.
|
||||||
|
uint8_t intermediate_checksum;
|
||||||
|
/// Total length of SMBIOS Structure Table, pointed to by the structure
|
||||||
|
/// table address, in bytes.
|
||||||
|
uint16_t table_length;
|
||||||
|
/// 32-bit physical starting address of the read-only SMBIOS Structure
|
||||||
|
/// Table.
|
||||||
|
uint32_t table_address;
|
||||||
|
/// Total number of structures present in the SMBIOS Structure Table.
|
||||||
|
uint16_t number_of_structures;
|
||||||
|
/// Indicates compliance with a revision of this specification.
|
||||||
|
uint8_t bcd_revision;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct smbios_entry_point_64 {
|
||||||
|
char anchor_str[5];
|
||||||
|
/// This value summed with all the values of the table.
|
||||||
|
uint8_t checksum;
|
||||||
|
/// Length of the entry point table.
|
||||||
|
uint8_t length;
|
||||||
|
/// Major version of SMBIOS.
|
||||||
|
uint8_t major_version;
|
||||||
|
/// Minor version of SMBIOS.
|
||||||
|
uint8_t minor_version;
|
||||||
|
uint8_t docrev;
|
||||||
|
uint8_t entry_point_revision;
|
||||||
|
uint8_t reserved;
|
||||||
|
/// Size of the largest SMBIOS structure, in bytes, and encompasses the
|
||||||
|
/// structure’s formatted area and text strings
|
||||||
|
uint16_t max_structure_size;
|
||||||
|
/// 64-bit physical starting address of the read-only SMBIOS Structure
|
||||||
|
/// Table.
|
||||||
|
uint64_t table_address;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
uint8_t acpi_checksum(void *ptr, size_t size);
|
uint8_t acpi_checksum(void *ptr, size_t size);
|
||||||
void *acpi_get_rsdp(void);
|
void *acpi_get_rsdp(void);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user