summaryrefslogtreecommitdiffstats
path: root/sys/cam
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2014-10-23 07:37:48 +0000
committermav <mav@FreeBSD.org>2014-10-23 07:37:48 +0000
commit9d96d4ad456bb1d6185c8b52be2b43da186ff04d (patch)
tree7f2a9c9b9964491697dddbe5d47a41960d85be4d /sys/cam
parentb118502c8febc07a1a42036ec9ee4cac4370e646 (diff)
downloadFreeBSD-src-9d96d4ad456bb1d6185c8b52be2b43da186ff04d.zip
FreeBSD-src-9d96d4ad456bb1d6185c8b52be2b43da186ff04d.tar.gz
MFC r273259:
Make VPD 80h (Serial Number) transfer length match serial number length.
Diffstat (limited to 'sys/cam')
-rw-r--r--sys/cam/ctl/ctl.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/sys/cam/ctl/ctl.c b/sys/cam/ctl/ctl.c
index 97b2d67..31e7c33 100644
--- a/sys/cam/ctl/ctl.c
+++ b/sys/cam/ctl/ctl.c
@@ -9963,17 +9963,17 @@ ctl_inquiry_evpd_serial(struct ctl_scsiio *ctsio, int alloc_len)
{
struct scsi_vpd_unit_serial_number *sn_ptr;
struct ctl_lun *lun;
+ int data_len;
lun = (struct ctl_lun *)ctsio->io_hdr.ctl_private[CTL_PRIV_LUN].ptr;
- ctsio->kern_data_ptr = malloc(sizeof(*sn_ptr), M_CTL, M_WAITOK | M_ZERO);
+ data_len = 4 + CTL_SN_LEN;
+ ctsio->kern_data_ptr = malloc(data_len, M_CTL, M_WAITOK | M_ZERO);
sn_ptr = (struct scsi_vpd_unit_serial_number *)ctsio->kern_data_ptr;
- ctsio->kern_sg_entries = 0;
-
- if (sizeof(*sn_ptr) < alloc_len) {
- ctsio->residual = alloc_len - sizeof(*sn_ptr);
- ctsio->kern_data_len = sizeof(*sn_ptr);
- ctsio->kern_total_len = sizeof(*sn_ptr);
+ if (data_len < alloc_len) {
+ ctsio->residual = alloc_len - data_len;
+ ctsio->kern_data_len = data_len;
+ ctsio->kern_total_len = data_len;
} else {
ctsio->residual = 0;
ctsio->kern_data_len = alloc_len;
@@ -9995,16 +9995,16 @@ ctl_inquiry_evpd_serial(struct ctl_scsiio *ctsio, int alloc_len)
sn_ptr->device = (SID_QUAL_LU_OFFLINE << 5) | T_DIRECT;
sn_ptr->page_code = SVPD_UNIT_SERIAL_NUMBER;
- sn_ptr->length = ctl_min(sizeof(*sn_ptr) - 4, CTL_SN_LEN);
+ sn_ptr->length = CTL_SN_LEN;
/*
* If we don't have a LUN, we just leave the serial number as
* all spaces.
*/
- memset(sn_ptr->serial_num, 0x20, sizeof(sn_ptr->serial_num));
if (lun != NULL) {
strncpy((char *)sn_ptr->serial_num,
(char *)lun->be_lun->serial_num, CTL_SN_LEN);
- }
+ } else
+ memset(sn_ptr->serial_num, 0x20, CTL_SN_LEN);
ctsio->scsi_status = SCSI_STATUS_OK;
ctsio->io_hdr.flags |= CTL_FLAG_ALLOCATED;
OpenPOWER on IntegriCloud