From c9a12c7228d34e1fcac1bf2857ef11e5065a9dae Mon Sep 17 00:00:00 2001 From: Nicholas Bellinger Date: Thu, 29 Sep 2011 14:22:13 -0700 Subject: [PATCH] --- yaml --- r: 264663 b: refs/heads/master c: c252f003470a99d319db4ebd12f4a9e4710a65db h: refs/heads/master i: 264661: d5c149d87b11654ddd51df993c4bd49a81531e09 264659: f80ecceed7cff10ae0012b01f71b9cc5891fd477 264655: 79c62d74e11f9b2946332bd8813aae7fd4935838 v: v3 --- [refs] | 2 +- trunk/drivers/target/target_core_transport.c | 9 +++++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 93a42807f4db..d242c6bede1b 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 77039d1eafbbc192df71ee84b157b8973766737d +refs/heads/master: c252f003470a99d319db4ebd12f4a9e4710a65db diff --git a/trunk/drivers/target/target_core_transport.c b/trunk/drivers/target/target_core_transport.c index 009547b35574..af1e0a5f9bc6 100644 --- a/trunk/drivers/target/target_core_transport.c +++ b/trunk/drivers/target/target_core_transport.c @@ -4919,6 +4919,15 @@ EXPORT_SYMBOL(transport_check_aborted_status); void transport_send_task_abort(struct se_cmd *cmd) { + unsigned long flags; + + spin_lock_irqsave(&cmd->t_state_lock, flags); + if (cmd->se_cmd_flags & SCF_SENT_CHECK_CONDITION) { + spin_unlock_irqrestore(&cmd->t_state_lock, flags); + return; + } + spin_unlock_irqrestore(&cmd->t_state_lock, flags); + /* * If there are still expected incoming fabric WRITEs, we wait * until until they have completed before sending a TASK_ABORTED