svn commit: r287866 - head/sys/cam/scsi
Alexander Motin
mav at FreeBSD.org
Wed Sep 16 17:56:25 UTC 2015
Author: mav
Date: Wed Sep 16 17:56:24 2015
New Revision: 287866
URL: https://svnweb.freebsd.org/changeset/base/287866
Log:
Fix fixed sense writing when passed more data then it can fit.
MFC after: 1 week
Modified:
head/sys/cam/scsi/scsi_all.c
Modified: head/sys/cam/scsi/scsi_all.c
==============================================================================
--- head/sys/cam/scsi/scsi_all.c Wed Sep 16 17:44:45 2015 (r287865)
+++ head/sys/cam/scsi/scsi_all.c Wed Sep 16 17:56:24 2015 (r287866)
@@ -3804,8 +3804,6 @@ scsi_set_sense_data_va(struct scsi_sense
*/
sense->extra_len = 10;
sense_len = (int)va_arg(ap, int);
- len_to_copy = MIN(sense_len, SSD_EXTRA_MAX -
- sense->extra_len);
data = (uint8_t *)va_arg(ap, uint8_t *);
switch (elem_type) {
@@ -3823,10 +3821,14 @@ scsi_set_sense_data_va(struct scsi_sense
uint8_t *data_dest;
int i;
- if (elem_type == SSD_ELEM_COMMAND)
+ if (elem_type == SSD_ELEM_COMMAND) {
data_dest = &sense->cmd_spec_info[0];
- else {
+ len_to_copy = MIN(sense_len,
+ sizeof(sense->cmd_spec_info));
+ } else {
data_dest = &sense->info[0];
+ len_to_copy = MIN(sense_len,
+ sizeof(sense->info));
/*
* We're setting the info field, so
* set the valid bit.
More information about the svn-src-head
mailing list