1.\" Copyright (c) 2009-2015 Alexander Motin <mav@FreeBSD.org> 2.\" Copyright (c) 2006 Marcus Alves Grando 3.\" Copyright (c) 1998-2001 Matthew Jacob, for NASA/Ames Research Center 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright 9.\" notice, this list of conditions and the following disclaimer. 10.\" 2. Redistributions in binary form must reproduce the above copyright 11.\" notice, this list of conditions and the following disclaimer in the 12.\" documentation and/or other materials provided with the distribution. 13.\" 3. The name of the author may not be used to endorse or promote products 14.\" derived from this software without specific prior written permission. 15.\" 16.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 20.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 21.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26.\" 27.\" $FreeBSD$ 28.\" 29.Dd November 22, 2015 30.Dt ISP 4 31.Os 32.Sh NAME 33.Nm isp 34.Nd Qlogic based SPI and FibreChannel SCSI Host Adapters 35.Sh SYNOPSIS 36To compile this driver into the kernel, 37place the following lines in your 38kernel configuration file: 39.Bd -ragged -offset indent 40.Cd "device scbus" 41.Cd "device isp" 42.Ed 43.Pp 44Alternatively, to load the driver as a 45module at boot time, place the following line in 46.Xr loader.conf 5 : 47.Bd -literal -offset indent 48isp_load="YES" 49.Ed 50.Sh DESCRIPTION 51This driver provides access to 52.Tn SPI 53or 54.Tn FibreChannel 55SCSI devices. 56.Pp 57SPI supports initiator mode for Ultra SCSI and wide mode transactions for 58.Tn SCSI , 59Ultra2 LVD (1080, 1280), and Ultra3 LVD (10160, 12160). 60.Pp 61Fibre Channel supports initiator and target modes of FCP SCSI profile, 62utilizing Class 3 and Class 2 (2200 and later) connections. 63Support is available for Public and Private loops, Point-to-Point 64and Fabric connections. 65.Sh FIRMWARE 66Firmware loading is supported if the 67.Xr ispfw 4 68module is loaded. 69It is strongly recommended that you use the firmware available from 70.Xr ispfw 4 71as it is the most likely to have been tested with this driver. 72.Sh HARDWARE 73Cards supported by the 74.Nm 75driver include: 76.Bl -tag -width xxxxxx -offset indent 77.It Qlogic 1000 78Fast Wide, Ultra Fast Wide cards, Single Ended or Differential SBus cards. 79.It Qlogic 1020 80Fast Wide and Differential Fast Wide SCSI PCI cards. 81.It Qlogic 1040 82Ultra Wide and Differential Ultra Wide SCSI PCI cards. 83Also known as the DEC KZPBA-CA (single ended) and KZPBA-CB (HVD differential). 84.It Qlogic 1080 85LVD Ultra2 Wide SCSI PCI cards. 86.It Qlogic 10160 87LVD Ultra3 Wide SCSI PCI cards. 88.It Qlogic 1240 89Dual Bus Ultra Wide and Differential Ultra Wide SCSI PCI cards. 90.It Qlogic 1280 91Dual Bus LVD Ultra2 Wide SCSI PCI cards. 92.It Qlogic 12160 93Dual Bus LVD Ultra3 Wide SCSI PCI cards. 94.It Qlogic 210X 95Copper and Optical Fibre Channel Arbitrated Loop PCI cards (single, dual). 96.It Qlogic 220X 97Copper and Optical Fibre Channel Arbitrated Loop PCI cards (single, dual, quad). 98.It Qlogic 2300 99Optical 2Gb Fibre Channel PCI cards. 100.It Qlogic 2312 101Optical 2Gb Fibre Channel PCI cards. 102.It Qlogic 234X 103Optical 2Gb Fibre Channel PCI cards (2312 chipset, single and dual attach). 104.It Qlogic 2322 105Optical 2Gb Fibre Channel PCIe cards. 106.It Qlogic 200 107Dell branded version of the QLogic 2312. 108.It Qlogic 2422 109Optical 4Gb Fibre Channel PCI cards. 110.It Qlogic 2432 111Optical 4Gb Fibre Channel PCIe cards. 112.It Qlogic 2532 113Optical 8Gb Fibre Channel PCIe cards. 114.El 115.Sh CONFIGURATION OPTIONS 116Target mode support for Fibre Channel adapters may be enabled with the 117.Pp 118.Cd options ISP_TARGET_MODE 119.Pp 120option. 121.Sh BOOT OPTIONS 122The following options are switchable by setting values in 123.Pa /boot/device.hints . 124.Pp 125They are: 126.Bl -tag -width indent 127.It Va hint.isp.0.disable 128A hint value to disable driver in kernel. 129.It Va hint.isp.0.fwload_disable 130A hint value to disable loading of firmware 131.Xr ispfw 4 . 132.It Va hint.isp.0.prefer_memmap 133A hint value to use PCI memory space instead of I/O space 134access for. 135.It Va hint.isp.0.prefer_iomap 136A hint value to use PCI I/O space instead of Memory space 137access for. 138.It Va hint.isp.0.ignore_nvram 139A hint value to ignore board NVRAM settings for. 140Otherwise use NVRAM settings. 141.It Va hint.isp.0.fullduplex 142A hint value to set full duplex mode. 143.It Va hint.isp.0.topology 144A hint value to select topology of connection. 145Supported values are: 146.Pp 147.Bl -tag -width ".Li lport-only" -compact 148.It Li lport 149Prefer loopback and fallback to point to point. 150.It Li nport 151Prefer point to point and fallback to loopback. 152.It Li lport-only 153Loopback only. 154.It Li nport-only 155Point to point only. 156.El 157.It Va hint.isp.0.portwwn 158This should be the full 64 bit World Wide Port Name you would like 159to use, overriding the value in NVRAM for the card. 160.It Va hint.isp.0.nodewwn 161This should be the full 64 bit World Wide Node Name you would like 162to use, overriding the value in NVRAM for the card. 163.It Va hint.isp.0.iid 164A hint to override or set the Initiator ID or Loop ID. 165For Fibre Channel 166cards in Local Loop topologies it is 167.Ar strongly 168recommended that you set this value to non-zero. 169.It Va hint.isp.0.role 170A hint to define default role for isp instance (0 -- none, 1 -- target, 1712 -- initiator, 3 -- both). 172.It Va hint.isp.0.debug 173A hint value for a driver debug level (see the file 174.Pa /usr/src/sys/dev/isp/ispvar.h 175for the values. 176.It Va hint.isp.0.vports 177A hint to create specified number of additional virtual ports. 178.El 179.Sh SYSCTL OPTIONS 180.Bl -tag -width indent 181.It Va dev.isp.N.loop_down_limit 182This value says how long to wait in seconds after loop has gone down before 183giving up and expiring all of the devices that were visible. 184The default is 300 seconds (5 minutes). 185A separate (nonadjustable) timeout is used when 186booting to not stop booting on lack of FC connectivity. 187.It Va dev.isp.N.gone_device_time 188This value says how long to wait for devices to reappear if they (temporarily) 189disappear due to loop or fabric events. 190While this timeout is running, I/O 191to those devices will simply be held. 192.It Va dev.isp.N.wwnn 193This is the readonly World Wide Node Name value for this port. 194.It Va dev.isp.N.wwpn 195This is the readonly World Wide Port Name value for this port. 196.El 197.Sh SEE ALSO 198.Xr da 4 , 199.Xr intro 4 , 200.Xr ispfw 4 , 201.Xr sa 4 , 202.Xr scsi 4 , 203.Xr gmultipath 8 204.Sh AUTHORS 205The 206.Nm 207driver was written by 208.An Matthew Jacob 209originally for NetBSD at NASA/Ames Research Center. 210Some later improvement was done by 211.An Alexander Motin Aq Mt mav@FreeBSD.org . 212.Sh BUGS 213The driver currently ignores some NVRAM settings. 214.Pp 215Fabric support for 2100 cards has been so problematic, and these cards are so 216old now that it is just not worth your time to try it. 217