Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 | /* * Device driver for the SYMBIOS/LSILOGIC 53C8XX and 53C1010 family * of PCI-SCSI IO processors. * * Copyright (C) 1999-2001 Gerard Roudier <groudier@free.fr> * * This driver is derived from the Linux sym53c8xx driver. * Copyright (C) 1998-2000 Gerard Roudier * * The sym53c8xx driver is derived from the ncr53c8xx driver that had been * a port of the FreeBSD ncr driver to Linux-1.2.13. * * The original ncr driver has been written for 386bsd and FreeBSD by * Wolfgang Stanglmeier <wolf@cologne.de> * Stefan Esser <se@mi.Uni-Koeln.de> * Copyright (C) 1994 Wolfgang Stanglmeier * * Other major contributions: * * NVRAM detection and reading. * Copyright (C) 1997 Richard Waltham <dormouse@farsrobt.demon.co.uk> * *----------------------------------------------------------------------------- * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * Where this Software is combined with software released under the terms of * the GNU Public License ("GPL") and the terms of the GPL would require the * combined work to also be released under the terms of the GPL, the terms * and conditions of this License will apply in addition to those of the * GPL with the exception of any terms or conditions of this License that * conflict with, or are expressly prohibited by, the GPL. * * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #ifndef SYM53C8XX_H #define SYM53C8XX_H #if !defined(LINUX_VERSION_CODE) #include <linux/version.h> #endif #include <linux/config.h> /* * Compatibility with ncr53c8xx and sym53c8xx configuration options. */ #ifndef CONFIG_SCSI_SYM53C8XX_IOMAPPED #ifdef CONFIG_SCSI_NCR53C8XX_IOMAPPED #define CONFIG_SCSI_SYM53C8XX_IOMAPPED CONFIG_SCSI_NCR53C8XX_IOMAPPED #endif #endif #ifndef CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS #ifdef CONFIG_SCSI_NCR53C8XX_DEFAULT_TAGS #define CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS CONFIG_SCSI_NCR53C8XX_DEFAULT_TAGS #endif #endif #ifndef CONFIG_SCSI_SYM53C8XX_MAX_TAGS #ifdef CONFIG_SCSI_NCR53C8XX_MAX_TAGS #define CONFIG_SCSI_SYM53C8XX_MAX_TAGS CONFIG_SCSI_NCR53C8XX_MAX_TAGS #endif #endif int sym53c8xx_detect(Scsi_Host_Template *tpnt); const char *sym53c8xx_info(struct Scsi_Host *host); int sym53c8xx_queue_command(Scsi_Cmnd *, void (*done)(Scsi_Cmnd *)); int sym53c8xx_eh_abort_handler(Scsi_Cmnd *); int sym53c8xx_eh_device_reset_handler(Scsi_Cmnd *); int sym53c8xx_eh_bus_reset_handler(Scsi_Cmnd *); int sym53c8xx_eh_host_reset_handler(Scsi_Cmnd *); #ifdef MODULE int sym53c8xx_release(struct Scsi_Host *); #else #define sym53c8xx_release NULL #endif /* * Host template defintion */ #if (LINUX_VERSION_CODE >= 0x020400) || defined(HOSTS_C) || defined(MODULE) #include <scsi/scsicam.h> #define SYM53C8XX { \ name: "sym53c8xx", \ detect: sym53c8xx_detect, \ release: sym53c8xx_release, \ info: sym53c8xx_info, \ queuecommand: sym53c8xx_queue_command, \ eh_abort_handler: sym53c8xx_eh_abort_handler, \ eh_device_reset_handler:sym53c8xx_eh_device_reset_handler, \ eh_bus_reset_handler: sym53c8xx_eh_bus_reset_handler, \ eh_host_reset_handler: sym53c8xx_eh_host_reset_handler, \ bios_param: scsicam_bios_param, \ can_queue: 0, \ this_id: 7, \ sg_tablesize: 0, \ cmd_per_lun: 0, \ use_clustering: DISABLE_CLUSTERING, \ highmem_io: 1} #endif /* defined(HOSTS_C) || defined(MODULE) */ /* * Translate kernel configuration parameters * into corresponding driver parameters. */ #if !defined(HOSTS_C) /* * Use normal IO if configured. * Normal IO forced for alpha. * Forced to MMIO for sparc. */ #if defined(__alpha__) #define SYM_CONF_IOMAPPED #elif defined(__sparc__) #undef SYM_CONF_IOMAPPED /* #elif defined(__powerpc__) */ /* #define SYM_CONF_IOMAPPED */ /* #define SYM_OPT_NO_BUS_MEMORY_MAPPING */ #elif defined(CONFIG_SCSI_SYM53C8XX_IOMAPPED) #define SYM_CONF_IOMAPPED #endif /* * DMA addressing mode. * * 0 : 32 bit addressing for all chips. * 1 : 40 bit addressing when supported by chip. * 2 : 64 bit addressing when supported by chip, * limited to 16 segments of 4 GB -> 64 GB max. */ #ifdef CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE #define SYM_CONF_DMA_ADDRESSING_MODE CONFIG_SCSI_SYM53C8XX_DMA_ADDRESSING_MODE #endif /* * NCR PQS/PDS special device support. */ #if 1 #define SYM_CONF_PQS_PDS_SUPPORT #endif /* * NVRAM support. */ #if 1 #define SYM_CONF_NVRAM_SUPPORT (1) #define SYM_SETUP_SYMBIOS_NVRAM (1) #define SYM_SETUP_TEKRAM_NVRAM (1) #endif /* * These options are not tunable from 'make config' */ #if 1 #define SYM_LINUX_PROC_INFO_SUPPORT #define SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT #define SYM_LINUX_USER_COMMAND_SUPPORT #define SYM_LINUX_USER_INFO_SUPPORT #define SYM_LINUX_DEBUG_CONTROL_SUPPORT #endif /* * Also handle old NCR chips if not (0). */ #define SYM_CONF_GENERIC_SUPPORT (1) /* * Allow tags from 2 to 256, default 8 */ #ifndef CONFIG_SCSI_SYM53C8XX_MAX_TAGS #define CONFIG_SCSI_SYM53C8XX_MAX_TAGS (8) #endif #if CONFIG_SCSI_SYM53C8XX_MAX_TAGS < 2 #define SYM_CONF_MAX_TAG (2) #elif CONFIG_SCSI_SYM53C8XX_MAX_TAGS > 256 #define SYM_CONF_MAX_TAG (256) #else #define SYM_CONF_MAX_TAG CONFIG_SCSI_SYM53C8XX_MAX_TAGS #endif #ifndef CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS #define CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS SYM_CONF_MAX_TAG #endif /* * Anyway, we configure the driver for at least 64 tags per LUN. :) */ #if SYM_CONF_MAX_TAG <= 64 #define SYM_CONF_MAX_TAG_ORDER (6) #elif SYM_CONF_MAX_TAG <= 128 #define SYM_CONF_MAX_TAG_ORDER (7) #else #define SYM_CONF_MAX_TAG_ORDER (8) #endif /* * Sync transfer frequency at startup. * Allow up to ULTRA-160. The driver will scale the value * according to controller capabilities. */ #define CONFIG_SCSI_SYM53C8XX_DEFAULT_SYNC (9) /* * Max number of SG entries. */ #define SYM_CONF_MAX_SG (96) /* * Max number of LUNs per target. */ #if 1 /* defined CONFIG_SCSI_MULTI_LUN */ #define CONFIG_SCSI_SYM53C8XX_MAX_LUN (16) #else #define CONFIG_SCSI_SYM53C8XX_MAX_LUN (1) #endif /* * Driver setup structure. * * This structure is initialized from linux config options. * It can be overridden at boot-up by the boot command line. */ struct sym_driver_setup { u_char pci_parity; u_char scsi_parity; u_short max_tag; u_char min_sync; u_char burst_order; u_char scsi_led; u_char max_wide; u_char scsi_diff; u_char irq_mode; u_char scsi_bus_check; u_char host_id; u_char max_offs; u_char max_lun; u_char pci_fix_up; u_char reverse_probe; u_char verbose; u_short debug; u_char settle_delay; u_char use_nvram; u_long excludes[8]; char tag_ctrl[100]; }; #define SYM_SETUP_PCI_PARITY sym_driver_setup.pci_parity #define SYM_SETUP_SCSI_PARITY sym_driver_setup.scsi_parity #define SYM_SETUP_MAX_TAG sym_driver_setup.max_tag #define SYM_SETUP_MIN_SYNC sym_driver_setup.min_sync #define SYM_SETUP_BURST_ORDER sym_driver_setup.burst_order #define SYM_SETUP_SCSI_LED sym_driver_setup.scsi_led #define SYM_SETUP_MAX_WIDE sym_driver_setup.max_wide #define SYM_SETUP_SCSI_DIFF sym_driver_setup.scsi_diff #define SYM_SETUP_IRQ_MODE sym_driver_setup.irq_mode #define SYM_SETUP_SCSI_BUS_CHECK sym_driver_setup.scsi_bus_check #define SYM_SETUP_HOST_ID sym_driver_setup.host_id #define SYM_SETUP_MAX_OFFS sym_driver_setup.max_offs #define SYM_SETUP_MAX_LUN sym_driver_setup.max_lun #define SYM_SETUP_PCI_FIX_UP sym_driver_setup.pci_fix_up /* * Initial setup. * * Can be overriden at startup by a command line. */ #define SYM_LINUX_DRIVER_SETUP \ { \ 1, /* pci_parity */ \ 1, /* scsi_parity */ \ CONFIG_SCSI_SYM53C8XX_DEFAULT_TAGS, \ CONFIG_SCSI_SYM53C8XX_DEFAULT_SYNC, \ 7, /* burst_order */ \ 1, /* scsi_led */ \ 1, /* max_wide */ \ 1, /* scsi_diff */ \ 0, /* irq_mode */ \ 1, /* scsi_bus_check */ \ 7, /* host_id */ \ 62, /* max_offs */ \ CONFIG_SCSI_SYM53C8XX_MAX_LUN, \ 3, /* pci_fix_up */ \ 0, /* reverse_probe */ \ 0, /* verbose */ \ 0, /* debug */ \ 3, /* settle_delay */ \ 1, /* use_nvram */ \ } /* * Boot fail safe setup. * * Override initial setup from boot command line: * sym53c8xx=safe:y */ #define SYM_LINUX_DRIVER_SAFE_SETUP \ { \ 0, /* pci_parity */ \ 0, /* scsi_parity */ \ 0, /* max_tag */ \ 50, /* min_sync */ \ 0, /* burst_order */ \ 0, /* scsi_led */ \ 1, /* max_wide */ \ 1, /* scsi_diff */ \ 0, /* irq_mode */ \ 2, /* scsi_bus_check */ \ 7, /* host_id */ \ 15, /* max_offs */ \ 1, /* max_lun */ \ 0, /* pci_fix_up */ \ 0, /* reverse_probe */ \ 2, /* verbose */ \ 0, /* debug */ \ 10, /* settle_delay */ \ 1, /* use_nvram */ \ } /* * This structure is initialized from linux config options. * It can be overridden at boot-up by the boot command line. */ #ifdef SYM_GLUE_C struct sym_driver_setup sym_driver_setup = SYM_LINUX_DRIVER_SETUP; #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT u_int sym_debug_flags = 0; #endif #else extern struct sym_driver_setup sym_driver_setup; #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT extern u_int sym_debug_flags; #endif #endif /* SYM_GLUE_C */ #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT #define DEBUG_FLAGS sym_debug_flags #endif #define boot_verbose sym_driver_setup.verbose #endif /* !defined(HOSTS_C) */ #endif /* SYM53C8XX_H */ |