svn commit: r284641 - head/sys/cam/ctl
Alexander Motin
mav at FreeBSD.org
Sat Jun 20 13:02:58 UTC 2015
Author: mav
Date: Sat Jun 20 13:02:57 2015
New Revision: 284641
URL: https://svnweb.freebsd.org/changeset/base/284641
Log:
Fix REPORT LUNS command output for the case when same LUN mapped to same
port several times. While it is unusual configuration, it is not illegal.
MFC after: 1 week
Modified:
head/sys/cam/ctl/ctl.c
Modified: head/sys/cam/ctl/ctl.c
==============================================================================
--- head/sys/cam/ctl/ctl.c Sat Jun 20 12:43:54 2015 (r284640)
+++ head/sys/cam/ctl/ctl.c Sat Jun 20 13:02:57 2015 (r284641)
@@ -9348,11 +9348,16 @@ ctl_report_luns(struct ctl_scsiio *ctsio
well_known = 0;
cdb = (struct scsi_report_luns *)ctsio->cdb;
+ port = ctl_io_port(&ctsio->io_hdr);
CTL_DEBUG_PRINT(("ctl_report_luns\n"));
mtx_lock(&softc->ctl_lock);
- num_luns = softc->num_luns;
+ num_luns = 0;
+ for (targ_lun_id = 0; targ_lun_id < CTL_MAX_LUNS; targ_lun_id++) {
+ if (ctl_lun_map_from_port(port, targ_lun_id) < CTL_MAX_LUNS)
+ num_luns++;
+ }
mtx_unlock(&softc->ctl_lock);
switch (cdb->select_report) {
@@ -9395,7 +9400,6 @@ ctl_report_luns(struct ctl_scsiio *ctsio
request_lun = (struct ctl_lun *)
ctsio->io_hdr.ctl_private[CTL_PRIV_LUN].ptr;
- port = ctl_io_port(&ctsio->io_hdr);
lun_datalen = sizeof(*lun_data) +
(num_luns * sizeof(struct scsi_report_luns_lundata));
More information about the svn-src-all
mailing list