bdev_nvme_delete() had called nvme_bdev_ctrlr_get_by_name() and then called remove_cb(). But nvme_bdev_ctrlr_get_by_name() had not been guarded by lock and remove_cb() parsed the list again by using spdk_nvme_ctrlr as a key. These were not safe and efficient. This patch refines bdev_nvme_delete() to inline remove_cb() into it and acquire mutex before calling nvme_bdev_ctrlr_get_by_name(). Signed-off-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Change-Id: Ibf39859809efa6f22899353c53b7b1eef58aa470 Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/4842 Community-CI: Broadcom CI Community-CI: Mellanox Build Bot Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-by: Aleksey Marchuk <alexeymar@mellanox.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> |
||
---|---|---|
.. | ||
accel | ||
bdev | ||
blob | ||
blobfs | ||
env_dpdk | ||
event | ||
sock | ||
Makefile |