pci: intel: Fix configuration type based on secondary number
This fix issue when access config from PCIe switch. The PCIe controller need to send Type 0 config TLP if the targeting bus matches with the secondary bus number, which is when the TLP is targeting the immediate device on the link. The PCIe controller send Type 1 config TLP if the targeting bus is larger than the secondary bus, which is when the TLP is targeting the device not immediate on the link. Signed-off-by: Ley Foon Tan <ley.foon.tan@intel.com>
This commit is contained in:
parent
bf9b9813ad
commit
d44f793207
@ -36,16 +36,18 @@
|
||||
|
||||
#define RP_CFG_ADDR(pcie, reg) \
|
||||
((pcie->hip_base) + (reg) + (1 << 20))
|
||||
#define RP_SECONDARY(pcie) \
|
||||
readb(RP_CFG_ADDR(pcie, PCI_SECONDARY_BUS))
|
||||
#define TLP_REQ_ID(bus, devfn) (((bus) << 8) | (devfn))
|
||||
|
||||
#define TLP_CFGRD_DW0(pcie, bus) \
|
||||
((((bus != pcie->first_busno) ? TLP_FMTTYPE_CFGRD0 \
|
||||
: TLP_FMTTYPE_CFGRD1) << 24) | \
|
||||
((((bus > RP_SECONDARY(pcie)) ? TLP_FMTTYPE_CFGRD1 \
|
||||
: TLP_FMTTYPE_CFGRD0) << 24) | \
|
||||
TLP_PAYLOAD_SIZE)
|
||||
|
||||
#define TLP_CFGWR_DW0(pcie, bus) \
|
||||
((((bus != pcie->first_busno) ? TLP_FMTTYPE_CFGWR0 \
|
||||
: TLP_FMTTYPE_CFGWR1) << 24) | \
|
||||
((((bus > RP_SECONDARY(pcie)) ? TLP_FMTTYPE_CFGWR1 \
|
||||
: TLP_FMTTYPE_CFGWR0) << 24) | \
|
||||
TLP_PAYLOAD_SIZE)
|
||||
|
||||
#define TLP_CFG_DW1(pcie, tag, be) \
|
||||
|
Loading…
Reference in New Issue
Block a user