/* * VAS_EBOOT -- GRand Unified Bootloader * Copyright (C) 2008 Free Software Foundation, Inc. * * VAS_EBOOT 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 * (at your option) any later version. * * VAS_EBOOT 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 VAS_EBOOT. If not, see . */ #include #include #include #include #include #include VAS_EBOOT_MOD_LICENSE ("GPLv3+"); #ifndef VAS_EBOOT_MACHINE_EMU static const char *names[] = { [VAS_EBOOT_MEMORY_AVAILABLE] = N_("available RAM"), [VAS_EBOOT_MEMORY_RESERVED] = N_("reserved RAM"), /* TRANSLATORS: this refers to memory where ACPI tables are stored and which can be used by OS once it loads ACPI tables. */ [VAS_EBOOT_MEMORY_ACPI] = N_("ACPI reclaimable RAM"), /* TRANSLATORS: this refers to memory which ACPI-compliant OS is required to save accross hibernations. */ [VAS_EBOOT_MEMORY_NVS] = N_("ACPI non-volatile storage RAM"), [VAS_EBOOT_MEMORY_BADRAM] = N_("faulty RAM (BadRAM)"), [VAS_EBOOT_MEMORY_PERSISTENT] = N_("persistent RAM"), [VAS_EBOOT_MEMORY_PERSISTENT_LEGACY] = N_("persistent RAM (legacy)"), [VAS_EBOOT_MEMORY_COREBOOT_TABLES] = N_("RAM holding coreboot tables"), [VAS_EBOOT_MEMORY_CODE] = N_("RAM holding firmware code") }; /* Helper for VasEBoot_cmd_lsmmap. */ static int lsmmap_hook (VasEBoot_uint64_t addr, VasEBoot_uint64_t size, VasEBoot_memory_type_t type, void *data __attribute__ ((unused))) { if (type < (int) ARRAY_SIZE (names) && type >= 0 && names[type]) VasEBoot_printf_ (N_("base_addr = 0x%llx, length = 0x%llx, %s\n"), (long long) addr, (long long) size, _(names[type])); else VasEBoot_printf_ (N_("base_addr = 0x%llx, length = 0x%llx, type = 0x%x\n"), (long long) addr, (long long) size, type); return 0; } #endif static VasEBoot_err_t VasEBoot_cmd_lsmmap (VasEBoot_command_t cmd __attribute__ ((unused)), int argc __attribute__ ((unused)), char **args __attribute__ ((unused))) { #ifndef VAS_EBOOT_MACHINE_EMU VasEBoot_machine_mmap_iterate (lsmmap_hook, NULL); #endif return 0; } static VasEBoot_command_t cmd; VAS_EBOOT_MOD_INIT(lsmmap) { cmd = VasEBoot_register_command ("lsmmap", VasEBoot_cmd_lsmmap, 0, N_("List memory map provided by firmware.")); } VAS_EBOOT_MOD_FINI(lsmmap) { VasEBoot_unregister_command (cmd); }