summaryrefslogtreecommitdiff
path: root/arch
diff options
context:
space:
mode:
authorMark Rustad <mark.d.rustad@intel.com>2015-07-13 11:40:02 -0700
committerBjorn Helgaas <bhelgaas@google.com>2015-07-21 13:11:53 -0500
commit932c435caba8a2ce473a91753bad0173269ef334 (patch)
tree00a63ae50d202eb8a0ff9594df61f95214dabc18 /arch
parent113e0d118a93c964feea376de8c94dd8c7c63ff8 (diff)
downloadlwn-932c435caba8a2ce473a91753bad0173269ef334.tar.gz
lwn-932c435caba8a2ce473a91753bad0173269ef334.zip
PCI: Add dev_flags bit to access VPD through function 0
Add a dev_flags bit, PCI_DEV_FLAGS_VPD_REF_F0, to access VPD through function 0 to provide VPD access on other functions. This is for hardware devices that provide copies of the same VPD capability registers in multiple functions. Because the kernel expects that each function has its own registers, both the locking and the state tracking are affected by VPD accesses to different functions. On such devices for example, if a VPD write is performed on function 0, *any* later attempt to read VPD from any other function of that device will hang. This has to do with how the kernel tracks the expected value of the F bit per function. Concurrent accesses to different functions of the same device can not only hang but also corrupt both read and write VPD data. When hangs occur, typically the error message: vpd r/w failed. This is likely a firmware bug on this device. will be seen. Never set this bit on function 0 or there will be an infinite recursion. Signed-off-by: Mark Rustad <mark.d.rustad@intel.com> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> Acked-by: Alexander Duyck <alexander.h.duyck@redhat.com> CC: stable@vger.kernel.org
Diffstat (limited to 'arch')
0 files changed, 0 insertions, 0 deletions