diff options
Diffstat (limited to 'drivers/nvme/host/multipath.c')
| -rw-r--r-- | drivers/nvme/host/multipath.c | 24 | 
1 files changed, 23 insertions, 1 deletions
| diff --git a/drivers/nvme/host/multipath.c b/drivers/nvme/host/multipath.c index 956e0b8e9c4d..d7b664ae5923 100644 --- a/drivers/nvme/host/multipath.c +++ b/drivers/nvme/host/multipath.c @@ -15,10 +15,32 @@  #include "nvme.h"  static bool multipath = true; -module_param(multipath, bool, 0644); +module_param(multipath, bool, 0444);  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; | 
