ixgbe: Fix race when the VF driver does a reset
authorRoss Lagerwall <ross.lagerwall@citrix.com>
Wed, 5 Dec 2018 13:54:26 +0000 (13:54 +0000)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Wed, 12 Dec 2018 23:51:50 +0000 (15:51 -0800)
commit96d1a731611f711f0cb82cea93363ae2ea8cb028
treee8fdb69be76835c8f04192638e894e0b329ee7a1
parent800b8f637d07cc00a05e2e0d847d8d7c61745654
ixgbe: Fix race when the VF driver does a reset

When the VF driver does a reset, it (at least the Linux one) writes to
the VFCTRL register to issue a reset and then immediately sends a reset
message using the mailbox API. This is racy because when the PF driver
detects that the VFCTRL register reset pin has been asserted, it clears
the mailbox memory. Depending on ordering, the reset message sent by
the VF could be cleared by the PF driver. It then responds to the
cleared message with a NACK which causes the VF driver to malfunction.
Fix this by deferring clearing the mailbox memory until the reset
message is received.

Fixes: 939b701ad633 ("ixgbe: fix driver behaviour after issuing VFLR")
Signed-off-by: Ross Lagerwall <ross.lagerwall@citrix.com>
Tested-by: Andrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/ixgbe/ixgbe_sriov.c