scsi: Fix seg.fault due to the gap between IO channel put and LUN removal
The reported github issue #938 has been reported intermettently. The issue is that the bdev descriptor passed to spdk_bdev_reset() is not valid and causes seg. fault. Current implementation of LUN hot plug is that putting IO channel and removing LUN are done by different poller. Hence if any task management command is issued between the gap, the reported issue is likely to occur. The flag removing is set at the start of LUN hot plug and so spdk_scsi_dev_get_lun() can return NULL even before completing removal by referring the flag removing. Fixes #938. Signed-off-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Change-Id: I1a51d90cc700134e8c0ec399a3ce62620c84ef73 Reviewed-on: https://review.gerrithub.io/c/spdk/spdk/+/467212 Reviewed-by: Changpeng Liu <changpeng.liu@intel.com> Reviewed-by: Broadcom SPDK FC-NVMe CI <spdk-ci.pdl@broadcom.com> Reviewed-by: Ben Walker <benjamin.walker@intel.com> Reviewed-by: Paul Luse <paul.e.luse@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
This commit is contained in:
parent
429258ed26
commit
8f33ac020d
@ -411,11 +411,19 @@ spdk_scsi_dev_get_id(const struct spdk_scsi_dev *dev)
|
||||
struct spdk_scsi_lun *
|
||||
spdk_scsi_dev_get_lun(struct spdk_scsi_dev *dev, int lun_id)
|
||||
{
|
||||
struct spdk_scsi_lun *lun;
|
||||
|
||||
if (lun_id < 0 || lun_id >= SPDK_SCSI_DEV_MAX_LUN) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return dev->lun[lun_id];
|
||||
lun = dev->lun[lun_id];
|
||||
|
||||
if (lun != NULL && !spdk_scsi_lun_is_removing(lun)) {
|
||||
return lun;
|
||||
} else {
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
bool
|
||||
|
Loading…
x
Reference in New Issue
Block a user