[PATCH v4 00/37] SCSI target patches for kernel v4.11

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The most important changes in this patch series are:
* ABORT and LUN RESET handling is made synchronous.
* LUN lookup during ABORT handling is moved from the tcm_qla2xxx
  driver into the target core.
* A deadlock in the XCOPY implementation has been fixed.
* The SCSI target core is simplified significantly.

These patches have been tested against the iSCSI, ib_srpt and
tcm_qla2xxx target drivers.

Please review the patches that have not yet been reviewed,

Thanks,

Bart.

The changes compared to v3 are:
- The TMF workqueue initialization code has been moved from
  transport_alloc_session_tags() into transport_init_session() such that
  this queue is created for all types of sessions.
- The transport_wait_for_tasks() documentation no longer duplicates
  information that can be derived easily from the implementation of that
  function.
- Explained how the newly added return statement can be triggered in the
  description of patch "target: Stop execution if CMD_T_STOP has been set".
- Combined two patches into the new patch "target: Use the command
  reference counting mechanism consistently".
- Added a new patch "target: Move session check from target_put_sess_cmd()
  into target_release_cmd_kref()".
- Separated the target core refcnt from the target driver refcnt. See also
  "target: Introduce a target driver reference count per command".
- Dropped a TMF check from the patch that makes TMF handling synchronous.
  In the same patch a facility for showing the state of pending commands has
  been added and a command reference leak has been fixed in target_execute_cmd()
  (see also the transport_handle_abort() call added in that function).
- A new patch has been added: "target: Simplify session shutdown tests".
- transport_generic_free_cmd() has been modified such that it waits again
  for aborted commands until all tasks have completed.
- A bug in the XCOPY deadlock fix has been fixed, namely that that code no
  longer tries to increase the reference count of a device if that reference
  count had dropped to zero.

Changes between v2 and v3:
- Avoid that transport_free_session() can trigger a NULL pointer dereference.

Changes between v1 and v2:
- Introduced a new workqueue per session for task management functions.
- Renamed tmr_wq into alua_wq.

Bart Van Assche (37):
  target/iscsi: Fix spelling of "perform"
  target/iscsi: Fix spelling of "reallegiance"
  target/iscsi: Introduce a helper function for TMF translation
  target/iscsi: Fix iSCSI task reassignment handling
  target: Remove se_tmr_req.tmr_lun
  target: Make core_tmr_abort_task() consider all commands
  target: Introduce a new workqueue for TMF processing
  target: Rename tmr_wq into alua_wq
  target: Make it possible to specify I_T nexus for SCSI abort
  tcm_qla2xxx: Let the target core look up the LUN of the aborted cmd
  target: Correct transport_wait_for_tasks() documentation
  target: Remove an overly chatty debug message
  target: Stop execution if CMD_T_STOP has been set
  target: Use the command reference counting mechanism consistently
  target: Inline transport_cmd_check_stop()
  target: Move session check from target_put_sess_cmd() into
    target_release_cmd_kref()
  target: Introduce a target driver reference count per command
  target: Make ABORT and LUN RESET handling synchronous
  target: Simplify session shutdown tests
  target: Simplify session shutdown code
  target: Remove the SCF_SEND_DELAYED_TAS command flag
  target: Inline transport_check_aborted_status()
  target: Remove the write_pending_status() callback function
  target: Remove several state tests from TMF code
  target: Remove command flag CMD_T_BUSY
  target: Simplify LUN RESET implementation
  target: Remove command flag CMD_T_DEV_ACTIVE
  target: Reduce number of __transport_wait_for_tasks() arguments
  target: Remove command flag CMD_T_TAS
  target: Remove unused arguments from __target_check_io_state()
  target: Change return type of transport_wait_for_tasks() into void
  target: Inline transport_put_cmd()
  target: Inline transport_lun_remove_cmd()
  target: Move target_remove_from_state_list() into
    target_release_cmd_kref()
  configfs: Introduce config_item_get_unless_zero()
  target: Introduce target_get_device() and target_put_device()
  target: Avoid that XCOPY commands trigger a deadlock

 Documentation/target/tcm_mod_builder.py      |   8 -
 drivers/infiniband/ulp/srpt/ib_srpt.c        |  12 +-
 drivers/scsi/ibmvscsi_tgt/ibmvscsi_tgt.c     |   6 -
 drivers/scsi/qla2xxx/qla_target.c            |  66 ++-
 drivers/scsi/qla2xxx/qla_target.h            |   2 +-
 drivers/scsi/qla2xxx/tcm_qla2xxx.c           |  38 +-
 drivers/target/iscsi/iscsi_target.c          |  80 ++--
 drivers/target/iscsi/iscsi_target_configfs.c |  13 -
 drivers/target/iscsi/iscsi_target_erl1.c     |   8 +-
 drivers/target/iscsi/iscsi_target_erl2.c     |   6 +-
 drivers/target/iscsi/iscsi_target_erl2.h     |   2 +-
 drivers/target/iscsi/iscsi_target_login.c    |   2 +-
 drivers/target/iscsi/iscsi_target_tmr.c      |   4 +-
 drivers/target/loopback/tcm_loop.c           |   6 -
 drivers/target/sbp/sbp_target.c              |   6 -
 drivers/target/target_core_alua.c            |   4 +-
 drivers/target/target_core_configfs.c        |   4 -
 drivers/target/target_core_device.c          |  25 +-
 drivers/target/target_core_internal.h        |   6 +-
 drivers/target/target_core_sbc.c             |   2 +-
 drivers/target/target_core_tmr.c             | 144 +++----
 drivers/target/target_core_transport.c       | 584 +++++++++++----------------
 drivers/target/target_core_xcopy.c           |  49 ++-
 drivers/target/tcm_fc/tcm_fc.h               |   1 -
 drivers/target/tcm_fc/tfc_cmd.c              |   7 -
 drivers/target/tcm_fc/tfc_conf.c             |   1 -
 drivers/usb/gadget/function/f_tcm.c          |   9 -
 drivers/vhost/scsi.c                         |   6 -
 drivers/xen/xen-scsiback.c                   |   6 -
 fs/configfs/item.c                           |   6 +
 include/linux/configfs.h                     |   1 +
 include/target/target_core_base.h            |  17 +-
 include/target/target_core_fabric.h          |   6 +-
 33 files changed, 430 insertions(+), 707 deletions(-)

-- 
2.11.0

--
To unsubscribe from this list: send the line "unsubscribe target-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux SCSI]     [Kernel Newbies]     [Linux SCSI Target Infrastructure]     [Share Photos]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Device Mapper]

  Powered by Linux