diff options
author | Dan Williams <dan.j.williams@intel.com> | 2019-07-18 03:08:15 +0200 |
---|---|---|
committer | Dan Williams <dan.j.williams@intel.com> | 2019-07-19 01:23:02 +0200 |
commit | b70d31d054ee3a6fc1034b9d7fc0ae1e481aa018 (patch) | |
tree | 91af39c84f543136ea4594ea8e9d331844dfe127 /drivers/nvdimm/nd-core.h | |
parent | libnvdimm/bus: Prepare the nd_ioctl() path to be re-entrant (diff) | |
download | linux-b70d31d054ee3a6fc1034b9d7fc0ae1e481aa018.tar.xz linux-b70d31d054ee3a6fc1034b9d7fc0ae1e481aa018.zip |
libnvdimm/bus: Stop holding nvdimm_bus_list_mutex over __nd_ioctl()
In preparation for fixing a deadlock between wait_for_bus_probe_idle()
and the nvdimm_bus_list_mutex arrange for __nd_ioctl() without
nvdimm_bus_list_mutex held. This also unifies the 'dimm' and 'bus' level
ioctls into a common nd_ioctl() preamble implementation.
Marked for -stable as it is a pre-requisite for a follow-on fix.
Cc: <stable@vger.kernel.org>
Fixes: bf9bccc14c05 ("libnvdimm: pmem label sets and namespace instantiation")
Cc: Vishal Verma <vishal.l.verma@intel.com>
Tested-by: Jane Chu <jane.chu@oracle.com>
Link: https://lore.kernel.org/r/156341209518.292348.7183897251740665198.stgit@dwillia2-desk3.amr.corp.intel.com
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/nvdimm/nd-core.h')
-rw-r--r-- | drivers/nvdimm/nd-core.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/nvdimm/nd-core.h b/drivers/nvdimm/nd-core.h index 391e88de3a29..6cd470547106 100644 --- a/drivers/nvdimm/nd-core.h +++ b/drivers/nvdimm/nd-core.h @@ -17,10 +17,11 @@ extern struct workqueue_struct *nvdimm_wq; struct nvdimm_bus { struct nvdimm_bus_descriptor *nd_desc; - wait_queue_head_t probe_wait; + wait_queue_head_t wait; struct list_head list; struct device dev; int id, probe_active; + atomic_t ioctl_active; struct list_head mapping_list; struct mutex reconfig_mutex; struct badrange badrange; |