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