target: Fix handling of aborted commands
authorRoland Dreier <roland@purestorage.com>
Fri, 16 Nov 2012 16:06:16 +0000 (08:06 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 10 Dec 2012 19:13:10 +0000 (11:13 -0800)
commitb9ad94e178314d2a9754bf304a971dc4bea2b0e7
treeeff9c85c75ac1e6d1251b58b9cfd20dde53c0342
parent499c579186da5243ff2cb9ab6fd3ab25fd9c6e0a
target: Fix handling of aborted commands

commit 3ea160b3e8f0de8161861995d9901f61192fc0b0 upstream.

- If we stop processing an already-aborted command in
  target_execute_cmd(), then we need to complete t_transport_stop_comp
  to wake up the the TMR handling thread, or else it will end up
  waiting forever.

- If we've a already sent an "aborted" status for a command in
  transport_check_aborted_status() then we should bail out of
  transport_send_task_abort() to avoid freeing the command twice.

Signed-off-by: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@risingtidesystems.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/target/target_core_transport.c