Merge branch 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/nab/target-pending
Pull SCSI target updates from Nicholas Bellinger:
"Here are the outstanding target-pending updates for v4.3-rc1.
Mostly bug-fixes and minor changes this round. The fallout from the
big v4.2-rc1 RCU conversion have (thus far) been minimal.
The highlights this round include:
- Move sense handling routines into scsi_common code (Sagi)
- Return ABORTED_COMMAND sense key for PI errors (Sagi)
- Add tpg_enabled_sendtargets attribute for disabled iscsi-target
discovery (David)
- Shrink target struct se_cmd by rearranging fields (Roland)
- Drop iSCSI use of mutex around max_cmd_sn increment (Roland)
- Replace iSCSI __kernel_sockaddr_storage with sockaddr_storage (Andy +
Chris)
- Honor fabric max_data_sg_nents I/O transfer limit (Arun + Himanshu +
nab)
- Fix EXTENDED_COPY >= v4.1 regression OOPsen (Alex + nab)"
* 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/nab/target-pending: (37 commits)
target: use stringify.h instead of own definition
target/user: Fix UFLAG_UNKNOWN_OP handling
target: Remove no-op conditional
target/user: Remove unused variable
target: Fix max_cmd_sn increment w/o cmdsn mutex regressions
target: Attach EXTENDED_COPY local I/O descriptors to xcopy_pt_sess
target/qla2xxx: Honor max_data_sg_nents I/O transfer limit
target/iscsi: Replace __kernel_sockaddr_storage with sockaddr_storage
target/iscsi: Replace conn->login_ip with login_sockaddr
target/iscsi: Keep local_ip as the actual sockaddr
target/iscsi: Fix np_ip bracket issue by removing np_ip
target: Drop iSCSI use of mutex around max_cmd_sn increment
qla2xxx: Update tcm_qla2xxx module description to 24xx+
iscsi-target: Add tpg_enabled_sendtargets for disabled discovery
drivers: target: Drop unlikely before IS_ERR(_OR_NULL)
target: check DPO/FUA usage for COMPARE AND WRITE
target: Shrink struct se_cmd by rearranging fields
target: Remove cmd->se_ordered_id (unused except debug log lines)
target: add support for START_STOP_UNIT SCSI opcode
target: improve unsupported opcode message
...
This commit is contained in:
@@ -33,6 +33,7 @@
|
||||
#include <scsi/scsi_device.h>
|
||||
#include <scsi/scsi_driver.h>
|
||||
#include <scsi/scsi_eh.h>
|
||||
#include <scsi/scsi_common.h>
|
||||
#include <scsi/scsi_transport.h>
|
||||
#include <scsi/scsi_host.h>
|
||||
#include <scsi/scsi_ioctl.h>
|
||||
@@ -2424,45 +2425,6 @@ bool scsi_command_normalize_sense(const struct scsi_cmnd *cmd,
|
||||
}
|
||||
EXPORT_SYMBOL(scsi_command_normalize_sense);
|
||||
|
||||
/**
|
||||
* scsi_sense_desc_find - search for a given descriptor type in descriptor sense data format.
|
||||
* @sense_buffer: byte array of descriptor format sense data
|
||||
* @sb_len: number of valid bytes in sense_buffer
|
||||
* @desc_type: value of descriptor type to find
|
||||
* (e.g. 0 -> information)
|
||||
*
|
||||
* Notes:
|
||||
* only valid when sense data is in descriptor format
|
||||
*
|
||||
* Return value:
|
||||
* pointer to start of (first) descriptor if found else NULL
|
||||
*/
|
||||
const u8 * scsi_sense_desc_find(const u8 * sense_buffer, int sb_len,
|
||||
int desc_type)
|
||||
{
|
||||
int add_sen_len, add_len, desc_len, k;
|
||||
const u8 * descp;
|
||||
|
||||
if ((sb_len < 8) || (0 == (add_sen_len = sense_buffer[7])))
|
||||
return NULL;
|
||||
if ((sense_buffer[0] < 0x72) || (sense_buffer[0] > 0x73))
|
||||
return NULL;
|
||||
add_sen_len = (add_sen_len < (sb_len - 8)) ?
|
||||
add_sen_len : (sb_len - 8);
|
||||
descp = &sense_buffer[8];
|
||||
for (desc_len = 0, k = 0; k < add_sen_len; k += desc_len) {
|
||||
descp += desc_len;
|
||||
add_len = (k < (add_sen_len - 1)) ? descp[1]: -1;
|
||||
desc_len = add_len + 2;
|
||||
if (descp[0] == desc_type)
|
||||
return descp;
|
||||
if (add_len < 0) // short descriptor ??
|
||||
break;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
EXPORT_SYMBOL(scsi_sense_desc_find);
|
||||
|
||||
/**
|
||||
* scsi_get_sense_info_fld - get information field from sense data (either fixed or descriptor format)
|
||||
* @sense_buffer: byte array of sense data
|
||||
@@ -2512,31 +2474,3 @@ int scsi_get_sense_info_fld(const u8 * sense_buffer, int sb_len,
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL(scsi_get_sense_info_fld);
|
||||
|
||||
/**
|
||||
* scsi_build_sense_buffer - build sense data in a buffer
|
||||
* @desc: Sense format (non zero == descriptor format,
|
||||
* 0 == fixed format)
|
||||
* @buf: Where to build sense data
|
||||
* @key: Sense key
|
||||
* @asc: Additional sense code
|
||||
* @ascq: Additional sense code qualifier
|
||||
*
|
||||
**/
|
||||
void scsi_build_sense_buffer(int desc, u8 *buf, u8 key, u8 asc, u8 ascq)
|
||||
{
|
||||
if (desc) {
|
||||
buf[0] = 0x72; /* descriptor, current */
|
||||
buf[1] = key;
|
||||
buf[2] = asc;
|
||||
buf[3] = ascq;
|
||||
buf[7] = 0;
|
||||
} else {
|
||||
buf[0] = 0x70; /* fixed, current */
|
||||
buf[2] = key;
|
||||
buf[7] = 0xa;
|
||||
buf[12] = asc;
|
||||
buf[13] = ascq;
|
||||
}
|
||||
}
|
||||
EXPORT_SYMBOL(scsi_build_sense_buffer);
|
||||
|
||||
Reference in New Issue
Block a user