Source code for chipsec.utilcmd.acpi_cmd

# CHIPSEC: Platform Security Assessment Framework
# Copyright (c) 2010-2021, Intel Corporation
#
# This program 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; Version 2.
#
# This program 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 this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
#
# Contact information:
# chipsec@intel.com
#


"""
Command-line utility providing access to ACPI tables

>>> chipsec_util acpi list
>>> chipsec_util acpi table <name>|<file_path>

Examples:

>>> chipsec_util acpi list
>>> chipsec_util acpi table XSDT
>>> chipsec_util acpi table acpi_table.bin
"""

from os.path import exists as path_exists
from argparse import ArgumentParser

from chipsec.hal.acpi import ACPI
from chipsec.command import BaseCommand, toLoad

# ###################################################################
#
# Advanced Configuration and Power Interface (ACPI)
#
# ###################################################################


[docs]class ACPICommand(BaseCommand):
[docs] def requirements(self) -> toLoad: if self.func == self.acpi_table and self._file: return toLoad.Nil # TODO: Fix this case. Need to update ACPI HAL to not try to auto-populate tables. return toLoad.All
[docs] def parse_arguments(self) -> None: parser = ArgumentParser(usage=__doc__) subparsers = parser.add_subparsers() parser_list = subparsers.add_parser('list') parser_list.set_defaults(func=self.acpi_list) parser_table = subparsers.add_parser('table') parser_table.add_argument('-f', '--file', dest='_file', help='Read from file', action='store_true') parser_table.add_argument('_name', metavar='table|filename', nargs=1, help="table to list") parser_table.set_defaults(func=self.acpi_table) parser.parse_args(self.argv, namespace=self)
[docs] def set_up(self) -> None: self._acpi = ACPI(self.cs)
[docs] def acpi_list(self) -> None: self.logger.log('[CHIPSEC] Enumerating ACPI tables..') self._acpi.print_ACPI_table_list()
[docs] def acpi_table(self) -> None: name = self._name[0] if not self._file and not self._acpi.is_ACPI_table_present(name): self.logger.log_error(f'Please specify table name from {self._acpi.tableList.keys()}') return elif self._file and not path_exists(name): self.logger.log_error(f"[CHIPSEC] Unable to find file '{name}'") return self.logger.log(f"[CHIPSEC] reading ACPI table {'from file' if self._file else ''} '{name}'") self._acpi.dump_ACPI_table(name, self._file) return
commands = {'acpi': ACPICommand}