summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMichał Żygowski <michal.zygowski@3mdeb.com>2018-11-26 19:47:23 +0100
committerPatrick Georgi <pgeorgi@google.com>2018-12-03 13:03:32 +0000
commit0486458c730a2424ce2decc43dbea7610eb09957 (patch)
tree102f563775071a9ee8ab065baff310f35ace8b3a /src
parent4d2d171f02f7b2b238b2b3183af2a756d9377bb7 (diff)
src/mb/pcengines/apu2/mainboard.c: Fix retrieving serial number
Handle situation when first NIC is not BDF 1:0.0. The PCI enumeration is different when a external PCIe device is connected to mPCIe2 slot which is routed to first PCIe bridge. The first NIC is then assigned BDF 2:0.0, because it is connected to the second PCIe bridge. Read the secondary bus number from the NIC PCIe bridge before attempting to read MAC adress and calculating serial number. Change-Id: I9f89a6f3cd0c23a2d2924e587338f69c260b12f8 Signed-off-by: Michał Żygowski <michal.zygowski@3mdeb.com> Reviewed-on: https://review.coreboot.org/c/29842 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Patrick Rudolph <siro@das-labor.org>
Diffstat (limited to 'src')
-rw-r--r--src/mainboard/pcengines/apu2/mainboard.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/src/mainboard/pcengines/apu2/mainboard.c b/src/mainboard/pcengines/apu2/mainboard.c
index 35385c20ce..6a01a8b015 100644
--- a/src/mainboard/pcengines/apu2/mainboard.c
+++ b/src/mainboard/pcengines/apu2/mainboard.c
@@ -194,17 +194,30 @@ static void mainboard_final(void *chip_info)
const char *smbios_mainboard_serial_number(void)
{
static char serial[10];
- struct device *nic_dev;
+ struct device *dev;
uintptr_t bar10;
u32 mac_addr = 0;
+ u32 bus_no;
int i;
- nic_dev = dev_find_slot(1, PCI_DEVFN(0, 0));
- if ((serial[0] != 0) || !nic_dev)
+ /*
+ * In case we have PCIe module connected to mPCIe2 slot, BDF 1:0.0 may
+ * not be a NIC, because mPCIe2 slot is routed to the very first PCIe
+ * bridge and the first NIC is connected to the second PCIe bridge.
+ * Read secondary bus number from the PCIe bridge where the first NIC is
+ * connected.
+ */
+ dev = dev_find_slot(0, PCI_DEVFN(2, 2));
+ if ((serial[0] != 0) || !dev)
+ return serial;
+
+ bus_no = dev->link_list->secondary;
+ dev = dev_find_slot(bus_no, PCI_DEVFN(0, 0));
+ if (!dev)
return serial;
/* Read in the last 3 bytes of NIC's MAC address. */
- bar10 = pci_read_config32(nic_dev, 0x10);
+ bar10 = pci_read_config32(dev, 0x10);
bar10 &= 0xFFFE0000;
bar10 += 0x5400;
for (i = 3; i < 6; i++) {