+14
−1
Loading
By making dpdk device detach asynchronous we have actually broken some cases where devices are re-attached immediately after and fail since they were not detached yet. We'll need to make detach synchronous again, and for that we'll wait for the background dpdk thread to perform all necessary actions before we return from spdk_pci_device_detach(). However, device detach could be triggered from the very same dpdk background thread as well. Waiting there would cause a deadlock, so now we'll schedule asynchronous device detach to the dpdk thread only if we're not on that thread already. This patch itself serves also as an optimization. Change-Id: I86b7ac1b669169eee3325de2d28c2cc313e7d901 Signed-off-by:Darek Stojaczyk <dariusz.stojaczyk@intel.com> Reviewed-on: https://review.gerrithub.io/c/spdk/spdk/+/460285 Tested-by:
SPDK CI Jenkins <sys_sgci@intel.com> Reviewed-by:
Ben Walker <benjamin.walker@intel.com> Reviewed-by:
Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com>