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:
Junjie Mao 2021-07-03 08:31:53 +08:00 committed by wenlingz
parent 503b1ee317
commit 0991f7f03b
2 changed files with 36 additions and 0 deletions

View File

@ -11,6 +11,8 @@ from acpiparser.dmar import DMAR
from acpiparser.dsdt import DSDT
from acpiparser.facp import FACP
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):
if not path:

View File

@ -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))