diff options
| author | Jens Axboe <axboe@kernel.dk> | 2018-08-29 11:05:20 -0600 | 
|---|---|---|
| committer | Jens Axboe <axboe@kernel.dk> | 2018-08-29 11:05:20 -0600 | 
| commit | 52bd456a66c1abb7dd43628080025703248b1ea2 (patch) | |
| tree | ca01f0e9340a4aa0ecb52d41849a45a41d7ff346 /drivers | |
| parent | 8f3fafc9c2f0ece10832c25f7ffcb07c97a32ad4 (diff) | |
| parent | 04db0e5ec58167364a80fd33ddb4f3b67434eb85 (diff) | |
| download | linux-52bd456a66c1abb7dd43628080025703248b1ea2.tar.bz2 | |
Merge branch 'nvme-4.19' of git://git.infradead.org/nvme into for-linus
Pull NVMe fixes from Christoph.
* 'nvme-4.19' of git://git.infradead.org/nvme:
  nvmet: free workqueue object if module init fails
  nvme-fcloop: Fix dropped LS's to removed target port
  nvme-pci: add a memory barrier to nvme_dbbuf_update_and_check_event
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/nvme/host/pci.c | 8 | ||||
| -rw-r--r-- | drivers/nvme/target/core.c | 4 | ||||
| -rw-r--r-- | drivers/nvme/target/fcloop.c | 3 | 
3 files changed, 13 insertions, 2 deletions
| diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c index 1b9951d2067e..d668682f91df 100644 --- a/drivers/nvme/host/pci.c +++ b/drivers/nvme/host/pci.c @@ -316,6 +316,14 @@ static bool nvme_dbbuf_update_and_check_event(u16 value, u32 *dbbuf_db,  		old_value = *dbbuf_db;  		*dbbuf_db = value; +		/* +		 * Ensure that the doorbell is updated before reading the event +		 * index from memory.  The controller needs to provide similar +		 * ordering to ensure the envent index is updated before reading +		 * the doorbell. +		 */ +		mb(); +  		if (!nvme_dbbuf_need_event(*dbbuf_ei, value, old_value))  			return false;  	} diff --git a/drivers/nvme/target/core.c b/drivers/nvme/target/core.c index ebf3e7a6c49e..b5ec96abd048 100644 --- a/drivers/nvme/target/core.c +++ b/drivers/nvme/target/core.c @@ -1210,7 +1210,7 @@ static int __init nvmet_init(void)  	error = nvmet_init_discovery();  	if (error) -		goto out; +		goto out_free_work_queue;  	error = nvmet_init_configfs();  	if (error) @@ -1219,6 +1219,8 @@ static int __init nvmet_init(void)  out_exit_discovery:  	nvmet_exit_discovery(); +out_free_work_queue: +	destroy_workqueue(buffered_io_wq);  out:  	return error;  } diff --git a/drivers/nvme/target/fcloop.c b/drivers/nvme/target/fcloop.c index 34712def81b1..5251689a1d9a 100644 --- a/drivers/nvme/target/fcloop.c +++ b/drivers/nvme/target/fcloop.c @@ -311,7 +311,7 @@ fcloop_tgt_lsrqst_done_work(struct work_struct *work)  	struct fcloop_tport *tport = tls_req->tport;  	struct nvmefc_ls_req *lsreq = tls_req->lsreq; -	if (tport->remoteport) +	if (!tport || tport->remoteport)  		lsreq->done(lsreq, tls_req->status);  } @@ -329,6 +329,7 @@ fcloop_ls_req(struct nvme_fc_local_port *localport,  	if (!rport->targetport) {  		tls_req->status = -ECONNREFUSED; +		tls_req->tport = NULL;  		schedule_work(&tls_req->work);  		return ret;  	} |