diff options
author | Nicholas Bellinger <nab@linux-iscsi.org> | 2014-03-22 17:55:56 -0400 |
---|---|---|
committer | Nicholas Bellinger <nab@linux-iscsi.org> | 2014-04-07 04:48:51 -0400 |
commit | 131e6abc674edb9f9a59090bb35bf6650569b7e7 (patch) | |
tree | 3baa38894c61d5fca1a99ae91a7ba9986c570d34 /drivers/usb | |
parent | 68259b5aac13a57cba797b9605ed9812158f0e72 (diff) |
target: Add TFO->abort_task for aborted task resources release
Now that TASK_ABORTED status is not generated for all cases by
TMR ABORT_TASK + LUN_RESET, a new TFO->abort_task() caller is
necessary in order to give fabric drivers a chance to unmap
hardware / software resources before the se_cmd descriptor is
released via the normal TFO->release_cmd() codepath.
This patch adds TFO->aborted_task() in core_tmr_abort_task()
in place of the original transport_send_task_abort(), and
also updates all fabric drivers to implement this caller.
The fabric drivers that include changes to perform cleanup
via ->aborted_task() are:
- iscsi-target
- iser-target
- srpt
- tcm_qla2xxx
The fabric drivers that currently set ->aborted_task() to
NOPs are:
- loopback
- tcm_fc
- usb-gadget
- sbp-target
- vhost-scsi
For the latter five, there appears to be no additional cleanup
required before invoking TFO->release_cmd() to release the
se_cmd descriptor.
v2 changes:
- Move ->aborted_task() call into transport_cmd_finish_abort (Alex)
Cc: Alex Leung <amleung21@yahoo.com>
Cc: Mark Rustad <mark.d.rustad@intel.com>
Cc: Roland Dreier <roland@kernel.org>
Cc: Vu Pham <vu@mellanox.com>
Cc: Chris Boot <bootc@bootc.net>
Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Cc: Michael S. Tsirkin <mst@redhat.com>
Cc: Giridhar Malavali <giridhar.malavali@qlogic.com>
Cc: Saurav Kashyap <saurav.kashyap@qlogic.com>
Cc: Quinn Tran <quinn.tran@qlogic.com>
Cc: Sagi Grimberg <sagig@mellanox.com>
Cc: Or Gerlitz <ogerlitz@mellanox.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/gadget/tcm_usb_gadget.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/usb/gadget/tcm_usb_gadget.c b/drivers/usb/gadget/tcm_usb_gadget.c index 0f8aad78b54f..f9afa4a4ec3c 100644 --- a/drivers/usb/gadget/tcm_usb_gadget.c +++ b/drivers/usb/gadget/tcm_usb_gadget.c | |||
@@ -1471,6 +1471,11 @@ static void usbg_queue_tm_rsp(struct se_cmd *se_cmd) | |||
1471 | { | 1471 | { |
1472 | } | 1472 | } |
1473 | 1473 | ||
1474 | static void usbg_aborted_task(struct se_cmd *se_cmd) | ||
1475 | { | ||
1476 | return; | ||
1477 | } | ||
1478 | |||
1474 | static const char *usbg_check_wwn(const char *name) | 1479 | static const char *usbg_check_wwn(const char *name) |
1475 | { | 1480 | { |
1476 | const char *n; | 1481 | const char *n; |
@@ -1897,6 +1902,7 @@ static struct target_core_fabric_ops usbg_ops = { | |||
1897 | .queue_data_in = usbg_send_read_response, | 1902 | .queue_data_in = usbg_send_read_response, |
1898 | .queue_status = usbg_send_status_response, | 1903 | .queue_status = usbg_send_status_response, |
1899 | .queue_tm_rsp = usbg_queue_tm_rsp, | 1904 | .queue_tm_rsp = usbg_queue_tm_rsp, |
1905 | .aborted_task = usbg_aborted_task, | ||
1900 | .check_stop_free = usbg_check_stop_free, | 1906 | .check_stop_free = usbg_check_stop_free, |
1901 | 1907 | ||
1902 | .fabric_make_wwn = usbg_make_tport, | 1908 | .fabric_make_wwn = usbg_make_tport, |