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