mirror of
https://github.com/SCST-project/scst.git
synced 2026-05-20 04:01:26 +00:00
scst, scst_vdisk: Simplify the code for querying the vdisk filename
git-svn-id: http://svn.code.sf.net/p/scst/svn/trunk@7860 d57e44dd-8a1f-0410-8b47-8ef2f437770f
This commit is contained in:
@@ -2846,14 +2846,6 @@ struct scst_device {
|
|||||||
/* Set, if a strictly serialized cmd is waiting blocked */
|
/* Set, if a strictly serialized cmd is waiting blocked */
|
||||||
unsigned int strictly_serialized_cmd_waiting:1;
|
unsigned int strictly_serialized_cmd_waiting:1;
|
||||||
|
|
||||||
/*
|
|
||||||
* Set, if this device is being unregistered. Useful to let sysfs
|
|
||||||
* attributes know when they should exit immediately to prevent
|
|
||||||
* possible deadlocks with their device unregistration waiting for
|
|
||||||
* their kobj last put.
|
|
||||||
*/
|
|
||||||
unsigned int dev_unregistering:1;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Set if ext blocking is pending. It is just shortcut for
|
* Set if ext blocking is pending. It is just shortcut for
|
||||||
* !list_empty(&dev->ext_blockers_list) to save a cache miss.
|
* !list_empty(&dev->ext_blockers_list) to save a cache miss.
|
||||||
|
|||||||
@@ -9154,6 +9154,17 @@ static ssize_t vdisk_sysfs_rotational_show(struct kobject *kobj,
|
|||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool scst_dev_being_unregistered(struct scst_device *dev)
|
||||||
|
{
|
||||||
|
bool res;
|
||||||
|
|
||||||
|
mutex_lock(&scst_mutex);
|
||||||
|
res = list_empty(&dev->dev_list_entry);
|
||||||
|
mutex_unlock(&scst_mutex);
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
static int vdev_sysfs_process_get_filename(struct scst_sysfs_work_item *work)
|
static int vdev_sysfs_process_get_filename(struct scst_sysfs_work_item *work)
|
||||||
{
|
{
|
||||||
int res = 0;
|
int res = 0;
|
||||||
@@ -9171,7 +9182,7 @@ static int vdev_sysfs_process_get_filename(struct scst_sysfs_work_item *work)
|
|||||||
* under scst_vdisk_mutex.
|
* under scst_vdisk_mutex.
|
||||||
*/
|
*/
|
||||||
while (!mutex_trylock(&scst_vdisk_mutex)) {
|
while (!mutex_trylock(&scst_vdisk_mutex)) {
|
||||||
if (dev->dev_unregistering) {
|
if (scst_dev_being_unregistered(dev)) {
|
||||||
TRACE_MGMT_DBG("Skipping being unregistered dev %s",
|
TRACE_MGMT_DBG("Skipping being unregistered dev %s",
|
||||||
dev->virt_name);
|
dev->virt_name);
|
||||||
res = -ENOENT;
|
res = -ENOENT;
|
||||||
@@ -9182,18 +9193,6 @@ static int vdev_sysfs_process_get_filename(struct scst_sysfs_work_item *work)
|
|||||||
goto out_put;
|
goto out_put;
|
||||||
}
|
}
|
||||||
msleep(100);
|
msleep(100);
|
||||||
/*
|
|
||||||
* We need to reread dev_unregistering from memory, hence
|
|
||||||
* prevent compiler from putting it in a register. Generally,
|
|
||||||
* it shouldn't happen, because the compiler isn't allowed to do
|
|
||||||
* such a transformation if any functions that can cause side
|
|
||||||
* effects are called between successive accesses, but let's be
|
|
||||||
* on the safe side. We can't cast dev_unregistering to
|
|
||||||
* volatile, because it has no effect we need, and can't cast
|
|
||||||
* it to *(volatile bool*)&, because it isn't possible to get
|
|
||||||
* address of a bit field.
|
|
||||||
*/
|
|
||||||
barrier();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virt_dev = dev->dh_priv;
|
virt_dev = dev->dh_priv;
|
||||||
|
|||||||
@@ -1307,8 +1307,6 @@ static void scst_unregister_device(struct scsi_device *scsidp)
|
|||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
dev->dev_unregistering = 1;
|
|
||||||
|
|
||||||
list_del_init(&dev->dev_list_entry);
|
list_del_init(&dev->dev_list_entry);
|
||||||
|
|
||||||
#ifdef CONFIG_SCST_FORWARD_MODE_PASS_THROUGH
|
#ifdef CONFIG_SCST_FORWARD_MODE_PASS_THROUGH
|
||||||
@@ -1535,8 +1533,7 @@ out:
|
|||||||
return res;
|
return res;
|
||||||
|
|
||||||
out_unreg:
|
out_unreg:
|
||||||
dev->dev_unregistering = 1;
|
list_del_init(&dev->dev_list_entry);
|
||||||
list_del(&dev->dev_list_entry);
|
|
||||||
scst_assign_dev_handler(dev, &scst_null_devtype);
|
scst_assign_dev_handler(dev, &scst_null_devtype);
|
||||||
goto out_pr_clear_dev;
|
goto out_pr_clear_dev;
|
||||||
|
|
||||||
@@ -1593,8 +1590,6 @@ void scst_unregister_virtual_device(int id,
|
|||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
dev->dev_unregistering = 1;
|
|
||||||
|
|
||||||
scst_cm_on_dev_unregister(dev);
|
scst_cm_on_dev_unregister(dev);
|
||||||
|
|
||||||
list_del_init(&dev->dev_list_entry);
|
list_del_init(&dev->dev_list_entry);
|
||||||
|
|||||||
Reference in New Issue
Block a user