summaryrefslogtreecommitdiffstats
path: root/lib/asn1_decoder.c
diff options
context:
space:
mode:
authorAnjali Singhai <anjali.singhai@intel.com>2015-09-28 22:37:12 +0200
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>2015-09-29 02:43:23 +0200
commit30e2561b95295258890b4e0366ce867e04d34a97 (patch)
tree1c47ee8a4e8de32e665a72a73ec059dc0b388d90 /lib/asn1_decoder.c
parenti40e: Fix RS bit update in Tx path and disable force WB workaround (diff)
downloadlinux-30e2561b95295258890b4e0366ce867e04d34a97.tar.xz
linux-30e2561b95295258890b4e0366ce867e04d34a97.zip
i40e: Fix for recursive RTNL lock during PROMISC change
The sync_vsi_filters function can be called directly under RTNL or through the timer subtask without one. This was causing a deadlock. If sync_vsi_filters is called from a thread which held the lock, and in another thread the PROMISC setting got changed we would be executing the PROMISC change in the thread which already held the lock alongside the other filter update. The PROMISC change requires a reset if we are on a VEB, which requires it to be called under RTNL. Earlier the driver would call reset for PROMISC change without checking if we were already under RTNL and would try to grab it causing a deadlock. This patch changes the flow to see if we are already under RTNL before trying to grab it. Signed-off-by: Anjali Singhai Jain <anjali.singhai@intel.com> Signed-off-by: Kiran Patil <kiran.patil@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'lib/asn1_decoder.c')
0 files changed, 0 insertions, 0 deletions