APPLIED: [SRU Bionic][PATCH 1/1] nvme/multipath: Fix multipath disabled naming collisions

Kleber Souza kleber.souza at canonical.com
Mon Aug 27 14:43:27 UTC 2018


On 08/23/18 07:20, Khaled Elmously wrote:
> to bionic/master-next
> 
> On 2018-08-21 16:22:21 , Khalid Elmously wrote:
>> From: Keith Busch <keith.busch at intel.com>
>>
>> BugLink: https://bugs.launchpad.net/bugs/1785334

I have amended this commit using the following public bug report:

BugLink: https://bugs.launchpad.net/bugs/1789227


Thanks,
Kleber

>>
>> When CONFIG_NVME_MULTIPATH is set, but we're not using nvme to multipath,
>> namespaces with multiple paths were not creating unique names due to
>> reusing the same instance number from the namespace's head.
>>
>> This patch fixes this by falling back to the non-multipath naming method
>> when the parameter disabled using multipath.
>>
>> Reported-by: Mike Snitzer <snitzer at redhat.com>
>> Signed-off-by: Keith Busch <keith.busch at intel.com>
>> Reviewed-by: Christoph Hellwig <hch at lst.de>
>> Signed-off-by: Jens Axboe <axboe at kernel.dk>
>> (cherry-picked from a785dbccd95c37606c720580714f5a7a8b3255f1)
>> Signed-off-by: Khalid Elmously <khalid.elmously at canonical.com>
>> ---
>>  drivers/nvme/host/core.c      | 26 +-------------------------
>>  drivers/nvme/host/multipath.c | 22 ++++++++++++++++++++++
>>  drivers/nvme/host/nvme.h      | 12 ++++++++++++
>>  3 files changed, 35 insertions(+), 25 deletions(-)
>>
>> diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c
>> index a7662186c88e..0230b192540c 100644
>> --- a/drivers/nvme/host/core.c
>> +++ b/drivers/nvme/host/core.c
>> @@ -2902,31 +2902,7 @@ static void nvme_alloc_ns(struct nvme_ctrl *ctrl, unsigned nsid)
>>  	if (nvme_init_ns_head(ns, nsid, id, &new))
>>  		goto out_free_id;
>>  	nvme_setup_streams_ns(ctrl, ns);
>> -	
>> -#ifdef CONFIG_NVME_MULTIPATH
>> -	/*
>> -	 * If multipathing is enabled we need to always use the subsystem
>> -	 * instance number for numbering our devices to avoid conflicts
>> -	 * between subsystems that have multiple controllers and thus use
>> -	 * the multipath-aware subsystem node and those that have a single
>> -	 * controller and use the controller node directly.
>> -	 */
>> -	if (ns->head->disk) {
>> -		sprintf(disk_name, "nvme%dc%dn%d", ctrl->subsys->instance,
>> -				ctrl->cntlid, ns->head->instance);
>> -		flags = GENHD_FL_HIDDEN;
>> -	} else {
>> -		sprintf(disk_name, "nvme%dn%d", ctrl->subsys->instance,
>> -				ns->head->instance);
>> -	}
>> -#else
>> -	/*
>> -	 * But without the multipath code enabled, multiple controller per
>> -	 * subsystems are visible as devices and thus we cannot use the
>> -	 * subsystem instance.
>> -	 */
>> -	sprintf(disk_name, "nvme%dn%d", ctrl->instance, ns->head->instance);
>> -#endif
>> +	nvme_set_disk_name(disk_name, ns, ctrl, &flags);
>>  
>>  	if ((ctrl->quirks & NVME_QUIRK_LIGHTNVM) && id->vs[0] == 0x1) {
>>  		if (nvme_nvm_register(ns, disk_name, node)) {
>> diff --git a/drivers/nvme/host/multipath.c b/drivers/nvme/host/multipath.c
>> index cf16905d25e2..3f3143205071 100644
>> --- a/drivers/nvme/host/multipath.c
>> +++ b/drivers/nvme/host/multipath.c
>> @@ -19,6 +19,28 @@ module_param(multipath, bool, 0644);
>>  MODULE_PARM_DESC(multipath,
>>  	"turn on native support for multiple controllers per subsystem");
>>  
>> +/*
>> + * If multipathing is enabled we need to always use the subsystem instance
>> + * number for numbering our devices to avoid conflicts between subsystems that
>> + * have multiple controllers and thus use the multipath-aware subsystem node
>> + * and those that have a single controller and use the controller node
>> + * directly.
>> + */
>> +void nvme_set_disk_name(char *disk_name, struct nvme_ns *ns,
>> +			struct nvme_ctrl *ctrl, int *flags)
>> +{
>> +	if (!multipath) {
>> +		sprintf(disk_name, "nvme%dn%d", ctrl->instance, ns->head->instance);
>> +	} else if (ns->head->disk) {
>> +		sprintf(disk_name, "nvme%dc%dn%d", ctrl->subsys->instance,
>> +				ctrl->cntlid, ns->head->instance);
>> +		*flags = GENHD_FL_HIDDEN;
>> +	} else {
>> +		sprintf(disk_name, "nvme%dn%d", ctrl->subsys->instance,
>> +				ns->head->instance);
>> +	}
>> +}
>> +
>>  void nvme_failover_req(struct request *req)
>>  {
>>  	struct nvme_ns *ns = req->q->queuedata;
>> diff --git a/drivers/nvme/host/nvme.h b/drivers/nvme/host/nvme.h
>> index f82365cc99fd..a9ec71cce3cc 100644
>> --- a/drivers/nvme/host/nvme.h
>> +++ b/drivers/nvme/host/nvme.h
>> @@ -405,6 +405,8 @@ extern const struct attribute_group nvme_ns_id_attr_group;
>>  extern const struct block_device_operations nvme_ns_head_ops;
>>  
>>  #ifdef CONFIG_NVME_MULTIPATH
>> +void nvme_set_disk_name(char *disk_name, struct nvme_ns *ns,
>> +			struct nvme_ctrl *ctrl, int *flags);
>>  void nvme_failover_req(struct request *req);
>>  bool nvme_req_needs_failover(struct request *req);
>>  void nvme_kick_requeue_lists(struct nvme_ctrl *ctrl);
>> @@ -430,6 +432,16 @@ static inline void nvme_mpath_check_last_path(struct nvme_ns *ns)
>>  }
>>  
>>  #else
>> +/*
>> + * Without the multipath code enabled, multiple controller per subsystems are
>> + * visible as devices and thus we cannot use the subsystem instance.
>> + */
>> +static inline void nvme_set_disk_name(char *disk_name, struct nvme_ns *ns,
>> +				      struct nvme_ctrl *ctrl, int *flags)
>> +{
>> +	sprintf(disk_name, "nvme%dn%d", ctrl->instance, ns->head->instance);
>> +}
>> +
>>  static inline void nvme_failover_req(struct request *req)
>>  {
>>  }
>> -- 
>> 2.17.1
>>
> 





More information about the kernel-team mailing list