]> git.kernelconcepts.de Git - karo-tx-linux.git/commit
target: Fix MAINTENANCE_IN service action CDB checks to use lower 5 bits
authorNicholas Bellinger <nab@linux-iscsi.org>
Thu, 17 May 2012 04:52:10 +0000 (21:52 -0700)
committerBen Hutchings <ben@decadent.org.uk>
Thu, 25 Apr 2013 19:25:37 +0000 (20:25 +0100)
commitd801775a8e97920ab0399c987e3b128ad88f8a9d
tree32e8646a595179ebb0875e0c74a2de318baa7167
parent04de139ab01f8a7e1e2d28f27cb28054d64985f5
target: Fix MAINTENANCE_IN service action CDB checks to use lower 5 bits

commit ba539743b70cd160c84bab1c82910d0789b820f8 upstream.

This patch fixes the MAINTENANCE_IN service action type checks to only
look at the proper lower 5 bits of cdb byte 1.  This addresses the case
where MI_REPORT_TARGET_PGS w/ extended header using the upper three bits of
cdb byte 1 was not processed correctly in transport_generic_cmd_sequencer,
as well as the three cases for standby, unavailable, and transition ALUA
primary access state checks.

Also add MAINTENANCE_IN to the excluded list in transport_generic_prepare_cdb()
to prevent the PARAMETER DATA FORMAT bits from being cleared.

Cc: Hannes Reinecke <hare@suse.de>
Cc: Rob Evers <revers@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
drivers/target/target_core_alua.c
drivers/target/target_core_transport.c