aboutsummaryrefslogtreecommitdiff
path: root/com32/hdt/hdt-menu-acpi.c
diff options
context:
space:
mode:
Diffstat (limited to 'com32/hdt/hdt-menu-acpi.c')
-rw-r--r--com32/hdt/hdt-menu-acpi.c134
1 files changed, 134 insertions, 0 deletions
diff --git a/com32/hdt/hdt-menu-acpi.c b/com32/hdt/hdt-menu-acpi.c
new file mode 100644
index 0000000..8e0ba18
--- /dev/null
+++ b/com32/hdt/hdt-menu-acpi.c
@@ -0,0 +1,134 @@
+/* ----------------------------------------------------------------------- *
+ *
+ * Copyright 2009 Erwan Velu - All Rights Reserved
+ *
+ * Permission is hereby granted, free of charge, to any person
+ * obtaining a copy of this software and associated documentation
+ * files (the "Software"), to deal in the Software without
+ * restriction, including without limitation the rights to use,
+ * copy, modify, merge, publish, distribute, sublicense, and/or
+ * sell copies of the Software, and to permit persons to whom
+ * the Software is furnished to do so, subject to the following
+ * conditions:
+ *
+ * The above copyright notice and this permission notice shall
+ * be included in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
+ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
+ * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+ * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * -----------------------------------------------------------------------
+*/
+
+#include "hdt-menu.h"
+
+void compute_table(struct s_my_menu *menu, void *address, s_acpi_description_header * h) {
+ char buffer[SUBMENULEN + 1] = { 0 };
+ char statbuffer[STATLEN + 1] = { 0 };
+
+ snprintf(buffer, sizeof buffer, "%-4s v%03x %-6s %-8s %-7s %08x",
+ h->signature, h->revision, h->oem_id, h->oem_table_id, h->creator_id, h->creator_revision);
+ snprintf(statbuffer, sizeof statbuffer, "%-4s v%03x %-6s %-7s 0x%08x %-4s 0x%08x @ 0x%p",
+ h->signature, h->revision, h->oem_id, h->oem_table_id,
+ h->oem_revision, h->creator_id, h->creator_revision, address);
+ add_item(buffer, statbuffer, OPT_INACTIVE, NULL, 0);
+ menu->items_count++;
+
+}
+
+/* Submenu for the vesa card */
+static void compute_acpi_tables(struct s_my_menu *menu,
+ struct s_hardware *hardware)
+{
+ menu->menu = add_menu(" ACPI Tables ", -1);
+ menu->items_count = 0;
+ set_menu_pos(SUBMENU_Y, SUBMENU_X);
+
+ char buffer[SUBMENULEN + 1] = { 0 };
+
+ snprintf(buffer, sizeof buffer, "%-4s %-4s %-6s %-8s %-7s %-8s",
+ "ACPI", "rev", "oem", "table_id", "creator", "creator_rev");
+ add_item(buffer, "Description", OPT_INACTIVE, NULL, 0);
+ menu->items_count++;
+
+ add_item("", "", OPT_SEP, "", 0);
+
+ if (hardware->acpi.rsdt.valid)
+ compute_table(menu,hardware->acpi.rsdt.address,
+ &hardware->acpi.rsdt.header);
+
+ if (hardware->acpi.xsdt.valid)
+ compute_table(menu,hardware->acpi.xsdt.address,
+ &hardware->acpi.xsdt.header);
+
+ if (hardware->acpi.fadt.valid)
+ compute_table(menu,hardware->acpi.fadt.address, &hardware->acpi.fadt.header);
+
+ if (hardware->acpi.dsdt.valid)
+ compute_table(menu,hardware->acpi.dsdt.address, &hardware->acpi.dsdt.header);
+
+ /* SSDT includes many optional tables, let's display them */
+ for (int i = 0; i < hardware->acpi.ssdt_count; i++) {
+ if ((hardware->acpi.ssdt[i] != NULL) && (hardware->acpi.ssdt[i]->valid))
+ compute_table(menu,hardware->acpi.ssdt[i]->address,
+ &hardware->acpi.ssdt[i]->header);
+ }
+
+ if (hardware->acpi.sbst.valid)
+ compute_table(menu,hardware->acpi.sbst.address, &hardware->acpi.sbst.header);
+
+ if (hardware->acpi.ecdt.valid)
+ compute_table(menu,hardware->acpi.ecdt.address, &hardware->acpi.ecdt.header);
+
+ if (hardware->acpi.hpet.valid)
+ compute_table(menu,hardware->acpi.hpet.address, &hardware->acpi.hpet.header);
+
+ if (hardware->acpi.tcpa.valid)
+ compute_table(menu,hardware->acpi.tcpa.address, &hardware->acpi.tcpa.header);
+
+ if (hardware->acpi.mcfg.valid)
+ compute_table(menu,hardware->acpi.mcfg.address, &hardware->acpi.mcfg.header);
+
+ if (hardware->acpi.slic.valid)
+ compute_table(menu,hardware->acpi.slic.address, &hardware->acpi.slic.header);
+
+ if (hardware->acpi.boot.valid)
+ compute_table(menu,hardware->acpi.boot.address, &hardware->acpi.boot.header);
+
+ /* FACS isn't having the same headers, let's use a dedicated rendering */
+ if (hardware->acpi.facs.valid) {
+ s_facs *fa = &hardware->acpi.facs;
+ char buffer[SUBMENULEN + 1] = { 0 };
+ char statbuffer[STATLEN + 1] = { 0 };
+
+ snprintf(buffer, sizeof buffer, "%-4s", fa->signature);
+ snprintf(statbuffer, sizeof statbuffer, "%-4s @ 0x%p", fa->signature, fa->address);
+ add_item(buffer, statbuffer, OPT_INACTIVE, NULL, 0);
+ menu->items_count++;
+ }
+
+ if (hardware->acpi.madt.valid)
+ compute_table(menu,hardware->acpi.madt.address, &hardware->acpi.madt.header);
+
+}
+
+/* Main ACPI Menu*/
+int compute_ACPI(struct s_hdt_menu *hdt_menu, struct s_hardware *hardware)
+{
+ compute_acpi_tables(&hdt_menu->acpi_tables_menu, hardware);
+ hdt_menu->acpi_menu.menu = add_menu(" ACPI ", -1);
+ hdt_menu->acpi_menu.items_count = 0;
+
+ add_item("Tables", "Tables", OPT_SUBMENU, NULL,
+ hdt_menu->acpi_tables_menu.menu);
+ hdt_menu->acpi_menu.items_count++;
+ printf("MENU: ACPI menu done (%d items)\n",
+ hdt_menu->acpi_menu.items_count);
+ return 0;
+}