vc/amd/opensil/genoa_poc/mpio: don't add duplicate MPIO descriptors
When the device right below the MPIO chip driver has downstream devices without another chip in between, those downstream devices will also have their chip_ops entry set to vendorcode_amd_opensil_genoa_poc_mpio_ops. To avoid adding the same MPIO descriptor again for those additional downstream devices, make sure that the chip_info pointer of the device isn't the same as the one of the parent device, since that's only the case for those additional downstream devices. TEST=Onyx still boots to the payload and the MPIO configuration reported from the openSIL code is still the same Signed-off-by: Felix Held <felix-coreboot@felixheld.de> Suggested-by: Nico Huber <nico.h@gmx.de> Change-Id: I6ba90fdc83ba089127e6722778bfef29dd480bb4 Reviewed-on: https://review.coreboot.org/c/coreboot/+/80149 Reviewed-by: Arthur Heymans <arthur@aheymans.xyz> Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
dc12a3817a
commit
c4e5e91cbd
1 changed files with 3 additions and 2 deletions
|
@ -186,8 +186,9 @@ void configure_mpio(void)
|
|||
mpio_global_config(mpio_data);
|
||||
nbio_config();
|
||||
|
||||
/* Find all devices with this chip */
|
||||
/* Find all devices with this chip that are directly below the chip */
|
||||
for (struct device *dev = &dev_root; dev; dev = dev->next)
|
||||
if (dev->chip_ops == &vendorcode_amd_opensil_genoa_poc_mpio_ops)
|
||||
if (dev->chip_ops == &vendorcode_amd_opensil_genoa_poc_mpio_ops &&
|
||||
dev->chip_info != dev->bus->dev->chip_info)
|
||||
per_device_config(mpio_data, dev->bus->dev, dev->chip_info);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue