1. 04 10月, 2017 2 次提交
    • J
      nvme-fc: create fc class and transport device · 5f568556
      James Smart 提交于
      Added a new fc class and a device node for udev events under it.  I
      expect the fc class will eventually be the location where the FC SCSI and
      FC NVME merge in the future. Therefore names are kept somewhat generic.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Reviewed-by: NJohannes Thumshirn <jthumshirn@suse.de>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      5f568556
    • J
      nvme-fc: add uevent for auto-connect · eaefd5ab
      James Smart 提交于
      To support auto-connecting to FC-NVME devices upon their dynamic
      appearance, add a uevent that can kick off connection scripts.
      uevent is posted against the fc_udev device.
      
      patch set tested with the following rule to kick an nvme-cli connect-all
      for the FC initiator and FC target ports. This is just an example for
      testing and not intended for real life use.
      
      ACTION=="change", SUBSYSTEM=="fc", ENV{FC_EVENT}=="nvmediscovery", \
              ENV{NVMEFC_HOST_TRADDR}=="*", ENV{NVMEFC_TRADDR}=="*", \
      	RUN+="/bin/sh -c '/usr/local/sbin/nvme connect-all --transport=fc --host-traddr=$env{NVMEFC_HOST_TRADDR} --traddr=$env{NVMEFC_TRADDR} >> /tmp/nvme_fc.log'"
      
      I will post proposed udev/systemd scripts for possible kernel support.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      eaefd5ab
  2. 25 9月, 2017 2 次提交
  3. 29 8月, 2017 2 次提交
    • J
      nvme-fc: Reattach to localports on re-registration · 5533d424
      James Smart 提交于
      If the LLDD resets or detaches from an fc port, the LLDD will
      deregister all remoteports seen by the fc port and deregister the
      localport associated with the fc port. The teardown of the localport
      structure will be held off due to reference counting until all the
      remoteports are removed (and they are held off until all
      controllers/associations to terminated). Currently, if the fc port
      is reinit/reattached and registered again as a localport it is
      treated as an independent entity from the prior localport and all
      prior remoteports and controllers cannot be revived. They are
      created as new and separate entities.
      
      This patch changes the localport registration to look at the known
      localports that are waiting to be torndown. If they are the same port
      based on wwn's, the local port is transitioned out of the teardown
      state.  This allows the remote ports and controller connections to
      be reestablished and resumed as long as the localport can also be
      reregistered within the timeout windows.
      
      The patch adds a new routine nvme_fc_attach_to_unreg_lport() with
      the functionality and moves the lport get/put routines to avoid
      forward references.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      5533d424
    • S
      nvme: Add admin_tagset pointer to nvme_ctrl · 34b6c231
      Sagi Grimberg 提交于
      Will be used when we centralize control flows.
      Signed-off-by: NSagi Grimberg <sagi@grimberg.me>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      34b6c231
  4. 18 8月, 2017 1 次提交
  5. 26 7月, 2017 1 次提交
    • J
      nvme-fc: revise TRADDR parsing · 9c5358e1
      James Smart 提交于
      The FC-NVME spec hasn't locked down on the format string for TRADDR.
      Currently the spec is lobbying for "nn-<16hexdigits>:pn-<16hexdigits>"
      where the wwn's are hex values but not prefixed by 0x.
      
      Most implementations so far expect a string format of
      "nn-0x<16hexdigits>:pn-0x<16hexdigits>" to be used. The transport
      uses the match_u64 parser which requires a leading 0x prefix to set
      the base properly. If it's not there, a match will either fail or return
      a base 10 value.
      
      The resolution in T11 is pushing out. Therefore, to fix things now and
      to cover any eventuality and any implementations already in the field,
      this patch adds support for both formats.
      
      The change consists of replacing the token matching routine with a
      routine that validates the fixed string format, and then builds
      a local copy of the hex name with a 0x prefix before calling
      the system parser.
      
      Note: the same parser routine exists in both the initiator and target
      transports. Given this is about the only "shared" item, we chose to
      replicate rather than create an interdendency on some shared code.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      9c5358e1
  6. 25 7月, 2017 1 次提交
    • J
      nvme-fc: address target disconnect race conditions in fcp io submit · 8b25f351
      James Smart 提交于
      There are cases where threads are in the process of submitting new
      io when the LLDD calls in to remove the remote port. In some cases,
      the next io actually goes to the LLDD, who knows the remoteport isn't
      present and rejects it. To properly recovery/restart these i/o's we
      don't want to hard fail them, we want to treat them as temporary
      resource errors in which a delayed retry will work.
      
      Add a couple more checks on remoteport connectivity and commonize the
      busy response handling when it's seen.
      Signed-off-by: NJames Smart <james.smart@broadcom.com>
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      8b25f351
  7. 06 7月, 2017 2 次提交
  8. 04 7月, 2017 3 次提交
  9. 02 7月, 2017 2 次提交
  10. 28 6月, 2017 6 次提交
  11. 15 6月, 2017 4 次提交
  12. 09 6月, 2017 1 次提交
  13. 07 6月, 2017 2 次提交
  14. 05 6月, 2017 1 次提交
  15. 26 5月, 2017 1 次提交
  16. 23 5月, 2017 6 次提交
  17. 21 5月, 2017 2 次提交
  18. 02 5月, 2017 1 次提交