board_inspector: add a parser of PCI routing tables
This patch adds a parser to the PCI routing tables returned by _PRT objects of platform devices. The parsed result is a list of PRTMappingPackage instances, each of which is a named tuple with the following fields: * address: a dword with higher 16 bits being the function number and lower 16 bits all 1's. * pin: a byte representing the mapped pin. * source: either a DeviceDecl of the device that allocates the interrupt line, or the byte 0. * source_index: - If `source` is a DeviceDecl, this is the index of the interrupt source within that device. - If `source` is 0, this is the interrupt line connected to the pin. Tracked-On: #6287 Signed-off-by: Junjie Mao <junjie.mao@intel.com>
This commit is contained in:
parent
503b1ee317
commit
0991f7f03b
|
@ -11,6 +11,8 @@ from acpiparser.dmar import DMAR
|
||||||
from acpiparser.dsdt import DSDT
|
from acpiparser.dsdt import DSDT
|
||||||
from acpiparser.facp import FACP
|
from acpiparser.facp import FACP
|
||||||
from acpiparser.rtct import RTCT
|
from acpiparser.rtct import RTCT
|
||||||
|
from acpiparser.rdt import parse_resource_data
|
||||||
|
from acpiparser.prt import parse_pci_routing
|
||||||
|
|
||||||
def parse_table(signature, path=None):
|
def parse_table(signature, path=None):
|
||||||
if not path:
|
if not path:
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
# Copyright (C) 2021 Intel Corporation. All rights reserved.
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
#
|
||||||
|
|
||||||
|
from collections import namedtuple
|
||||||
|
from .aml import datatypes, context
|
||||||
|
|
||||||
|
class PRTMappingPackage(namedtuple("PRTMappingPackage", ["address", "pin", "source", "source_index"])):
|
||||||
|
def __repr__(self):
|
||||||
|
if isinstance(self.source, context.DeviceDecl):
|
||||||
|
s = self.source.name
|
||||||
|
else:
|
||||||
|
s = str(self.source)
|
||||||
|
return "address=0x{0:08x}, pin=0x{1:02x}, source={2}, source_index=0x{3:08x}".format(
|
||||||
|
self.address, self.pin, s, self.source_index)
|
||||||
|
|
||||||
|
def parse_prt_mapping(x):
|
||||||
|
address = x.elements[0].get()
|
||||||
|
pin = x.elements[1].get()
|
||||||
|
source = x.elements[2]
|
||||||
|
if isinstance(source, datatypes.Device):
|
||||||
|
source = source.get_sym()
|
||||||
|
elif isinstance(source, datatypes.Integer):
|
||||||
|
source = source.get()
|
||||||
|
else:
|
||||||
|
source = "unknown"
|
||||||
|
source_index = x.elements[3].get()
|
||||||
|
|
||||||
|
return PRTMappingPackage(address, pin, source, source_index)
|
||||||
|
|
||||||
|
def parse_pci_routing(package):
|
||||||
|
"""Parse ACPI PCI routing table returned by _PRT control methods."""
|
||||||
|
return list(map(parse_prt_mapping, package.elements))
|
Loading…
Reference in New Issue