| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | * Device driver for the SYMBIOS/LSILOGIC 53C8XX and 53C1010 family | 
|  | 3 | * of PCI-SCSI IO processors. | 
|  | 4 | * | 
|  | 5 | * Copyright (C) 1999-2001  Gerard Roudier <groudier@free.fr> | 
|  | 6 | * | 
|  | 7 | * This driver is derived from the Linux sym53c8xx driver. | 
|  | 8 | * Copyright (C) 1998-2000  Gerard Roudier | 
|  | 9 | * | 
|  | 10 | * The sym53c8xx driver is derived from the ncr53c8xx driver that had been | 
|  | 11 | * a port of the FreeBSD ncr driver to Linux-1.2.13. | 
|  | 12 | * | 
|  | 13 | * The original ncr driver has been written for 386bsd and FreeBSD by | 
|  | 14 | *         Wolfgang Stanglmeier        <wolf@cologne.de> | 
|  | 15 | *         Stefan Esser                <se@mi.Uni-Koeln.de> | 
|  | 16 | * Copyright (C) 1994  Wolfgang Stanglmeier | 
|  | 17 | * | 
|  | 18 | * Other major contributions: | 
|  | 19 | * | 
|  | 20 | * NVRAM detection and reading. | 
|  | 21 | * Copyright (C) 1997 Richard Waltham <dormouse@farsrobt.demon.co.uk> | 
|  | 22 | * | 
|  | 23 | *----------------------------------------------------------------------------- | 
|  | 24 | * | 
|  | 25 | * This program is free software; you can redistribute it and/or modify | 
|  | 26 | * it under the terms of the GNU General Public License as published by | 
|  | 27 | * the Free Software Foundation; either version 2 of the License, or | 
|  | 28 | * (at your option) any later version. | 
|  | 29 | * | 
|  | 30 | * This program is distributed in the hope that it will be useful, | 
|  | 31 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | 32 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | 33 | * GNU General Public License for more details. | 
|  | 34 | * | 
|  | 35 | * You should have received a copy of the GNU General Public License | 
|  | 36 | * along with this program; if not, write to the Free Software | 
|  | 37 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
|  | 38 | */ | 
|  | 39 |  | 
|  | 40 | #ifndef SYM53C8XX_H | 
|  | 41 | #define SYM53C8XX_H | 
|  | 42 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 |  | 
|  | 44 | /* | 
|  | 45 | *  DMA addressing mode. | 
|  | 46 | * | 
|  | 47 | *  0 : 32 bit addressing for all chips. | 
|  | 48 | *  1 : 40 bit addressing when supported by chip. | 
|  | 49 | *  2 : 64 bit addressing when supported by chip, | 
|  | 50 | *      limited to 16 segments of 4 GB -> 64 GB max. | 
|  | 51 | */ | 
|  | 52 | #define	SYM_CONF_DMA_ADDRESSING_MODE CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE | 
|  | 53 |  | 
|  | 54 | /* | 
|  | 55 | *  NVRAM support. | 
|  | 56 | */ | 
|  | 57 | #if 1 | 
|  | 58 | #define SYM_CONF_NVRAM_SUPPORT		(1) | 
|  | 59 | #endif | 
|  | 60 |  | 
|  | 61 | /* | 
|  | 62 | *  These options are not tunable from 'make config' | 
|  | 63 | */ | 
|  | 64 | #if 1 | 
|  | 65 | #define	SYM_LINUX_PROC_INFO_SUPPORT | 
|  | 66 | #define SYM_LINUX_USER_COMMAND_SUPPORT | 
|  | 67 | #define SYM_LINUX_USER_INFO_SUPPORT | 
|  | 68 | #define SYM_LINUX_DEBUG_CONTROL_SUPPORT | 
|  | 69 | #endif | 
|  | 70 |  | 
|  | 71 | /* | 
|  | 72 | *  Also handle old NCR chips if not (0). | 
|  | 73 | */ | 
|  | 74 | #define SYM_CONF_GENERIC_SUPPORT	(1) | 
|  | 75 |  | 
|  | 76 | /* | 
|  | 77 | *  Allow tags from 2 to 256, default 8 | 
|  | 78 | */ | 
|  | 79 | #ifndef CONFIG_SCSI_SYM53C8XX_MAX_TAGS | 
|  | 80 | #define CONFIG_SCSI_SYM53C8XX_MAX_TAGS	(8) | 
|  | 81 | #endif | 
|  | 82 |  | 
|  | 83 | #if	CONFIG_SCSI_SYM53C8XX_MAX_TAGS < 2 | 
|  | 84 | #define SYM_CONF_MAX_TAG	(2) | 
|  | 85 | #elif	CONFIG_SCSI_SYM53C8XX_MAX_TAGS > 256 | 
|  | 86 | #define SYM_CONF_MAX_TAG	(256) | 
|  | 87 | #else | 
|  | 88 | #define	SYM_CONF_MAX_TAG	CONFIG_SCSI_SYM53C8XX_MAX_TAGS | 
|  | 89 | #endif | 
|  | 90 |  | 
|  | 91 | #ifndef	CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS | 
|  | 92 | #define	CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS	SYM_CONF_MAX_TAG | 
|  | 93 | #endif | 
|  | 94 |  | 
|  | 95 | /* | 
|  | 96 | *  Anyway, we configure the driver for at least 64 tags per LUN. :) | 
|  | 97 | */ | 
|  | 98 | #if	SYM_CONF_MAX_TAG <= 64 | 
|  | 99 | #define SYM_CONF_MAX_TAG_ORDER	(6) | 
|  | 100 | #elif	SYM_CONF_MAX_TAG <= 128 | 
|  | 101 | #define SYM_CONF_MAX_TAG_ORDER	(7) | 
|  | 102 | #else | 
|  | 103 | #define SYM_CONF_MAX_TAG_ORDER	(8) | 
|  | 104 | #endif | 
|  | 105 |  | 
|  | 106 | /* | 
|  | 107 | *  Max number of SG entries. | 
|  | 108 | */ | 
|  | 109 | #define SYM_CONF_MAX_SG		(96) | 
|  | 110 |  | 
|  | 111 | /* | 
|  | 112 | *  Driver setup structure. | 
|  | 113 | * | 
|  | 114 | *  This structure is initialized from linux config options. | 
|  | 115 | *  It can be overridden at boot-up by the boot command line. | 
|  | 116 | */ | 
|  | 117 | struct sym_driver_setup { | 
|  | 118 | u_short	max_tag; | 
|  | 119 | u_char	burst_order; | 
|  | 120 | u_char	scsi_led; | 
|  | 121 | u_char	scsi_diff; | 
|  | 122 | u_char	irq_mode; | 
|  | 123 | u_char	scsi_bus_check; | 
|  | 124 | u_char	host_id; | 
|  | 125 |  | 
|  | 126 | u_char	verbose; | 
|  | 127 | u_char	settle_delay; | 
|  | 128 | u_char	use_nvram; | 
|  | 129 | u_long	excludes[8]; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 130 | }; | 
|  | 131 |  | 
|  | 132 | #define SYM_SETUP_MAX_TAG		sym_driver_setup.max_tag | 
|  | 133 | #define SYM_SETUP_BURST_ORDER		sym_driver_setup.burst_order | 
|  | 134 | #define SYM_SETUP_SCSI_LED		sym_driver_setup.scsi_led | 
|  | 135 | #define SYM_SETUP_SCSI_DIFF		sym_driver_setup.scsi_diff | 
|  | 136 | #define SYM_SETUP_IRQ_MODE		sym_driver_setup.irq_mode | 
|  | 137 | #define SYM_SETUP_SCSI_BUS_CHECK	sym_driver_setup.scsi_bus_check | 
|  | 138 | #define SYM_SETUP_HOST_ID		sym_driver_setup.host_id | 
|  | 139 | #define boot_verbose			sym_driver_setup.verbose | 
|  | 140 |  | 
|  | 141 | /* | 
|  | 142 | *  Initial setup. | 
|  | 143 | * | 
|  | 144 | *  Can be overriden at startup by a command line. | 
|  | 145 | */ | 
|  | 146 | #define SYM_LINUX_DRIVER_SETUP	{				\ | 
|  | 147 | .max_tag	= CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS,	\ | 
|  | 148 | .burst_order	= 7,					\ | 
|  | 149 | .scsi_led	= 1,					\ | 
|  | 150 | .scsi_diff	= 1,					\ | 
|  | 151 | .irq_mode	= 0,					\ | 
|  | 152 | .scsi_bus_check	= 1,					\ | 
|  | 153 | .host_id	= 7,					\ | 
|  | 154 | .verbose	= 0,					\ | 
|  | 155 | .settle_delay	= 3,					\ | 
|  | 156 | .use_nvram	= 1,					\ | 
|  | 157 | } | 
|  | 158 |  | 
|  | 159 | extern struct sym_driver_setup sym_driver_setup; | 
|  | 160 | extern unsigned int sym_debug_flags; | 
|  | 161 | #define DEBUG_FLAGS	sym_debug_flags | 
|  | 162 |  | 
|  | 163 | /* | 
|  | 164 | *  Max number of targets. | 
|  | 165 | *  Maximum is 16 and you are advised not to change this value. | 
|  | 166 | */ | 
|  | 167 | #ifndef SYM_CONF_MAX_TARGET | 
|  | 168 | #define SYM_CONF_MAX_TARGET	(16) | 
|  | 169 | #endif | 
|  | 170 |  | 
|  | 171 | /* | 
|  | 172 | *  Max number of logical units. | 
|  | 173 | *  SPI-2 allows up to 64 logical units, but in real life, target | 
|  | 174 | *  that implements more that 7 logical units are pretty rare. | 
|  | 175 | *  Anyway, the cost of accepting up to 64 logical unit is low in | 
|  | 176 | *  this driver, thus going with the maximum is acceptable. | 
|  | 177 | */ | 
|  | 178 | #ifndef SYM_CONF_MAX_LUN | 
|  | 179 | #define SYM_CONF_MAX_LUN	(64) | 
|  | 180 | #endif | 
|  | 181 |  | 
|  | 182 | /* | 
|  | 183 | *  Max number of IO control blocks queued to the controller. | 
|  | 184 | *  Each entry needs 8 bytes and the queues are allocated contiguously. | 
|  | 185 | *  Since we donnot want to allocate more than a page, the theorical | 
|  | 186 | *  maximum is PAGE_SIZE/8. For safety, we announce a bit less to the | 
|  | 187 | *  access method. :) | 
|  | 188 | *  When not supplied, as it is suggested, the driver compute some | 
|  | 189 | *  good value for this parameter. | 
|  | 190 | */ | 
|  | 191 | /* #define SYM_CONF_MAX_START	(PAGE_SIZE/8 - 16) */ | 
|  | 192 |  | 
|  | 193 | /* | 
|  | 194 | *  Support for Immediate Arbitration. | 
|  | 195 | *  Not advised. | 
|  | 196 | */ | 
|  | 197 | /* #define SYM_CONF_IARB_SUPPORT */ | 
|  | 198 |  | 
|  | 199 | /* | 
|  | 200 | *  Only relevant if IARB support configured. | 
|  | 201 | *  - Max number of successive settings of IARB hints. | 
|  | 202 | *  - Set IARB on arbitration lost. | 
|  | 203 | */ | 
|  | 204 | #define SYM_CONF_IARB_MAX 3 | 
|  | 205 | #define SYM_CONF_SET_IARB_ON_ARB_LOST 1 | 
|  | 206 |  | 
|  | 207 | /* | 
|  | 208 | *  Returning wrong residuals may make problems. | 
|  | 209 | *  When zero, this define tells the driver to | 
|  | 210 | *  always return 0 as transfer residual. | 
|  | 211 | *  Btw, all my testings of residuals have succeeded. | 
|  | 212 | */ | 
|  | 213 | #define SYM_SETUP_RESIDUAL_SUPPORT 1 | 
|  | 214 |  | 
|  | 215 | #endif /* SYM53C8XX_H */ |