target: Fix COMPARE_AND_WRITE with SG_TO_MEM_NOALLOC handling
authorNicholas Bellinger <nab@linux-iscsi.org>
Tue, 7 Apr 2015 21:53:27 +0000 (21:53 +0000)
committerSasha Levin <sasha.levin@oracle.com>
Sun, 17 May 2015 23:12:11 +0000 (19:12 -0400)
commitd71c65f44eb154106c2fae897fd58f1197c4a09c
treeddb846f1da4eed3960919eb967506b6685b4dd15
parent867af24da06080ffb12a2d0614e046bce917012e
target: Fix COMPARE_AND_WRITE with SG_TO_MEM_NOALLOC handling

[ Upstream commit c8e639852ad720499912acedfd6b072325fd2807 ]

This patch fixes a bug for COMPARE_AND_WRITE handling with
fabrics using SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC.

It adds the missing allocation for cmd->t_bidi_data_sg within
transport_generic_new_cmd() that is used by COMPARE_AND_WRITE
for the initial READ payload, even if the fabric is already
providing a pre-allocated buffer for cmd->t_data_sg.

Also, fix zero-length COMPARE_AND_WRITE handling within the
compare_and_write_callback() and target_complete_ok_work()
to queue the response, skipping the initial READ.

This fixes COMPARE_AND_WRITE emulation with loopback, vhost,
and xen-backend fabric drivers using SG_TO_MEM_NOALLOC.

Reported-by: Christoph Hellwig <hch@lst.de>
Cc: Christoph Hellwig <hch@lst.de>
Cc: <stable@vger.kernel.org> # v3.12+
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: Sasha Levin <sasha.levin@oracle.com>
drivers/target/target_core_sbc.c
drivers/target/target_core_transport.c
include/target/target_core_base.h