2 * Device driver for the SYMBIOS/LSILOGIC 53C8XX and 53C1010 family
3 * of PCI-SCSI IO processors.
5 * Copyright (C) 1999-2001 Gerard Roudier <groudier@free.fr>
7 * This driver is derived from the Linux sym53c8xx driver.
8 * Copyright (C) 1998-2000 Gerard Roudier
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.
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
18 * Other major contributions:
20 * NVRAM detection and reading.
21 * Copyright (C) 1997 Richard Waltham <dormouse@farsrobt.demon.co.uk>
23 *-----------------------------------------------------------------------------
25 * Redistribution and use in source and binary forms, with or without
26 * modification, are permitted provided that the following conditions
28 * 1. Redistributions of source code must retain the above copyright
29 * notice, this list of conditions and the following disclaimer.
30 * 2. The name of the author may not be used to endorse or promote products
31 * derived from this software without specific prior written permission.
33 * Where this Software is combined with software released under the terms of
34 * the GNU Public License ("GPL") and the terms of the GPL would require the
35 * combined work to also be released under the terms of the GPL, the terms
36 * and conditions of this License will apply in addition to those of the
37 * GPL with the exception of any terms or conditions of this License that
38 * conflict with, or are expressly prohibited by, the GPL.
40 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
41 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
44 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
45 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
46 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
48 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
49 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
54 #include <linux/module.h>
57 #define NAME53C "sym53c"
58 #define NAME53C8XX "sym53c8xx"
61 * Simple Wrapper to kernel PCI bus interface.
64 typedef struct pci_dev *pcidev_t;
65 #define PCIDEV_NULL (0)
66 #define PciBusNumber(d) (d)->bus->number
67 #define PciDeviceFn(d) (d)->devfn
68 #define PciVendorId(d) (d)->vendor
69 #define PciDeviceId(d) (d)->device
70 #define PciIrqLine(d) (d)->irq
73 pci_get_base_cookie(struct pci_dev *pdev, int index)
77 #if LINUX_VERSION_CODE > LinuxVersionCode(2,3,12)
78 base = pdev->resource[index].start;
80 base = pdev->base_address[index];
81 #if BITS_PER_LONG > 32
82 if ((base & 0x7) == 0x4)
83 base |= (((u_long)pdev->base_address[++index]) << 32);
86 return (base & ~0x7ul);
90 pci_get_base_address(struct pci_dev *pdev, int index, u_long *base)
93 #define PCI_BAR_OFFSET(index) (PCI_BASE_ADDRESS_0 + (index<<2))
95 pci_read_config_dword(pdev, PCI_BAR_OFFSET(index), &tmp);
98 if ((tmp & 0x7) == 0x4) {
99 #if BITS_PER_LONG > 32
100 pci_read_config_dword(pdev, PCI_BAR_OFFSET(index), &tmp);
101 *base |= (((u_long)tmp) << 32);
106 #undef PCI_BAR_OFFSET
109 #if LINUX_VERSION_CODE < LinuxVersionCode(2,4,0)
110 #define pci_enable_device(pdev) (0)
113 #if LINUX_VERSION_CODE < LinuxVersionCode(2,4,4)
114 #define scsi_set_pci_device(inst, pdev) do { ;} while (0)
118 * Insert a delay in micro-seconds and milli-seconds.
120 void sym_udelay(int us) { udelay(us); }
121 void sym_mdelay(int ms) { mdelay(ms); }
126 * The whole SCSI sub-system under Linux is basically single-threaded.
127 * Everything, including low-level driver interrupt routine, happens
128 * with the `io_request_lock' held.
129 * The sym53c8xx-1.x drivers series ran their interrupt code using a
130 * spin mutex per controller. This added complexity without improving
131 * scalability significantly. the sym-2 driver still use a spinlock
132 * per controller for safety, but basically runs with the damned
133 * io_request_lock held.
136 spinlock_t sym53c8xx_lock = SPIN_LOCK_UNLOCKED;
138 #define SYM_LOCK_DRIVER(flags) spin_lock_irqsave(&sym53c8xx_lock, flags)
139 #define SYM_UNLOCK_DRIVER(flags) spin_unlock_irqrestore(&sym53c8xx_lock,flags)
141 #define SYM_INIT_LOCK_HCB(np) spin_lock_init(&np->s.smp_lock);
142 #define SYM_LOCK_HCB(np, flags) spin_lock_irqsave(&np->s.smp_lock, flags)
143 #define SYM_UNLOCK_HCB(np, flags) spin_unlock_irqrestore(&np->s.smp_lock, flags)
145 #define SYM_LOCK_SCSI(np, flags) \
146 spin_lock_irqsave(&io_request_lock, flags)
147 #define SYM_UNLOCK_SCSI(np, flags) \
148 spin_unlock_irqrestore(&io_request_lock, flags)
150 /* Ugly, but will make things easier if this locking will ever disappear */
151 #define SYM_LOCK_SCSI_NOSAVE(np) spin_lock_irq(&io_request_lock)
152 #define SYM_UNLOCK_SCSI_NORESTORE(np) spin_unlock_irq(&io_request_lock)
155 * These simple macros limit expression involving
156 * kernel time values (jiffies) to some that have
157 * chance not to be too much incorrect. :-)
159 #define ktime_get(o) (jiffies + (u_long) o)
160 #define ktime_exp(b) ((long)(jiffies) - (long)(b) >= 0)
161 #define ktime_dif(a, b) ((long)(a) - (long)(b))
162 #define ktime_add(a, o) ((a) + (u_long)(o))
163 #define ktime_sub(a, o) ((a) - (u_long)(o))
166 * Wrappers to the generic memory allocator.
168 void *sym_calloc(int size, char *name)
172 SYM_LOCK_DRIVER(flags);
173 m = sym_calloc_unlocked(size, name);
174 SYM_UNLOCK_DRIVER(flags);
178 void sym_mfree(void *m, int size, char *name)
181 SYM_LOCK_DRIVER(flags);
182 sym_mfree_unlocked(m, size, name);
183 SYM_UNLOCK_DRIVER(flags);
186 #ifdef SYM_LINUX_DYNAMIC_DMA_MAPPING
188 void *__sym_calloc_dma(m_pool_ident_t dev_dmat, int size, char *name)
192 SYM_LOCK_DRIVER(flags);
193 m = __sym_calloc_dma_unlocked(dev_dmat, size, name);
194 SYM_UNLOCK_DRIVER(flags);
198 void __sym_mfree_dma(m_pool_ident_t dev_dmat, void *m, int size, char *name)
201 SYM_LOCK_DRIVER(flags);
202 __sym_mfree_dma_unlocked(dev_dmat, m, size, name);
203 SYM_UNLOCK_DRIVER(flags);
206 m_addr_t __vtobus(m_pool_ident_t dev_dmat, void *m)
210 SYM_LOCK_DRIVER(flags);
211 b = __vtobus_unlocked(dev_dmat, m);
212 SYM_UNLOCK_DRIVER(flags);
216 #endif /* SYM_LINUX_DYNAMIC_DMA_MAPPING */
220 * Map/unmap a PCI memory window.
222 #ifndef SYM_OPT_NO_BUS_MEMORY_MAPPING
223 static u_long __init pci_map_mem(u_long base, u_long size)
225 u_long page_base = ((u_long) base) & PAGE_MASK;
226 u_long page_offs = ((u_long) base) - page_base;
227 u_long page_remapped;
229 spin_unlock_irq(&io_request_lock);
230 page_remapped = (u_long) ioremap(page_base, page_offs+size);
231 spin_lock_irq(&io_request_lock);
233 return page_remapped? (page_remapped + page_offs) : 0UL;
236 static void pci_unmap_mem(u_long vaddr,
238 int holding_io_request_lock)
241 if (holding_io_request_lock)
242 spin_unlock_irq(&io_request_lock);
243 iounmap((void *) (vaddr & PAGE_MASK));
244 if (holding_io_request_lock)
245 spin_lock_irq(&io_request_lock);
251 * Used to retrieve the host structure when the
252 * driver is called from the proc FS.
254 static struct Scsi_Host *first_host = NULL;
257 * /proc directory entry and proc_info.
259 #if LINUX_VERSION_CODE < LinuxVersionCode(2,3,27)
260 static struct proc_dir_entry proc_scsi_sym53c8xx = {
261 PROC_SCSI_SYM53C8XX, 9, NAME53C8XX,
262 S_IFDIR | S_IRUGO | S_IXUGO, 2
269 * Until some linux kernel version near 2.3.40, low-level scsi
270 * drivers were not told about data transfer direction.
272 #if LINUX_VERSION_CODE > LinuxVersionCode(2, 3, 40)
274 #define scsi_data_direction(cmd) (cmd->sc_data_direction)
278 static __inline__ int scsi_data_direction(Scsi_Cmnd *cmd)
282 switch((int) cmd->cmnd[0]) {
283 case 0x08: /* READ(6) 08 */
284 case 0x28: /* READ(10) 28 */
285 case 0xA8: /* READ(12) A8 */
286 direction = SCSI_DATA_READ;
288 case 0x0A: /* WRITE(6) 0A */
289 case 0x2A: /* WRITE(10) 2A */
290 case 0xAA: /* WRITE(12) AA */
291 direction = SCSI_DATA_WRITE;
294 direction = SCSI_DATA_UNKNOWN;
304 * Driver host data structure.
311 * Some type that fit DMA addresses as seen from BUS.
313 #ifndef SYM_LINUX_DYNAMIC_DMA_MAPPING
314 typedef u_long bus_addr_t;
316 #if SYM_CONF_DMA_ADDRESSING_MODE > 0
317 typedef dma64_addr_t bus_addr_t;
319 typedef dma_addr_t bus_addr_t;
324 * Used by the eh thread to wait for command completion.
325 * It is allocated on the eh thread stack.
328 struct semaphore sem;
329 struct timer_list timer;
330 void (*old_done)(Scsi_Cmnd *);
336 * Driver private area in the SCSI command structure.
338 struct sym_ucmd { /* Override the SCSI pointer structure */
339 SYM_QUEHEAD link_cmdq; /* Must stay at offset ZERO */
340 #ifdef SYM_LINUX_DYNAMIC_DMA_MAPPING
341 bus_addr_t data_mapping;
344 struct sym_eh_wait *eh_wait;
347 typedef struct sym_ucmd *ucmd_p;
349 #define SYM_UCMD_PTR(cmd) ((ucmd_p)(&(cmd)->SCp))
350 #define SYM_SCMD_PTR(ucmd) sym_que_entry(ucmd, Scsi_Cmnd, SCp)
351 #define SYM_SOFTC_PTR(cmd) (((struct host_data *)cmd->host->hostdata)->ncb)
354 * Deal with DMA mapping/unmapping.
357 #ifndef SYM_LINUX_DYNAMIC_DMA_MAPPING
359 /* Linux versions prior to pci bus iommu kernel interface */
361 #define __unmap_scsi_data(pdev, cmd) do {; } while (0)
362 #define __map_scsi_single_data(pdev, cmd) (__vtobus(pdev,(cmd)->request_buffer))
363 #define __map_scsi_sg_data(pdev, cmd) ((cmd)->use_sg)
364 #define __sync_scsi_data(pdev, cmd) do {; } while (0)
366 #define bus_sg_dma_address(sc) vtobus((sc)->address)
367 #define bus_sg_dma_len(sc) ((sc)->length)
369 #else /* Linux version with pci bus iommu kernel interface */
371 #define bus_unmap_sg(pdev, sgptr, sgcnt, dir) \
372 pci_unmap_sg(pdev, sgptr, sgcnt, dir)
374 #define bus_unmap_single(pdev, mapping, bufptr, dir) \
375 pci_unmap_single(pdev, mapping, bufptr, dir)
377 #define bus_map_single(pdev, bufptr, bufsiz, dir) \
378 pci_map_single(pdev, bufptr, bufsiz, dir)
380 #define bus_map_sg(pdev, sgptr, sgcnt, dir) \
381 pci_map_sg(pdev, sgptr, sgcnt, dir)
383 #define bus_dma_sync_sg(pdev, sgptr, sgcnt, dir) \
384 pci_dma_sync_sg(pdev, sgptr, sgcnt, dir)
386 #define bus_dma_sync_single(pdev, mapping, bufsiz, dir) \
387 pci_dma_sync_single(pdev, mapping, bufsiz, dir)
389 #define bus_sg_dma_address(sc) sg_dma_address(sc)
390 #define bus_sg_dma_len(sc) sg_dma_len(sc)
392 static void __unmap_scsi_data(pcidev_t pdev, Scsi_Cmnd *cmd)
394 int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction);
396 switch(SYM_UCMD_PTR(cmd)->data_mapped) {
398 bus_unmap_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir);
401 bus_unmap_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping,
402 cmd->request_bufflen, dma_dir);
405 SYM_UCMD_PTR(cmd)->data_mapped = 0;
408 static bus_addr_t __map_scsi_single_data(pcidev_t pdev, Scsi_Cmnd *cmd)
411 int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction);
413 mapping = bus_map_single(pdev, cmd->request_buffer,
414 cmd->request_bufflen, dma_dir);
416 SYM_UCMD_PTR(cmd)->data_mapped = 1;
417 SYM_UCMD_PTR(cmd)->data_mapping = mapping;
423 static int __map_scsi_sg_data(pcidev_t pdev, Scsi_Cmnd *cmd)
426 int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction);
428 use_sg = bus_map_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir);
430 SYM_UCMD_PTR(cmd)->data_mapped = 2;
431 SYM_UCMD_PTR(cmd)->data_mapping = use_sg;
437 static void __sync_scsi_data(pcidev_t pdev, Scsi_Cmnd *cmd)
439 int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction);
441 switch(SYM_UCMD_PTR(cmd)->data_mapped) {
443 bus_dma_sync_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir);
446 bus_dma_sync_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping,
447 cmd->request_bufflen, dma_dir);
452 #endif /* SYM_LINUX_DYNAMIC_DMA_MAPPING */
454 #define unmap_scsi_data(np, cmd) \
455 __unmap_scsi_data(np->s.device, cmd)
456 #define map_scsi_single_data(np, cmd) \
457 __map_scsi_single_data(np->s.device, cmd)
458 #define map_scsi_sg_data(np, cmd) \
459 __map_scsi_sg_data(np->s.device, cmd)
460 #define sync_scsi_data(np, cmd) \
461 __sync_scsi_data(np->s.device, cmd)
464 * Complete a pending CAM CCB.
466 void sym_xpt_done(hcb_p np, Scsi_Cmnd *ccb)
468 sym_remque(&SYM_UCMD_PTR(ccb)->link_cmdq);
469 unmap_scsi_data(np, ccb);
473 void sym_xpt_done2(hcb_p np, Scsi_Cmnd *ccb, int cam_status)
475 sym_set_cam_status(ccb, cam_status);
476 sym_xpt_done(np, ccb);
481 * Print something that identifies the IO.
483 void sym_print_addr (ccb_p cp)
485 Scsi_Cmnd *cmd = cp->cam_ccb;
487 printf("%s:%d:%d:", sym_name(SYM_SOFTC_PTR(cmd)),
488 cmd->target,cmd->lun);
492 * Tell the SCSI layer about a BUS RESET.
494 void sym_xpt_async_bus_reset(hcb_p np)
496 printf_notice("%s: SCSI BUS has been reset.\n", sym_name(np));
497 np->s.settle_time = ktime_get(sym_driver_setup.settle_delay * HZ);
498 np->s.settle_time_valid = 1;
499 if (sym_verbose >= 2)
500 printf_info("%s: command processing suspended for %d seconds\n",
501 sym_name(np), sym_driver_setup.settle_delay);
505 * Tell the SCSI layer about a BUS DEVICE RESET message sent.
507 void sym_xpt_async_sent_bdr(hcb_p np, int target)
509 printf_notice("%s: TARGET %d has been reset.\n", sym_name(np), target);
513 * Tell the SCSI layer about the new transfer parameters.
515 void sym_xpt_async_nego_wide(hcb_p np, int target)
519 sym_announce_transfer_rate(np, target);
523 * Choose the more appropriate CAM status if
524 * the IO encountered an extended error.
526 static int sym_xerr_cam_status(int cam_status, int x_status)
529 if (x_status & XE_PARITY_ERR)
530 cam_status = DID_PARITY;
531 else if (x_status &(XE_EXTRA_DATA|XE_SODL_UNRUN|XE_SWIDE_OVRUN))
532 cam_status = DID_ERROR;
533 else if (x_status & XE_BAD_PHASE)
534 cam_status = DID_ERROR;
536 cam_status = DID_ERROR;
542 * Build CAM result for a failed or auto-sensed IO.
544 void sym_set_cam_result_error(hcb_p np, ccb_p cp, int resid)
546 Scsi_Cmnd *csio = cp->cam_ccb;
547 u_int cam_status, scsi_status, drv_status;
551 scsi_status = cp->ssss_status;
553 if (cp->host_flags & HF_SENSE) {
554 scsi_status = cp->sv_scsi_status;
555 resid = cp->sv_resid;
556 if (sym_verbose && cp->sv_xerr_status)
557 sym_print_xerr(cp, cp->sv_xerr_status);
558 if (cp->host_status == HS_COMPLETE &&
559 cp->ssss_status == S_GOOD &&
560 cp->xerr_status == 0) {
561 cam_status = sym_xerr_cam_status(DID_OK,
563 drv_status = DRIVER_SENSE;
565 * Bounce back the sense data to user.
567 bzero(&csio->sense_buffer, sizeof(csio->sense_buffer));
568 bcopy(cp->sns_bbuf, csio->sense_buffer,
569 MIN(sizeof(csio->sense_buffer),SYM_SNS_BBUF_LEN));
572 * If the device reports a UNIT ATTENTION condition
573 * due to a RESET condition, we should consider all
574 * disconnect CCBs for this unit as aborted.
578 p = (u_char *) csio->sense_data;
579 if (p[0]==0x70 && p[2]==0x6 && p[12]==0x29)
580 sym_clear_tasks(np, DID_ABORT,
581 cp->target,cp->lun, -1);
586 cam_status = DID_ERROR;
588 else if (cp->host_status == HS_COMPLETE) /* Bad SCSI status */
590 else if (cp->host_status == HS_SEL_TIMEOUT) /* Selection timeout */
591 cam_status = DID_NO_CONNECT;
592 else if (cp->host_status == HS_UNEXPECTED) /* Unexpected BUS FREE*/
593 cam_status = DID_ERROR;
594 else { /* Extended error */
597 printf ("COMMAND FAILED (%x %x %x).\n",
598 cp->host_status, cp->ssss_status,
602 * Set the most appropriate value for CAM status.
604 cam_status = sym_xerr_cam_status(DID_ERROR, cp->xerr_status);
606 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,3,99)
609 csio->result = (drv_status << 24) + (cam_status << 16) + scsi_status;
614 * Called on successfull INQUIRY response.
616 void sym_sniff_inquiry(hcb_p np, Scsi_Cmnd *cmd, int resid)
620 if (!cmd || cmd->use_sg)
623 sync_scsi_data(np, cmd);
624 retv = __sym_sniff_inquiry(np, cmd->target, cmd->lun,
625 (u_char *) cmd->request_buffer,
626 cmd->request_bufflen - resid);
630 sym_update_trans_settings(np, &np->target[cmd->target]);
634 * Build the scatter/gather array for an I/O.
637 static int sym_scatter_no_sglist(hcb_p np, ccb_p cp, Scsi_Cmnd *cmd)
639 struct sym_tblmove *data = &cp->phys.data[SYM_CONF_MAX_SG-1];
642 cp->data_len = cmd->request_bufflen;
644 if (cmd->request_bufflen) {
645 bus_addr_t baddr = map_scsi_single_data(np, cmd);
647 sym_build_sge(np, data, baddr, cmd->request_bufflen);
659 static int sym_scatter(hcb_p np, ccb_p cp, Scsi_Cmnd *cmd)
662 int use_sg = (int) cmd->use_sg;
667 segment = sym_scatter_no_sglist(np, cp, cmd);
668 else if (use_sg > SYM_CONF_MAX_SG)
670 else if ((use_sg = map_scsi_sg_data(np, cmd)) > 0) {
671 struct scatterlist *scatter = (struct scatterlist *)cmd->buffer;
672 struct sym_tblmove *data;
674 data = &cp->phys.data[SYM_CONF_MAX_SG - use_sg];
676 for (segment = 0; segment < use_sg; segment++) {
677 bus_addr_t baddr = bus_sg_dma_address(&scatter[segment]);
678 unsigned int len = bus_sg_dma_len(&scatter[segment]);
680 sym_build_sge(np, &data[segment], baddr, len);
691 * Queue a SCSI command.
693 static int sym_queue_command(hcb_p np, Scsi_Cmnd *ccb)
695 /* Scsi_Device *device = ccb->device; */
702 * Minimal checkings, so that we will not
703 * go outside our tables.
705 if (ccb->target == np->myaddr ||
706 ccb->target >= SYM_CONF_MAX_TARGET ||
707 ccb->lun >= SYM_CONF_MAX_LUN) {
708 sym_xpt_done2(np, ccb, CAM_DEV_NOT_THERE);
713 * Retreive the target descriptor.
715 tp = &np->target[ccb->target];
718 * Complete the 1st INQUIRY command with error
719 * condition if the device is flagged NOSCAN
720 * at BOOT in the NVRAM. This may speed up
721 * the boot and maintain coherency with BIOS
722 * device numbering. Clearing the flag allows
723 * user to rescan skipped devices later.
724 * We also return error for devices not flagged
725 * for SCAN LUNS in the NVRAM since some mono-lun
726 * devices behave badly when asked for some non
727 * zero LUN. Btw, this is an absolute hack.:-)
729 if (ccb->cmnd[0] == 0x12 || ccb->cmnd[0] == 0x0) {
730 if ((tp->usrflags & SYM_SCAN_BOOT_DISABLED) ||
731 ((tp->usrflags & SYM_SCAN_LUNS_DISABLED) &&
733 tp->usrflags &= ~SYM_SCAN_BOOT_DISABLED;
734 sym_xpt_done2(np, ccb, CAM_DEV_NOT_THERE);
740 * Select tagged/untagged.
742 lp = sym_lp(np, tp, ccb->lun);
743 order = (lp && lp->s.reqtags) ? M_SIMPLE_TAG : 0;
748 cp = sym_get_ccb(np, ccb->target, ccb->lun, order);
750 return 1; /* Means resource shortage */
751 (void) sym_queue_scsiio(np, ccb, cp);
756 * Setup buffers and pointers that address the CDB.
758 static int __inline sym_setup_cdb(hcb_p np, Scsi_Cmnd *ccb, ccb_p cp)
764 * CDB is 16 bytes max.
766 if (ccb->cmd_len > sizeof(cp->cdb_buf)) {
767 sym_set_cam_status(cp->cam_ccb, CAM_REQ_INVALID);
771 bcopy(ccb->cmnd, cp->cdb_buf, ccb->cmd_len);
772 cmd_ba = CCB_BA (cp, cdb_buf[0]);
773 cmd_len = ccb->cmd_len;
775 cp->phys.cmd.addr = cpu_to_scr(cmd_ba);
776 cp->phys.cmd.size = cpu_to_scr(cmd_len);
782 * Setup pointers that address the data and start the I/O.
784 int sym_setup_data_and_start(hcb_p np, Scsi_Cmnd *csio, ccb_p cp)
787 tcb_p tp = &np->target[cp->target];
788 lcb_p lp = sym_lp(np, tp, cp->lun);
793 if (sym_setup_cdb(np, csio, cp))
797 * No direction means no data.
799 dir = scsi_data_direction(csio);
800 if (dir != SCSI_DATA_NONE) {
801 cp->segments = sym_scatter (np, cp, csio);
802 if (cp->segments < 0) {
803 if (cp->segments == -2)
804 sym_set_cam_status(csio, CAM_RESRC_UNAVAIL);
806 sym_set_cam_status(csio, CAM_REQ_TOO_BIG);
818 sym_setup_data_pointers(np, cp, dir);
821 * When `#ifed 1', the code below makes the driver
822 * panic on the first attempt to write to a SCSI device.
823 * It is the first test we want to do after a driver
824 * change that does not seem obviously safe. :)
827 switch (cp->cdb_buf[0]) {
828 case 0x0A: case 0x2A: case 0xAA:
829 panic("XXXXXXXXXXXXX WRITE NOT YET ALLOWED XXXXXXXXXXXXXX\n");
841 sym_start_next_ccbs(np, lp, 2);
843 sym_put_start_queue(np, cp);
847 sym_free_ccb(np, cp);
848 sym_xpt_done(np, csio);
856 * Misused to keep the driver running when
857 * interrupts are not configured correctly.
859 static void sym_timer (hcb_p np)
861 u_long thistime = ktime_get(0);
863 #if LINUX_VERSION_CODE < LinuxVersionCode(2, 4, 0)
865 * If release process in progress, let's go
866 * Set the release stage from 1 to 2 to synchronize
867 * with the release process.
870 if (np->s.release_stage) {
871 if (np->s.release_stage == 1)
872 np->s.release_stage = 2;
880 #ifdef SYM_CONF_PCIQ_BROKEN_INTR
881 np->s.timer.expires = ktime_get((HZ+99)/100);
883 np->s.timer.expires = ktime_get(SYM_CONF_TIMER_INTERVAL);
885 add_timer(&np->s.timer);
888 * If we are resetting the ncr, wait for settle_time before
889 * clearing it. Then command processing will be resumed.
891 if (np->s.settle_time_valid) {
892 if (ktime_dif(np->s.settle_time, thistime) <= 0){
893 if (sym_verbose >= 2 )
894 printk("%s: command processing resumed\n",
896 np->s.settle_time_valid = 0;
902 * Nothing to do for now, but that may come.
904 if (np->s.lasttime + 4*HZ < thistime) {
905 np->s.lasttime = thistime;
908 #ifdef SYM_CONF_PCIQ_MAY_MISS_COMPLETIONS
910 * Some way-broken PCI bridges may lead to
911 * completions being lost when the clearing
912 * of the INTFLY flag by the CPU occurs
913 * concurrently with the chip raising this flag.
914 * If this ever happen, lost completions will
920 #ifdef SYM_CONF_PCIQ_BROKEN_INTR
921 if (INB(nc_istat) & (INTF|SIP|DIP)) {
924 ** Process pending interrupts.
926 if (DEBUG_FLAGS & DEBUG_TINY) printk ("{");
928 if (DEBUG_FLAGS & DEBUG_TINY) printk ("}");
930 #endif /* SYM_CONF_PCIQ_BROKEN_INTR */
935 * PCI BUS error handler.
937 void sym_log_bus_error(hcb_p np)
940 pci_read_config_word(np->s.device, PCI_STATUS, &pci_sts);
941 if (pci_sts & 0xf900) {
942 pci_write_config_word(np->s.device, PCI_STATUS,
944 printf("%s: PCI STATUS = 0x%04x\n",
945 sym_name(np), pci_sts & 0xf900);
951 * Requeue awaiting commands.
953 static void sym_requeue_awaiting_cmds(hcb_p np)
956 ucmd_p ucp = SYM_UCMD_PTR(cmd);
957 SYM_QUEHEAD tmp_cmdq;
960 sym_que_move(&np->s.wait_cmdq, &tmp_cmdq);
962 while ((ucp = (ucmd_p) sym_remque_head(&tmp_cmdq)) != 0) {
963 sym_insque_tail(&ucp->link_cmdq, &np->s.busy_cmdq);
964 cmd = SYM_SCMD_PTR(ucp);
965 sts = sym_queue_command(np, cmd);
967 sym_remque(&ucp->link_cmdq);
968 sym_insque_head(&ucp->link_cmdq, &np->s.wait_cmdq);
974 * Linux entry point of the queuecommand() function
976 int sym53c8xx_queue_command (Scsi_Cmnd *cmd, void (*done)(Scsi_Cmnd *))
978 hcb_p np = SYM_SOFTC_PTR(cmd);
979 ucmd_p ucp = SYM_UCMD_PTR(cmd);
983 cmd->scsi_done = done;
984 cmd->host_scribble = NULL;
985 memset(ucp, 0, sizeof(*ucp));
987 SYM_LOCK_HCB(np, flags);
990 * Shorten our settle_time if needed for
991 * this command not to time out.
993 if (np->s.settle_time_valid && cmd->timeout_per_command) {
994 u_long tlimit = ktime_get(cmd->timeout_per_command);
995 tlimit = ktime_sub(tlimit, SYM_CONF_TIMER_INTERVAL*2);
996 if (ktime_dif(np->s.settle_time, tlimit) > 0) {
997 np->s.settle_time = tlimit;
1001 if (np->s.settle_time_valid || !sym_que_empty(&np->s.wait_cmdq)) {
1002 sym_insque_tail(&ucp->link_cmdq, &np->s.wait_cmdq);
1006 sym_insque_tail(&ucp->link_cmdq, &np->s.busy_cmdq);
1007 sts = sym_queue_command(np, cmd);
1009 sym_remque(&ucp->link_cmdq);
1010 sym_insque_tail(&ucp->link_cmdq, &np->s.wait_cmdq);
1013 SYM_UNLOCK_HCB(np, flags);
1019 * Linux entry point of the interrupt handler.
1021 static void sym53c8xx_intr(int irq, void *dev_id, struct pt_regs * regs)
1023 unsigned long flags;
1024 unsigned long flags1;
1025 hcb_p np = (hcb_p) dev_id;
1027 if (DEBUG_FLAGS & DEBUG_TINY) printf_debug ("[");
1029 SYM_LOCK_SCSI(np, flags1);
1030 SYM_LOCK_HCB(np, flags);
1034 if (!sym_que_empty(&np->s.wait_cmdq) && !np->s.settle_time_valid)
1035 sym_requeue_awaiting_cmds(np);
1037 SYM_UNLOCK_HCB(np, flags);
1038 SYM_UNLOCK_SCSI(np, flags1);
1040 if (DEBUG_FLAGS & DEBUG_TINY) printf_debug ("]\n");
1044 * Linux entry point of the timer handler
1046 static void sym53c8xx_timer(unsigned long npref)
1048 hcb_p np = (hcb_p) npref;
1049 unsigned long flags;
1050 unsigned long flags1;
1052 SYM_LOCK_SCSI(np, flags1);
1053 SYM_LOCK_HCB(np, flags);
1057 if (!sym_que_empty(&np->s.wait_cmdq) && !np->s.settle_time_valid)
1058 sym_requeue_awaiting_cmds(np);
1060 SYM_UNLOCK_HCB(np, flags);
1061 SYM_UNLOCK_SCSI(np, flags1);
1066 * What the eh thread wants us to perform.
1068 #define SYM_EH_ABORT 0
1069 #define SYM_EH_DEVICE_RESET 1
1070 #define SYM_EH_BUS_RESET 2
1071 #define SYM_EH_HOST_RESET 3
1074 * What we will do regarding the involved SCSI command.
1076 #define SYM_EH_DO_IGNORE 0
1077 #define SYM_EH_DO_COMPLETE 1
1078 #define SYM_EH_DO_WAIT 2
1081 * Our general completion handler.
1083 static void __sym_eh_done(Scsi_Cmnd *cmd, int timed_out)
1085 struct sym_eh_wait *ep = SYM_UCMD_PTR(cmd)->eh_wait;
1089 /* Try to avoid a race here (not 100% safe) */
1092 if (ep->to_do == SYM_EH_DO_WAIT && !del_timer(&ep->timer))
1096 /* Revert everything */
1097 SYM_UCMD_PTR(cmd)->eh_wait = 0;
1098 cmd->scsi_done = ep->old_done;
1100 /* Wake up the eh thread if it wants to sleep */
1101 if (ep->to_do == SYM_EH_DO_WAIT)
1106 * scsi_done() alias when error recovery is in progress.
1108 static void sym_eh_done(Scsi_Cmnd *cmd) { __sym_eh_done(cmd, 0); }
1111 * Some timeout handler to avoid waiting too long.
1113 static void sym_eh_timeout(u_long p) { __sym_eh_done((Scsi_Cmnd *)p, 1); }
1116 * Generic method for our eh processing.
1117 * The 'op' argument tells what we have to do.
1119 static int sym_eh_handler(int op, char *opname, Scsi_Cmnd *cmd)
1121 hcb_p np = SYM_SOFTC_PTR(cmd);
1122 unsigned long flags;
1124 int to_do = SYM_EH_DO_IGNORE;
1126 struct sym_eh_wait eh, *ep = &eh;
1129 sprintf(devname, "%s:%d:%d", sym_name(np), cmd->target, cmd->lun);
1131 printf_warning("%s: %s operation started.\n", devname, opname);
1133 SYM_LOCK_HCB(np, flags);
1136 /* This one should be the result of some race, thus to ignore */
1137 if (cmd->serial_number != cmd->serial_number_at_timeout)
1141 /* This one is not queued to the core driver -> to complete here */
1142 FOR_EACH_QUEUED_ELEMENT(&np->s.wait_cmdq, qp) {
1143 if (SYM_SCMD_PTR(qp) == cmd) {
1144 to_do = SYM_EH_DO_COMPLETE;
1149 /* This one is queued in some place -> to wait for completion */
1150 FOR_EACH_QUEUED_ELEMENT(&np->busy_ccbq, qp) {
1151 ccb_p cp = sym_que_entry(qp, struct sym_ccb, link_ccbq);
1152 if (cp->cam_ccb == cmd) {
1153 to_do = SYM_EH_DO_WAIT;
1159 /* Prepare stuff to either ignore, complete or wait for completion */
1162 case SYM_EH_DO_IGNORE:
1164 case SYM_EH_DO_WAIT:
1165 #if LINUX_VERSION_CODE > LinuxVersionCode(2,3,0)
1166 init_MUTEX_LOCKED(&ep->sem);
1168 ep->sem = MUTEX_LOCKED;
1171 case SYM_EH_DO_COMPLETE:
1172 ep->old_done = cmd->scsi_done;
1173 cmd->scsi_done = sym_eh_done;
1174 SYM_UCMD_PTR(cmd)->eh_wait = ep;
1177 /* Try to proceed the operation we have been asked for */
1181 sts = sym_abort_scsiio(np, cmd, 1);
1183 case SYM_EH_DEVICE_RESET:
1184 sts = sym_reset_scsi_target(np, cmd->target);
1186 case SYM_EH_BUS_RESET:
1187 sym_reset_scsi_bus(np, 1);
1190 case SYM_EH_HOST_RESET:
1191 sym_reset_scsi_bus(np, 0);
1192 sym_start_up (np, 1);
1199 /* On error, restore everything and cross fingers :) */
1201 SYM_UCMD_PTR(cmd)->eh_wait = 0;
1202 cmd->scsi_done = ep->old_done;
1203 to_do = SYM_EH_DO_IGNORE;
1207 /* Complete the command with locks held as required by the driver */
1208 if (to_do == SYM_EH_DO_COMPLETE)
1209 sym_xpt_done2(np, cmd, CAM_REQ_ABORTED);
1211 SYM_UNLOCK_HCB(np, flags);
1213 /* Wait for completion with locks released, as required by kernel */
1214 if (to_do == SYM_EH_DO_WAIT) {
1215 init_timer(&ep->timer);
1216 ep->timer.expires = jiffies + (5*HZ);
1217 ep->timer.function = sym_eh_timeout;
1218 ep->timer.data = (u_long)cmd;
1219 ep->timed_out = 1; /* Be pessimistic for once :) */
1220 add_timer(&ep->timer);
1221 SYM_UNLOCK_SCSI_NORESTORE(np);
1223 SYM_LOCK_SCSI_NOSAVE(np);
1227 printf_warning("%s: %s operation %s.\n", devname, opname,
1228 sts==0?"complete":sts==-2?"timed-out":"failed");
1229 return sts? SCSI_FAILED : SCSI_SUCCESS;
1234 * Error handlers called from the eh thread (one thread per HBA).
1236 int sym53c8xx_eh_abort_handler(Scsi_Cmnd *cmd)
1238 return sym_eh_handler(SYM_EH_ABORT, "ABORT", cmd);
1241 int sym53c8xx_eh_device_reset_handler(Scsi_Cmnd *cmd)
1243 return sym_eh_handler(SYM_EH_DEVICE_RESET, "DEVICE RESET", cmd);
1246 int sym53c8xx_eh_bus_reset_handler(Scsi_Cmnd *cmd)
1248 return sym_eh_handler(SYM_EH_BUS_RESET, "BUS RESET", cmd);
1251 int sym53c8xx_eh_host_reset_handler(Scsi_Cmnd *cmd)
1253 return sym_eh_handler(SYM_EH_HOST_RESET, "HOST RESET", cmd);
1257 * Tune device queuing depth, according to various limits.
1260 sym_tune_dev_queuing(hcb_p np, int target, int lun, u_short reqtags)
1262 tcb_p tp = &np->target[target];
1263 lcb_p lp = sym_lp(np, tp, lun);
1269 oldtags = lp->s.reqtags;
1271 if (reqtags > lp->s.scdev_depth)
1272 reqtags = lp->s.scdev_depth;
1274 lp->started_limit = reqtags ? reqtags : 2;
1275 lp->started_max = 1;
1276 lp->s.reqtags = reqtags;
1278 if (reqtags != oldtags) {
1279 printf_info("%s:%d:%d: "
1280 "tagged command queuing %s, command queue depth %d.\n",
1281 sym_name(np), target, lun,
1282 lp->s.reqtags ? "enabled" : "disabled",
1287 #ifdef SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT
1289 * Linux select queue depths function
1291 #define DEF_DEPTH (sym_driver_setup.max_tag)
1292 #define ALL_TARGETS -2
1293 #define NO_TARGET -1
1297 static int device_queue_depth(hcb_p np, int target, int lun)
1300 char *p = sym_driver_setup.tag_ctrl;
1306 while ((c = *p++) != 0) {
1307 v = simple_strtoul(p, &ep, 0);
1316 t = (target == v) ? v : NO_TARGET;
1321 u = (lun == v) ? v : NO_LUN;
1324 if (h == np->s.unit &&
1325 (t == ALL_TARGETS || t == target) &&
1326 (u == ALL_LUNS || u == lun))
1341 #define device_queue_depth(np, t, l) (sym_driver_setup.max_tag)
1342 #endif /* SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT */
1345 * Linux entry point for device queue sizing.
1348 sym53c8xx_select_queue_depths(struct Scsi_Host *host,
1349 struct scsi_device *devlist)
1351 struct scsi_device *device;
1353 for (device = devlist; device; device = device->next) {
1359 if (device->host != host)
1362 np = ((struct host_data *) host->hostdata)->ncb;
1363 tp = &np->target[device->id];
1366 * Get user settings for transfer parameters.
1368 tp->inq_byte7_valid = (INQ7_SYNC|INQ7_WIDE16);
1369 sym_update_trans_settings(np, tp);
1372 * Allocate the LCB if not yet.
1373 * If it fail, we may well be in the sh*t. :)
1375 lp = sym_alloc_lcb(np, device->id, device->lun);
1377 device->queue_depth = 1;
1384 lp->curr_flags = lp->user_flags;
1387 * Select queue depth from driver setup.
1388 * Donnot use more than configured by user.
1390 * Donnot use more than our maximum.
1392 reqtags = device_queue_depth(np, device->id, device->lun);
1393 if (reqtags > tp->usrtags)
1394 reqtags = tp->usrtags;
1395 if (!device->tagged_supported)
1397 #if 1 /* Avoid to locally queue commands for no good reasons */
1398 if (reqtags > SYM_CONF_MAX_TAG)
1399 reqtags = SYM_CONF_MAX_TAG;
1400 device->queue_depth = reqtags ? reqtags : 2;
1402 device->queue_depth = reqtags ? SYM_CONF_MAX_TAG : 2;
1404 lp->s.scdev_depth = device->queue_depth;
1405 sym_tune_dev_queuing(np, device->id, device->lun, reqtags);
1410 * Linux entry point for info() function
1412 const char *sym53c8xx_info (struct Scsi_Host *host)
1414 return sym_driver_name();
1418 #ifdef SYM_LINUX_PROC_INFO_SUPPORT
1420 * Proc file system stuff
1422 * A read operation returns adapter information.
1423 * A write operation is a control command.
1424 * The string is parsed in the driver code and the command is passed
1425 * to the sym_usercmd() function.
1428 #ifdef SYM_LINUX_USER_COMMAND_SUPPORT
1437 #define UC_SETSYNC 10
1438 #define UC_SETTAGS 11
1439 #define UC_SETDEBUG 12
1440 #define UC_SETWIDE 14
1441 #define UC_SETFLAG 15
1442 #define UC_SETVERBOSE 17
1443 #define UC_RESETDEV 18
1444 #define UC_CLEARDEV 19
1446 static void sym_exec_user_command (hcb_p np, struct sym_usrcmd *uc)
1454 #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT
1456 sym_debug_flags = uc->data;
1460 np->verbose = uc->data;
1464 * We assume that other commands apply to targets.
1465 * This should always be the case and avoid the below
1466 * 4 lines to be repeated 6 times.
1468 for (t = 0; t < SYM_CONF_MAX_TARGET; t++) {
1469 if (!((uc->target >> t) & 1))
1471 tp = &np->target[t];
1476 if (!uc->data || uc->data >= 255) {
1477 tp->tinfo.goal.options = 0;
1478 tp->tinfo.goal.offset = 0;
1481 if (uc->data <= 9 && np->minsync_dt &&
1482 np->scsi_mode == SMODE_LVD) {
1483 if (uc->data < np->minsync_dt)
1484 uc->data = np->minsync_dt;
1485 tp->tinfo.goal.options = PPR_OPT_DT;
1486 tp->tinfo.goal.width = 1;
1487 tp->tinfo.goal.period = uc->data;
1488 tp->tinfo.goal.offset = np->maxoffs_dt;
1491 if (uc->data < np->minsync)
1492 uc->data = np->minsync;
1493 tp->tinfo.goal.options = 0;
1494 tp->tinfo.goal.period = uc->data;
1495 tp->tinfo.goal.offset = np->maxoffs;
1499 tp->tinfo.goal.width = uc->data ? 1 : 0;
1502 for (l = 0; l < SYM_CONF_MAX_LUN; l++)
1503 sym_tune_dev_queuing(np, t,l, uc->data);
1507 np->istat_sem = SEM;
1508 OUTB (nc_istat, SIGP|SEM);
1511 for (l = 0; l < SYM_CONF_MAX_LUN; l++) {
1512 lcb_p lp = sym_lp(np, tp, l);
1513 if (lp) lp->to_clear = 1;
1515 np->istat_sem = SEM;
1516 OUTB (nc_istat, SIGP|SEM);
1519 tp->usrflags = uc->data;
1527 #define is_digit(c) ((c) >= '0' && (c) <= '9')
1528 #define digit_to_bin(c) ((c) - '0')
1529 #define is_space(c) ((c) == ' ' || (c) == '\t')
1531 static int skip_spaces(char *ptr, int len)
1535 for (cnt = len; cnt > 0 && (c = *ptr++) && is_space(c); cnt--);
1540 static int get_int_arg(char *ptr, int len, u_long *pv)
1545 for (v = 0, cnt = len; cnt > 0 && (c = *ptr++) && is_digit(c); cnt--) {
1546 v = (v * 10) + digit_to_bin(c);
1555 static int is_keyword(char *ptr, int len, char *verb)
1557 int verb_len = strlen(verb);
1559 if (len >= strlen(verb) && !memcmp(verb, ptr, verb_len))
1566 #define SKIP_SPACES(min_spaces) \
1567 if ((arg_len = skip_spaces(ptr, len)) < (min_spaces)) \
1569 ptr += arg_len; len -= arg_len;
1571 #define GET_INT_ARG(v) \
1572 if (!(arg_len = get_int_arg(ptr, len, &(v)))) \
1574 ptr += arg_len; len -= arg_len;
1578 * Parse a control command
1581 static int sym_user_command(hcb_p np, char *buffer, int length)
1585 struct sym_usrcmd cmd, *uc = &cmd;
1589 bzero(uc, sizeof(*uc));
1591 if (len > 0 && ptr[len-1] == '\n')
1594 if ((arg_len = is_keyword(ptr, len, "setsync")) != 0)
1595 uc->cmd = UC_SETSYNC;
1596 else if ((arg_len = is_keyword(ptr, len, "settags")) != 0)
1597 uc->cmd = UC_SETTAGS;
1598 else if ((arg_len = is_keyword(ptr, len, "setverbose")) != 0)
1599 uc->cmd = UC_SETVERBOSE;
1600 else if ((arg_len = is_keyword(ptr, len, "setwide")) != 0)
1601 uc->cmd = UC_SETWIDE;
1602 #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT
1603 else if ((arg_len = is_keyword(ptr, len, "setdebug")) != 0)
1604 uc->cmd = UC_SETDEBUG;
1606 else if ((arg_len = is_keyword(ptr, len, "setflag")) != 0)
1607 uc->cmd = UC_SETFLAG;
1608 else if ((arg_len = is_keyword(ptr, len, "resetdev")) != 0)
1609 uc->cmd = UC_RESETDEV;
1610 else if ((arg_len = is_keyword(ptr, len, "cleardev")) != 0)
1611 uc->cmd = UC_CLEARDEV;
1615 #ifdef DEBUG_PROC_INFO
1616 printk("sym_user_command: arg_len=%d, cmd=%ld\n", arg_len, uc->cmd);
1621 ptr += arg_len; len -= arg_len;
1631 if ((arg_len = is_keyword(ptr, len, "all")) != 0) {
1632 ptr += arg_len; len -= arg_len;
1635 GET_INT_ARG(target);
1636 uc->target = (1<<target);
1637 #ifdef DEBUG_PROC_INFO
1638 printk("sym_user_command: target=%ld\n", target);
1650 GET_INT_ARG(uc->data);
1651 #ifdef DEBUG_PROC_INFO
1652 printk("sym_user_command: data=%ld\n", uc->data);
1655 #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT
1659 if ((arg_len = is_keyword(ptr, len, "alloc")))
1660 uc->data |= DEBUG_ALLOC;
1661 else if ((arg_len = is_keyword(ptr, len, "phase")))
1662 uc->data |= DEBUG_PHASE;
1663 else if ((arg_len = is_keyword(ptr, len, "queue")))
1664 uc->data |= DEBUG_QUEUE;
1665 else if ((arg_len = is_keyword(ptr, len, "result")))
1666 uc->data |= DEBUG_RESULT;
1667 else if ((arg_len = is_keyword(ptr, len, "scatter")))
1668 uc->data |= DEBUG_SCATTER;
1669 else if ((arg_len = is_keyword(ptr, len, "script")))
1670 uc->data |= DEBUG_SCRIPT;
1671 else if ((arg_len = is_keyword(ptr, len, "tiny")))
1672 uc->data |= DEBUG_TINY;
1673 else if ((arg_len = is_keyword(ptr, len, "timing")))
1674 uc->data |= DEBUG_TIMING;
1675 else if ((arg_len = is_keyword(ptr, len, "nego")))
1676 uc->data |= DEBUG_NEGO;
1677 else if ((arg_len = is_keyword(ptr, len, "tags")))
1678 uc->data |= DEBUG_TAGS;
1679 else if ((arg_len = is_keyword(ptr, len, "pointer")))
1680 uc->data |= DEBUG_POINTER;
1683 ptr += arg_len; len -= arg_len;
1685 #ifdef DEBUG_PROC_INFO
1686 printk("sym_user_command: data=%ld\n", uc->data);
1689 #endif /* SYM_LINUX_DEBUG_CONTROL_SUPPORT */
1693 if ((arg_len = is_keyword(ptr, len, "no_disc")))
1694 uc->data &= ~SYM_DISC_ENABLED;
1697 ptr += arg_len; len -= arg_len;
1709 SYM_LOCK_HCB(np, flags);
1710 sym_exec_user_command (np, uc);
1711 SYM_UNLOCK_HCB(np, flags);
1716 #endif /* SYM_LINUX_USER_COMMAND_SUPPORT */
1719 #ifdef SYM_LINUX_USER_INFO_SUPPORT
1721 * Informations through the proc file system.
1730 static void copy_mem_info(struct info_str *info, char *data, int len)
1732 if (info->pos + len > info->length)
1733 len = info->length - info->pos;
1735 if (info->pos + len < info->offset) {
1739 if (info->pos < info->offset) {
1740 data += (info->offset - info->pos);
1741 len -= (info->offset - info->pos);
1745 memcpy(info->buffer + info->pos, data, len);
1750 static int copy_info(struct info_str *info, char *fmt, ...)
1756 va_start(args, fmt);
1757 len = vsprintf(buf, fmt, args);
1760 copy_mem_info(info, buf, len);
1765 * Copy formatted information into the input buffer.
1767 static int sym_host_info(hcb_p np, char *ptr, off_t offset, int len)
1769 struct info_str info;
1773 info.offset = offset;
1776 copy_info(&info, "Chip " NAME53C "%s, device id 0x%x, "
1777 "revision id 0x%x\n",
1778 np->s.chip_name, np->device_id, np->revision_id);
1779 copy_info(&info, "On PCI bus %d, device %d, function %d, "
1785 np->s.bus, (np->s.device_fn & 0xf8) >> 3, np->s.device_fn & 7,
1787 __irq_itoa(np->s.irq));
1791 copy_info(&info, "Min. period factor %d, %s SCSI BUS%s\n",
1792 (int) (np->minsync_dt ? np->minsync_dt : np->minsync),
1793 np->maxwide ? "Wide" : "Narrow",
1794 np->minsync_dt ? ", DT capable" : "");
1796 copy_info(&info, "Max. started commands %d, "
1797 "max. commands per LUN %d\n",
1798 SYM_CONF_MAX_START, SYM_CONF_MAX_TAG);
1800 return info.pos > info.offset? info.pos - info.offset : 0;
1802 #endif /* SYM_LINUX_USER_INFO_SUPPORT */
1805 * Entry point of the scsi proc fs of the driver.
1806 * - func = 0 means read (returns adapter infos)
1807 * - func = 1 means write (not yet merget from sym53c8xx)
1809 static int sym53c8xx_proc_info(char *buffer, char **start, off_t offset,
1810 int length, int hostno, int func)
1812 struct Scsi_Host *host;
1813 struct host_data *host_data;
1817 for (host = first_host; host; host = host->next) {
1818 if (host->hostt != first_host->hostt)
1820 if (host->host_no == hostno) {
1821 host_data = (struct host_data *) host->hostdata;
1822 np = host_data->ncb;
1831 #ifdef SYM_LINUX_USER_COMMAND_SUPPORT
1832 retv = sym_user_command(np, buffer, length);
1840 #ifdef SYM_LINUX_USER_INFO_SUPPORT
1841 retv = sym_host_info(np, buffer, offset, length);
1849 #endif /* SYM_LINUX_PROC_INFO_SUPPORT */
1852 * Free controller resources.
1854 static void sym_free_resources(hcb_p np, int holding_io_request_lock)
1857 * Free O/S specific resources.
1860 free_irq(np->s.irq, np);
1862 release_region(np->s.io_port, np->s.io_ws);
1863 #ifndef SYM_OPT_NO_BUS_MEMORY_MAPPING
1865 pci_unmap_mem(np->s.mmio_va,
1867 holding_io_request_lock);
1869 pci_unmap_mem(np->s.ram_va,
1871 holding_io_request_lock);
1874 * Free O/S independant resources.
1878 sym_mfree_dma(np, sizeof(*np), "HCB");
1882 * Ask/tell the system about DMA addressing.
1884 #ifdef SYM_LINUX_DYNAMIC_DMA_MAPPING
1885 static int sym_setup_bus_dma_mask(hcb_p np)
1887 #if LINUX_VERSION_CODE < LinuxVersionCode(2,4,3)
1888 if (!pci_dma_supported(np->s.device, 0xffffffffUL))
1891 #if SYM_CONF_DMA_ADDRESSING_MODE == 0
1892 if (pci_set_dma_mask(np->s.device, 0xffffffffUL))
1895 #if SYM_CONF_DMA_ADDRESSING_MODE == 1
1896 #define PciDmaMask 0xffffffffff
1897 #elif SYM_CONF_DMA_ADDRESSING_MODE == 2
1898 #define PciDmaMask 0xffffffffffffffff
1900 if (np->features & FE_DAC) {
1901 if (!pci_set_dma_mask(np->s.device, PciDmaMask)) {
1903 printf_info("%s: using 64 bit DMA addressing\n",
1907 if (pci_set_dma_mask(np->s.device, 0xffffffffUL))
1917 printf_warning("%s: 32 BIT DMA ADDRESSING NOT SUPPORTED\n",
1921 #endif /* SYM_LINUX_DYNAMIC_DMA_MAPPING */
1924 * Host attach and initialisations.
1926 * Allocate host data and ncb structure.
1927 * Request IO region and remap MMIO region.
1928 * Do chip initialization.
1929 * If all is OK, install interrupt handling and
1930 * start the timer daemon.
1933 sym_attach (Scsi_Host_Template *tpnt, int unit, sym_device *dev)
1935 struct host_data *host_data;
1937 struct Scsi_Host *instance = 0;
1939 sym_nvram *nvram = dev->nvram;
1943 "sym%d: <%s> rev 0x%x on pci bus %d device %d function %d "
1949 unit, dev->chip.name, dev->chip.revision_id,
1950 dev->s.bus, (dev->s.device_fn & 0xf8) >> 3,
1951 dev->s.device_fn & 7,
1953 __irq_itoa(dev->s.irq));
1959 * Get the firmware for this chip.
1961 fw = sym_find_firmware(&dev->chip);
1966 * Allocate host_data structure
1968 if (!(instance = scsi_register(tpnt, sizeof(*host_data))))
1970 host_data = (struct host_data *) instance->hostdata;
1973 * Allocate immediately the host control block,
1974 * since we are only expecting to succeed. :)
1975 * We keep track in the HCB of all the resources that
1976 * are to be released on error.
1978 #ifdef SYM_LINUX_DYNAMIC_DMA_MAPPING
1979 np = __sym_calloc_dma(dev->pdev, sizeof(*np), "HCB");
1981 np->s.device = dev->pdev;
1982 np->bus_dmat = dev->pdev; /* Result in 1 DMA pool per HBA */
1987 np = sym_calloc_dma(sizeof(*np), "HCB");
1991 host_data->ncb = np;
1993 SYM_INIT_LOCK_HCB(np);
1996 * Copy some useful infos to the HCB.
1998 np->hcb_ba = vtobus(np);
1999 np->verbose = sym_driver_setup.verbose;
2000 np->s.device = dev->pdev;
2002 np->device_id = dev->chip.device_id;
2003 np->revision_id = dev->chip.revision_id;
2004 np->s.bus = dev->s.bus;
2005 np->s.device_fn = dev->s.device_fn;
2006 np->features = dev->chip.features;
2007 np->clock_divn = dev->chip.nr_divisor;
2008 np->maxoffs = dev->chip.offset_max;
2009 np->maxburst = dev->chip.burst_max;
2010 np->myaddr = dev->host_id;
2015 strncpy(np->s.chip_name, dev->chip.name, sizeof(np->s.chip_name)-1);
2016 sprintf(np->s.inst_name, "sym%d", np->s.unit);
2019 * Ask/tell the system about DMA addressing.
2021 #ifdef SYM_LINUX_DYNAMIC_DMA_MAPPING
2022 if (sym_setup_bus_dma_mask(np))
2027 * Try to map the controller chip to
2028 * virtual and physical memory.
2030 np->mmio_ba = (u32)dev->s.base;
2031 np->s.io_ws = (np->features & FE_IO256)? 256 : 128;
2033 #ifndef SYM_CONF_IOMAPPED
2034 np->s.mmio_va = pci_map_mem(dev->s.base_c, np->s.io_ws);
2035 if (!np->s.mmio_va) {
2036 printf_err("%s: can't map PCI MMIO region\n", sym_name(np));
2039 else if (sym_verbose > 1)
2040 printf_info("%s: using memory mapped IO\n", sym_name(np));
2041 #endif /* !defined SYM_CONF_IOMAPPED */
2044 * Try to map the controller chip into iospace.
2046 if (dev->s.io_port) {
2047 request_region(dev->s.io_port, np->s.io_ws, NAME53C8XX);
2048 np->s.io_port = dev->s.io_port;
2052 * Map on-chip RAM if present and supported.
2054 if (!(np->features & FE_RAM))
2056 if (dev->s.base_2) {
2057 np->ram_ba = (u32)dev->s.base_2;
2058 if (np->features & FE_RAM8K)
2062 #ifndef SYM_OPT_NO_BUS_MEMORY_MAPPING
2063 np->s.ram_va = pci_map_mem(dev->s.base_2_c, np->ram_ws);
2064 if (!np->s.ram_va) {
2065 printf_err("%s: can't map PCI MEMORY region\n",
2073 * Perform O/S independant stuff.
2075 if (sym_hcb_attach(np, fw, nvram))
2080 * Install the interrupt handler.
2081 * If we synchonize the C code with SCRIPTS on interrupt,
2082 * we donnot want to share the INTR line at all.
2084 if (request_irq(dev->s.irq, sym53c8xx_intr, SA_SHIRQ,
2086 printf_err("%s: request irq %d failure\n",
2087 sym_name(np), dev->s.irq);
2090 np->s.irq = dev->s.irq;
2093 * After SCSI devices have been opened, we cannot
2094 * reset the bus safely, so we do it here.
2096 SYM_LOCK_HCB(np, flags);
2097 if (sym_reset_scsi_bus(np, 0)) {
2098 printf_err("%s: FATAL ERROR: CHECK SCSI BUS - CABLES, "
2099 "TERMINATION, DEVICE POWER etc.!\n", sym_name(np));
2100 SYM_UNLOCK_HCB(np, flags);
2105 * Initialize some queue headers.
2107 sym_que_init(&np->s.wait_cmdq);
2108 sym_que_init(&np->s.busy_cmdq);
2111 * Start the SCRIPTS.
2113 sym_start_up (np, 1);
2116 * Start the timer daemon
2118 init_timer(&np->s.timer);
2119 np->s.timer.data = (unsigned long) np;
2120 np->s.timer.function = sym53c8xx_timer;
2128 first_host = instance;
2131 * Fill Linux host instance structure
2132 * and return success.
2134 instance->max_channel = 0;
2135 instance->this_id = np->myaddr;
2136 instance->max_id = np->maxwide ? 16 : 8;
2137 instance->max_lun = SYM_CONF_MAX_LUN;
2138 #ifndef SYM_CONF_IOMAPPED
2139 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,3,29)
2140 instance->base = (unsigned long) np->s.mmio_va;
2142 instance->base = (char *) np->s.mmio_va;
2145 instance->irq = np->s.irq;
2146 instance->unique_id = np->s.io_port;
2147 instance->io_port = np->s.io_port;
2148 instance->n_io_port = np->s.io_ws;
2149 instance->dma_channel = 0;
2150 instance->cmd_per_lun = SYM_CONF_MAX_TAG;
2151 instance->can_queue = (SYM_CONF_MAX_START-2);
2152 instance->sg_tablesize = SYM_CONF_MAX_SG;
2153 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,4,0)
2154 instance->max_cmd_len = 16;
2156 instance->select_queue_depths = sym53c8xx_select_queue_depths;
2157 instance->highmem_io = 1;
2159 SYM_UNLOCK_HCB(np, flags);
2161 scsi_set_pci_device(instance, dev->pdev);
2164 * Now let the generic SCSI driver
2165 * look for the SCSI devices on the bus ..
2170 if (!instance) return -1;
2171 printf_info("%s: giving up ...\n", sym_name(np));
2173 sym_free_resources(np, 1);
2174 scsi_unregister(instance);
2181 * Detect and try to read SYMBIOS and TEKRAM NVRAM.
2183 #if SYM_CONF_NVRAM_SUPPORT
2184 static void __init sym_get_nvram(sym_device *devp, sym_nvram *nvp)
2190 devp->device_id = devp->chip.device_id;
2194 * Get access to chip IO registers
2196 #ifdef SYM_CONF_IOMAPPED
2197 request_region(devp->s.io_port, 128, NAME53C8XX);
2199 devp->s.mmio_va = pci_map_mem(devp->s.base_c, 128);
2200 if (!devp->s.mmio_va)
2205 * Try to read SYMBIOS|TEKRAM nvram.
2207 (void) sym_read_nvram(devp, nvp);
2210 * Release access to chip IO registers
2212 #ifdef SYM_CONF_IOMAPPED
2213 release_region(devp->s.io_port, 128);
2215 pci_unmap_mem((u_long) devp->s.mmio_va, 128ul, 1);
2218 #endif /* SYM_CONF_NVRAM_SUPPORT */
2221 * Driver setup from the boot command line
2223 #ifdef SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT
2225 static struct sym_driver_setup
2226 sym_driver_safe_setup __initdata = SYM_LINUX_DRIVER_SAFE_SETUP;
2228 char *sym53c8xx = 0; /* command line passed by insmod */
2229 MODULE_PARM(sym53c8xx, "s");
2232 static void __init sym53c8xx_print_driver_setup(void)
2234 printf_info (NAME53C8XX ": setup="
2235 "mpar:%d,spar:%d,tags:%d,sync:%d,burst:%d,"
2236 "led:%d,wide:%d,diff:%d,irqm:%d, buschk:%d\n",
2237 sym_driver_setup.pci_parity,
2238 sym_driver_setup.scsi_parity,
2239 sym_driver_setup.max_tag,
2240 sym_driver_setup.min_sync,
2241 sym_driver_setup.burst_order,
2242 sym_driver_setup.scsi_led,
2243 sym_driver_setup.max_wide,
2244 sym_driver_setup.scsi_diff,
2245 sym_driver_setup.irq_mode,
2246 sym_driver_setup.scsi_bus_check);
2247 printf_info (NAME53C8XX ": setup="
2248 "hostid:%d,offs:%d,luns:%d,pcifix:%d,revprob:%d,"
2249 "verb:%d,debug:0x%x,setlle_delay:%d\n",
2250 sym_driver_setup.host_id,
2251 sym_driver_setup.max_offs,
2252 sym_driver_setup.max_lun,
2253 sym_driver_setup.pci_fix_up,
2254 sym_driver_setup.reverse_probe,
2255 sym_driver_setup.verbose,
2256 sym_driver_setup.debug,
2257 sym_driver_setup.settle_delay);
2263 #define OPT_PCI_PARITY 1
2264 #define OPT_SCSI_PARITY 2
2265 #define OPT_MAX_TAG 3
2266 #define OPT_MIN_SYNC 4
2267 #define OPT_BURST_ORDER 5
2268 #define OPT_SCSI_LED 6
2269 #define OPT_MAX_WIDE 7
2270 #define OPT_SCSI_DIFF 8
2271 #define OPT_IRQ_MODE 9
2272 #define OPT_SCSI_BUS_CHECK 10
2273 #define OPT_HOST_ID 11
2274 #define OPT_MAX_OFFS 12
2275 #define OPT_MAX_LUN 13
2276 #define OPT_PCI_FIX_UP 14
2278 #define OPT_REVERSE_PROBE 15
2279 #define OPT_VERBOSE 16
2280 #define OPT_DEBUG 17
2281 #define OPT_SETTLE_DELAY 18
2282 #define OPT_USE_NVRAM 19
2283 #define OPT_EXCLUDE 20
2284 #define OPT_SAFE_SETUP 21
2286 static char setup_token[] __initdata =
2306 static int __init get_setup_token(char *p)
2308 char *cur = setup_token;
2312 while (cur != NULL && (pc = strchr(cur, ':')) != NULL) {
2315 if (!strncmp(p, cur, pc - cur))
2321 #endif /* SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT */
2323 int __init sym53c8xx_setup(char *str)
2325 #ifdef SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT
2332 while (cur != NULL && (pc = strchr(cur, ':')) != NULL) {
2344 val = (int) simple_strtoul(pv, &pe, 0);
2346 switch (get_setup_token(cur)) {
2348 sym_driver_setup.max_tag = val;
2349 if (!(pe && *pe == '/'))
2352 while (*pe && *pe != ARG_SEP &&
2353 i < sizeof(sym_driver_setup.tag_ctrl)-1) {
2354 sym_driver_setup.tag_ctrl[i++] = *pe++;
2356 sym_driver_setup.tag_ctrl[i] = '\0';
2358 case OPT_SAFE_SETUP:
2359 memcpy(&sym_driver_setup, &sym_driver_safe_setup,
2360 sizeof(sym_driver_setup));
2364 sym_driver_setup.excludes[xi++] = val;
2367 #define __SIMPLE_OPTION(NAME, name) \
2368 case OPT_ ## NAME : \
2369 sym_driver_setup.name = val;\
2372 __SIMPLE_OPTION(PCI_PARITY, pci_parity)
2373 __SIMPLE_OPTION(SCSI_PARITY, scsi_parity)
2374 __SIMPLE_OPTION(MIN_SYNC, min_sync)
2375 __SIMPLE_OPTION(BURST_ORDER, burst_order)
2376 __SIMPLE_OPTION(SCSI_LED, scsi_led)
2377 __SIMPLE_OPTION(MAX_WIDE, max_wide)
2378 __SIMPLE_OPTION(SCSI_DIFF, scsi_diff)
2379 __SIMPLE_OPTION(IRQ_MODE, irq_mode)
2380 __SIMPLE_OPTION(SCSI_BUS_CHECK, scsi_bus_check)
2381 __SIMPLE_OPTION(HOST_ID, host_id)
2382 __SIMPLE_OPTION(MAX_OFFS, max_offs)
2383 __SIMPLE_OPTION(MAX_LUN, max_lun)
2384 __SIMPLE_OPTION(PCI_FIX_UP, pci_fix_up)
2385 __SIMPLE_OPTION(REVERSE_PROBE, reverse_probe)
2386 __SIMPLE_OPTION(VERBOSE, verbose)
2387 __SIMPLE_OPTION(DEBUG, debug)
2388 __SIMPLE_OPTION(SETTLE_DELAY, settle_delay)
2389 __SIMPLE_OPTION(USE_NVRAM, use_nvram)
2391 #undef __SIMPLE_OPTION
2394 printk("sym53c8xx_setup: unexpected boot option '%.*s' ignored\n", (int)(pc-cur+1), cur);
2398 if ((cur = strchr(cur, ARG_SEP)) != NULL)
2401 #endif /* SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT */
2405 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,3,13)
2407 __setup("sym53c8xx=", sym53c8xx_setup);
2411 #ifdef SYM_CONF_PQS_PDS_SUPPORT
2413 * Detect all NCR PQS/PDS boards and keep track of their bus nr.
2415 * The NCR PQS or PDS card is constructed as a DEC bridge
2416 * behind which sit a proprietary NCR memory controller and
2417 * four or two 53c875s as separate devices. In its usual mode
2418 * of operation, the 875s are slaved to the memory controller
2419 * for all transfers. We can tell if an 875 is part of a
2420 * PQS/PDS or not since if it is, it will be on the same bus
2421 * as the memory controller. To operate with the Linux
2422 * driver, the memory controller is disabled and the 875s
2423 * freed to function independently. The only wrinkle is that
2424 * the preset SCSI ID (which may be zero) must be read in from
2425 * a special configuration space register of the 875
2427 #ifndef SYM_CONF_MAX_PQS_BUS
2428 #define SYM_CONF_MAX_PQS_BUS 16
2430 static int pqs_bus[SYM_CONF_MAX_PQS_BUS] __initdata = { 0 };
2432 static void __init sym_detect_pqs_pds(void)
2435 pcidev_t dev = PCIDEV_NULL;
2437 for(index=0; index < SYM_CONF_MAX_PQS_BUS; index++) {
2440 dev = pci_find_device(0x101a, 0x0009, dev);
2441 if (dev == PCIDEV_NULL) {
2442 pqs_bus[index] = -1;
2445 printf_info(NAME53C8XX ": NCR PQS/PDS memory controller detected on bus %d\n", PciBusNumber(dev));
2446 pci_read_config_byte(dev, 0x44, &tmp);
2447 /* bit 1: allow individual 875 configuration */
2449 pci_write_config_byte(dev, 0x44, tmp);
2450 pci_read_config_byte(dev, 0x45, &tmp);
2451 /* bit 2: drive individual 875 interrupts to the bus */
2453 pci_write_config_byte(dev, 0x45, tmp);
2455 pqs_bus[index] = PciBusNumber(dev);
2458 #endif /* SYM_CONF_PQS_PDS_SUPPORT */
2461 * Read and check the PCI configuration for any detected NCR
2462 * boards and save data for attaching after all boards have
2466 sym53c8xx_pci_init(Scsi_Host_Template *tpnt, pcidev_t pdev, sym_device *device)
2468 u_short vendor_id, device_id, command, status_reg;
2469 u_char cache_line_size;
2470 u_char suggested_cache_line_size = 0;
2471 u_char pci_fix_up = SYM_SETUP_PCI_FIX_UP;
2474 u_long base, base_2, base_io;
2475 u_long base_c, base_2_c, io_port;
2479 /* Choose some short name for this device */
2480 sprintf(device->s.inst_name, "sym.%d.%d.%d",
2482 (int) (PciDeviceFn(pdev) & 0xf8) >> 3,
2483 (int) (PciDeviceFn(pdev) & 7));
2486 * Read needed minimal info from the PCI config space.
2488 vendor_id = PciVendorId(pdev);
2489 device_id = PciDeviceId(pdev);
2490 irq = PciIrqLine(pdev);
2492 i = pci_get_base_address(pdev, 0, &base_io);
2493 io_port = pci_get_base_cookie(pdev, 0);
2495 base_c = pci_get_base_cookie(pdev, i);
2496 i = pci_get_base_address(pdev, i, &base);
2498 base_2_c = pci_get_base_cookie(pdev, i);
2499 (void) pci_get_base_address(pdev, i, &base_2);
2501 io_port &= PCI_BASE_ADDRESS_IO_MASK;
2502 base &= PCI_BASE_ADDRESS_MEM_MASK;
2503 base_2 &= PCI_BASE_ADDRESS_MEM_MASK;
2505 pci_read_config_byte(pdev, PCI_CLASS_REVISION, &revision);
2508 * If user excluded this chip, donnot initialize it.
2511 for (i = 0 ; i < 8 ; i++) {
2512 if (sym_driver_setup.excludes[i] == base_io)
2518 * Leave here if another driver attached the chip.
2520 if (io_port && check_region (io_port, 128)) {
2521 printf_info("%s: IO region 0x%lx[0..127] is in use\n",
2522 sym_name(device), (long) io_port);
2527 * Check if the chip is supported.
2529 chip = sym_lookup_pci_chip_table(device_id, revision);
2531 printf_info("%s: device not supported\n", sym_name(device));
2536 * Check if the chip has been assigned resources we need.
2538 #ifdef SYM_CONF_IOMAPPED
2540 printf_info("%s: IO base address disabled.\n",
2546 printf_info("%s: MMIO base address disabled.\n",
2553 * Ignore Symbios chips controlled by various RAID controllers.
2554 * These controllers set value 0x52414944 at RAM end - 16.
2556 #if defined(__i386__) && !defined(SYM_OPT_NO_BUS_MEMORY_MAPPING)
2558 unsigned int ram_size, ram_val;
2561 if (chip->features & FE_RAM8K)
2566 ram_ptr = pci_map_mem(base_2_c, ram_size);
2568 ram_val = readl_raw(ram_ptr + ram_size - 16);
2569 pci_unmap_mem(ram_ptr, ram_size, 1);
2570 if (ram_val == 0x52414944) {
2571 printf_info("%s: not initializing, "
2572 "driven by RAID controller.\n",
2578 #endif /* i386 and PCI MEMORY accessible */
2581 * Copy the chip description to our device structure,
2582 * so we can make it match the actual device and options.
2584 bcopy(chip, &device->chip, sizeof(device->chip));
2585 device->chip.revision_id = revision;
2588 * Read additionnal info from the configuration space.
2590 pci_read_config_word(pdev, PCI_COMMAND, &command);
2591 pci_read_config_byte(pdev, PCI_CACHE_LINE_SIZE, &cache_line_size);
2594 * Enable missing capabilities in the PCI COMMAND register.
2596 #ifdef SYM_CONF_IOMAPPED
2597 #define PCI_COMMAND_BITS_TO_ENABLE (PCI_COMMAND_IO | \
2598 PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER | PCI_COMMAND_PARITY)
2600 #define PCI_COMMAND_BITS_TO_ENABLE \
2601 (PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER | PCI_COMMAND_PARITY)
2603 if ((command & PCI_COMMAND_BITS_TO_ENABLE)
2604 != PCI_COMMAND_BITS_TO_ENABLE) {
2605 printf_info("%s: setting%s%s%s%s...\n", sym_name(device),
2606 (command & PCI_COMMAND_IO) ? "" : " PCI_COMMAND_IO",
2607 (command & PCI_COMMAND_MEMORY) ? "" : " PCI_COMMAND_MEMORY",
2608 (command & PCI_COMMAND_MASTER) ? "" : " PCI_COMMAND_MASTER",
2609 (command & PCI_COMMAND_PARITY) ? "" : " PCI_COMMAND_PARITY");
2610 command |= PCI_COMMAND_BITS_TO_ENABLE;
2611 pci_write_config_word(pdev, PCI_COMMAND, command);
2613 #undef PCI_COMMAND_BITS_TO_ENABLE
2616 * If cache line size is not configured, suggest
2617 * a value for well known CPUs.
2619 #if defined(__i386__) && !defined(MODULE)
2620 if (!cache_line_size && boot_cpu_data.x86_vendor == X86_VENDOR_INTEL) {
2621 switch(boot_cpu_data.x86) {
2622 case 4: suggested_cache_line_size = 4; break;
2623 case 6: if (boot_cpu_data.x86_model > 8) break;
2624 case 5: suggested_cache_line_size = 8; break;
2627 #endif /* __i386__ */
2630 * Some features are required to be enabled in order to
2631 * work around some chip problems. :) ;)
2632 * (ITEM 12 of a DEL about the 896 I haven't yet).
2633 * We must ensure the chip will use WRITE AND INVALIDATE.
2634 * The revision number limit is for now arbitrary.
2636 if (device_id == PCI_DEVICE_ID_NCR_53C896 && revision < 0x4) {
2637 chip->features |= (FE_WRIE | FE_CLSE);
2638 pci_fix_up |= 3; /* Force appropriate PCI fix-up */
2641 #ifdef SYM_CONF_PCI_FIX_UP
2643 * Try to fix up PCI config according to wished features.
2645 if ((pci_fix_up & 1) && (chip->features & FE_CLSE) &&
2646 !cache_line_size && suggested_cache_line_size) {
2647 cache_line_size = suggested_cache_line_size;
2648 pci_write_config_byte(pdev,
2649 PCI_CACHE_LINE_SIZE, cache_line_size);
2650 printf_info("%s: PCI_CACHE_LINE_SIZE set to %d.\n",
2651 sym_name(device), cache_line_size);
2654 if ((pci_fix_up & 2) && cache_line_size &&
2655 (chip->features & FE_WRIE) && !(command & PCI_COMMAND_INVALIDATE)) {
2656 printf_info("%s: setting PCI_COMMAND_INVALIDATE.\n",
2658 command |= PCI_COMMAND_INVALIDATE;
2659 pci_write_config_word(pdev, PCI_COMMAND, command);
2661 #endif /* SYM_CONF_PCI_FIX_UP */
2664 * Work around for errant bit in 895A. The 66Mhz
2665 * capable bit is set erroneously. Clear this bit.
2668 * Make sure Config space and Features agree.
2670 * Recall: writes are not normal to status register -
2671 * write a 1 to clear and a 0 to leave unchanged.
2672 * Can only reset bits.
2674 pci_read_config_word(pdev, PCI_STATUS, &status_reg);
2675 if (chip->features & FE_66MHZ) {
2676 if (!(status_reg & PCI_STATUS_66MHZ))
2677 chip->features &= ~FE_66MHZ;
2680 if (status_reg & PCI_STATUS_66MHZ) {
2681 status_reg = PCI_STATUS_66MHZ;
2682 pci_write_config_word(pdev, PCI_STATUS, status_reg);
2683 pci_read_config_word(pdev, PCI_STATUS, &status_reg);
2688 * Initialise device structure with items required by sym_attach.
2690 device->pdev = pdev;
2691 device->s.bus = PciBusNumber(pdev);
2692 device->s.device_fn = PciDeviceFn(pdev);
2693 device->s.base = base;
2694 device->s.base_2 = base_2;
2695 device->s.base_c = base_c;
2696 device->s.base_2_c = base_2_c;
2697 device->s.io_port = io_port;
2698 device->s.irq = irq;
2699 device->attach_done = 0;
2705 * List of supported NCR chip ids
2707 static u_short sym_chip_ids[] __initdata = {
2725 * Detect all 53c8xx hosts and then attach them.
2727 * If we are using NVRAM, once all hosts are detected, we need to
2728 * check any NVRAM for boot order in case detect and boot order
2729 * differ and attach them using the order in the NVRAM.
2731 * If no NVRAM is found or data appears invalid attach boards in
2732 * the order they are detected.
2734 int __init sym53c8xx_detect(Scsi_Host_Template *tpnt)
2737 int i, j, chips, hosts, count;
2738 int attach_count = 0;
2739 sym_device *devtbl, *devp;
2741 #if SYM_CONF_NVRAM_SUPPORT
2742 sym_nvram nvram0, *nvp;
2752 * Initialize driver general stuff.
2754 #ifdef SYM_LINUX_PROC_INFO_SUPPORT
2755 #if LINUX_VERSION_CODE < LinuxVersionCode(2,3,27)
2756 tpnt->proc_dir = &proc_scsi_sym53c8xx;
2758 tpnt->proc_name = NAME53C8XX;
2760 tpnt->proc_info = sym53c8xx_proc_info;
2763 #ifdef SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT
2766 sym53c8xx_setup(sym53c8xx);
2768 #ifdef SYM_LINUX_DEBUG_CONTROL_SUPPORT
2769 sym_debug_flags = sym_driver_setup.debug;
2771 if (boot_verbose >= 2)
2772 sym53c8xx_print_driver_setup();
2773 #endif /* SYM_LINUX_BOOT_COMMAND_LINE_SUPPORT */
2776 * Allocate the device table since we donnot want to
2777 * overflow the kernel stack.
2778 * 1 x 4K PAGE is enough for more than 40 devices for i386.
2780 devtbl = sym_calloc(PAGE_SIZE, "DEVTBL");
2785 * Detect all NCR PQS/PDS memory controllers.
2787 #ifdef SYM_CONF_PQS_PDS_SUPPORT
2788 sym_detect_pqs_pds();
2792 * Detect all 53c8xx hosts.
2793 * Save the first Symbios NVRAM content if any
2794 * for the boot order.
2796 chips = sizeof(sym_chip_ids) / sizeof(sym_chip_ids[0]);
2797 hosts = PAGE_SIZE / sizeof(*devtbl);
2798 #if SYM_CONF_NVRAM_SUPPORT
2799 nvp = (sym_driver_setup.use_nvram & 0x1) ? &nvram0 : 0;
2803 pcidev = PCIDEV_NULL;
2810 i = sym_driver_setup.reverse_probe ? chips - 1 - j : j;
2811 pcidev = pci_find_device(PCI_VENDOR_ID_NCR, sym_chip_ids[i],
2813 if (pcidev == PCIDEV_NULL) {
2817 /* This one is guaranteed by AC to do nothing :-) */
2818 if (pci_enable_device(pcidev))
2820 /* Some HW as the HP LH4 may report twice PCI devices */
2821 for (i = 0; i < count ; i++) {
2822 if (devtbl[i].s.bus == PciBusNumber(pcidev) &&
2823 devtbl[i].s.device_fn == PciDeviceFn(pcidev))
2826 if (i != count) /* Ignore this device if we already have it */
2828 devp = &devtbl[count];
2829 devp->host_id = SYM_SETUP_HOST_ID;
2830 devp->attach_done = 0;
2831 if (sym53c8xx_pci_init(tpnt, pcidev, devp)) {
2835 #if SYM_CONF_NVRAM_SUPPORT
2837 sym_get_nvram(devp, nvp);
2839 case SYM_SYMBIOS_NVRAM:
2841 * Switch to the other nvram buffer, so that
2842 * nvram0 will contain the first Symbios
2843 * format NVRAM content with boot order.
2846 msg = "with Symbios NVRAM";
2848 case SYM_TEKRAM_NVRAM:
2849 msg = "with Tekram NVRAM";
2854 #ifdef SYM_CONF_PQS_PDS_SUPPORT
2856 * Match the BUS number for PQS/PDS devices.
2857 * Read the SCSI ID from a special register mapped
2858 * into the configuration space of the individual
2859 * 875s. This register is set up by the PQS bios
2861 for(i = 0; i < SYM_CONF_MAX_PQS_BUS && pqs_bus[i] != -1; i++) {
2863 if (pqs_bus[i] == PciBusNumber(pcidev)) {
2864 pci_read_config_byte(pcidev, 0x84, &tmp);
2866 devp->host_id = tmp;
2871 msg = "(NCR PQS/PDS)";
2874 printf_info("%s: 53c%s detected %s\n",
2875 sym_name(devp), devp->chip.name, msg);
2879 * If we have found a SYMBIOS NVRAM, use first the NVRAM boot
2880 * sequence as device boot order.
2881 * check devices in the boot record against devices detected.
2882 * attach devices if we find a match. boot table records that
2883 * do not match any detected devices will be ignored.
2884 * devices that do not match any boot table will not be attached
2885 * here but will attempt to be attached during the device table
2888 #if SYM_CONF_NVRAM_SUPPORT
2889 if (!nvp || nvram0.type != SYM_SYMBIOS_NVRAM)
2891 for (i = 0; i < 4; i++) {
2892 Symbios_host *h = &nvram0.data.Symbios.host[i];
2893 for (j = 0 ; j < count ; j++) {
2895 if (h->device_fn != devp->s.device_fn ||
2896 h->bus_nr != devp->s.bus ||
2897 h->device_id != devp->chip.device_id)
2899 if (devp->attach_done)
2901 if (h->flags & SYMBIOS_INIT_SCAN_AT_BOOT) {
2902 sym_get_nvram(devp, nvp);
2903 if (!sym_attach (tpnt, attach_count, devp))
2906 else if (!(sym_driver_setup.use_nvram & 0x80))
2908 "%s: 53c%s state OFF thus not attached\n",
2909 sym_name(devp), devp->chip.name);
2913 devp->attach_done = 1;
2921 * Rescan device list to make sure all boards attached.
2922 * Devices without boot records will not be attached yet
2923 * so try to attach them here.
2925 for (i= 0; i < count; i++) {
2927 if (!devp->attach_done) {
2928 devp->nvram = &nvram;
2930 #if SYM_CONF_NVRAM_SUPPORT
2931 sym_get_nvram(devp, nvp);
2933 if (!sym_attach (tpnt, attach_count, devp))
2938 sym_mfree(devtbl, PAGE_SIZE, "DEVTBL");
2940 return attach_count;
2947 * Linux release module stuff.
2949 * Called before unloading the module.
2951 * We have to free resources and halt the NCR chip.
2954 static int sym_detach(hcb_p np)
2956 printk("%s: detaching ...\n", sym_name(np));
2959 * Try to delete the timer.
2960 * In the unlikely situation where this failed,
2961 * try to synchronize with the timer handler.
2963 #if LINUX_VERSION_CODE < LinuxVersionCode(2, 4, 0)
2964 np->s.release_stage = 1;
2965 if (!del_timer(&np->s.timer)) {
2970 SYM_LOCK_HCB(np, flags);
2971 k = np->s.release_stage;
2972 SYM_UNLOCK_HCB(np, flags);
2978 printk("%s: failed to kill timer!\n", sym_name(np));
2980 np->s.release_stage = 2;
2982 (void)del_timer_sync(&np->s.timer);
2987 * We should use sym_soft_reset(), but we donnot want to do
2988 * so, since we may not be safe if interrupts occur.
2990 printk("%s: resetting chip\n", sym_name(np));
2991 OUTB (nc_istat, SRST);
2996 * Free host resources
2998 sym_free_resources(np, 0);
3003 int sym53c8xx_release(struct Scsi_Host *host)
3005 sym_detach(((struct host_data *) host->hostdata)->ncb);
3012 * For bigots to keep silent. :)
3014 #ifdef MODULE_LICENSE
3015 MODULE_LICENSE("Dual BSD/GPL");
3019 * Driver host template.
3021 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,4,0)
3024 #if LINUX_VERSION_CODE >= LinuxVersionCode(2,4,0) || defined(MODULE)
3025 Scsi_Host_Template driver_template = SYM53C8XX;
3026 #include "../scsi_module.c"