1. 26 5月, 2017 1 次提交
  2. 23 5月, 2017 9 次提交
  3. 21 5月, 2017 3 次提交
  4. 10 5月, 2017 1 次提交
  5. 08 5月, 2017 1 次提交
    • G
      lightnvm: remove unused rq parameter of nvme_nvm_rqtocmd() to kill warning · 629b1b2e
      Geert Uytterhoeven 提交于
      With gcc 4.1.2:
      
          drivers/nvme/host/lightnvm.c: In function ‘nvme_nvm_submit_io’:
          drivers/nvme/host/lightnvm.c:498: warning: ‘rq’ is used uninitialized in this function
      
      Indeed, since commit 2e13f33a ("lightnvm: create cmd before
      allocating request"), the request is passed to nvme_nvm_rqtocmd() before
      it is allocated.
      
      Fortunately, as of commit 91276162 ("lightnvm: refactor end_io
      functions for sync"), nvme_nvm_rqtocmd () no longer uses the passed
      request, so this warning is a false positive.
      
      Drop the unused parameter to clean up the code and kill the warning.
      
      Fixes: 2e13f33a ("lightnvm: create cmd before allocating request")
      Fixes: 91276162 ("lightnvm: refactor end_io functions for sync")
      Signed-off-by: NGeert Uytterhoeven <geert@linux-m68k.org>
      Signed-off-by: NJens Axboe <axboe@fb.com>
      629b1b2e
  6. 04 5月, 2017 1 次提交
  7. 02 5月, 2017 1 次提交
  8. 27 4月, 2017 1 次提交
  9. 26 4月, 2017 3 次提交
  10. 25 4月, 2017 3 次提交
  11. 24 4月, 2017 4 次提交
    • C
      nvme-fc: mark two symbols static · baee29ac
      Christoph Hellwig 提交于
      Found by sparse.
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      Reviewed-by: NJames Smart <james.smart@broadcom.com>
      Reviewed-by: NJohannes Thumshirn <jthumshirn@suse.de>
      baee29ac
    • J
      nvme_fc: add controller reset support · 61bff8ef
      James Smart 提交于
      This patch actually does quite a few things.  When looking to add
      controller reset support, the organization modeled after rdma was
      very fragmented. rdma duplicates the reset and teardown paths and does
      different things to the block layer on the two paths. The code to build
      up the controller is also duplicated between the initial creation and
      the reset/error recovery paths. So I decided to make this sane.
      
      I reorganized the controller creation and teardown so that there is a
      connect path and a disconnect path.  Initial creation obviously uses
      the connect path.  Controller teardown will use the disconnect path,
      followed last access code. Controller reset will use the disconnect
      path to stop operation, and then the connect path to re-establish
      the controller.
      
      Along the way, several things were fixed
      - aens were not properly set up. They are allocated differently from
        the per-request structure on the blk queues.
      - aens were oddly torn down. the prior patch corrected to abort, but
        we still need to dma unmap and free relative elements.
      - missed a few ref counting points: in aen completion and on i/o's
        that fail
      - controller initial create failure paths were still confused vs teardown
        before converting to ref counting vs after we convert to refcounting.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      61bff8ef
    • J
      nvme_fc: add aen abort to teardown · 78a7ac26
      James Smart 提交于
      Add abort support for aens. Commonized the op abort to apply to aen or
      real ios (caused some reorg/routine movement). Abort path sets termination
      flag in prep for next patch that will be watching i/o abort completion
      before proceeding with controller teardown.
      
      Now that we're aborting aens, the "exit" code that simply cleared out
      their context no longer applies.
      
      Also clarified how we detect an AEN vs a normal io - by a flag, not
      by whether a rq exists or the a rqno is out of range.
      
      Note: saw some interesting cases where if the queues are stopped and
      we're waiting for the aborts, the core layer can call the complete_rq
      callback for the io. So the io completion synchronizes link side completion
      with possible blk layer completion under error.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Reviewed-by: NSagi Grimberg <sagi@grimberg.me>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      78a7ac26
    • J
      nvme_fc: fix command id check · 458f280d
      James Smart 提交于
      The code validates the command_id in the response to the original
      sqe command. But prior code was using the rq->rqno as the sqe command
      id. The core layer overwrites what the transport set there originally.
      
      Use the actual sqe content.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Reviewed-by: NSagi Grimberg <sagi@grimberg.me>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      458f280d
  12. 21 4月, 2017 12 次提交