MAINTAINERS | 4 drivers/scsi/Kconfig | 52 ++++----- drivers/scsi/sym53c8xx_2/sym53c8xx.h | 16 -- drivers/scsi/sym53c8xx_2/sym_fw.c | 34 ------ drivers/scsi/sym53c8xx_2/sym_fw.h | 8 - drivers/scsi/sym53c8xx_2/sym_fw1.h | 23 ---- drivers/scsi/sym53c8xx_2/sym_fw2.h | 54 --------- drivers/scsi/sym53c8xx_2/sym_glue.c | 90 ++++++---------- drivers/scsi/sym53c8xx_2/sym_glue.h | 5 drivers/scsi/sym53c8xx_2/sym_hipd.c | 24 +--- drivers/scsi/sym53c8xx_2/sym_hipd.h | 36 ++---- drivers/scsi/sym53c8xx_2/sym_malloc.c | 14 -- drivers/scsi/sym53c8xx_2/sym_nvram.c | 185 +++++++++++++--------------------- 13 files changed, 159 insertions(+), 386 deletions(-) diff -puN drivers/scsi/Kconfig~sym-2.1.18f drivers/scsi/Kconfig --- 25/drivers/scsi/Kconfig~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/Kconfig 2003-11-04 22:01:46.000000000 -0800 @@ -919,37 +919,34 @@ config SCSI_SYM53C8XX_DMA_ADDRESSING_MOD depends on SCSI_SYM53C8XX_2 default "1" ---help--- - This option only applies to PCI-SCSI chip that are PCI DAC capable - (875A, 895A, 896, 1010-33, 1010-66, 1000). + This option only applies to PCI-SCSI chips that are PCI DAC + capable (875A, 895A, 896, 1010-33, 1010-66, 1000). - When set to 0, only PCI 32 bit DMA addressing (SAC) will be performed. - When set to 1, 40 bit DMA addressing (with upper 24 bits of address - set to zero) is supported. The addressable range is here 1 TB. - When set to 2, full 64 bits of address for DMA are supported, but only - 16 segments of 4 GB can be addressed. The addressable range is so - limited to 64 GB. - - The safest value is 0 (32 bit DMA addressing) that is guessed to still - fit most of real machines. - - The preferred value 1 (40 bit DMA addressing) should make happy - properly engineered PCI DAC capable host bridges. You may configure - this option for Intel platforms with more than 4 GB of memory. - - The still experimental value 2 (64 bit DMA addressing with 16 x 4GB - segments limitation) can be used on systems that require PCI address - bits past bit 39 to be set for the addressing of memory using PCI - DAC cycles. + When set to 0, the driver will program the chip to only perform + 32-bit DMA. When set to 1, the chip will be able to perform DMA + to addresses up to 1TB. When set to 2, the driver supports the + full 64-bit DMA address range, but can only address 16 segments + of 4 GB each. This limits the total addressable range to 64 GB. + + Most machines with less than 4GB of memory should use a setting + of 0 for best performance. If your machine has 4GB of memory + or more, you should set this option to 1 (the default). + + The still experimental value 2 (64 bit DMA addressing with 16 + x 4GB segments limitation) can be used on systems that require + PCI address bits past bit 39 to be set for the addressing of + memory using PCI DAC cycles. config SCSI_SYM53C8XX_DEFAULT_TAGS int "default tagged command queue depth" depends on SCSI_SYM53C8XX_2 default "16" help - This is the default value of the command queue depth the driver will - announce to the generic SCSI layer for devices that support tagged - command queueing. This value can be changed from the boot command line. - This is a soft limit that cannot exceed CONFIG_SCSI_SYM53C8XX_MAX_TAGS. + This is the default value of the command queue depth the + driver will announce to the generic SCSI layer for devices + that support tagged command queueing. This value can be changed + from the boot command line. This is a soft limit that cannot + exceed CONFIG_SCSI_SYM53C8XX_MAX_TAGS. config SCSI_SYM53C8XX_MAX_TAGS int "maximum number of queued commands" @@ -962,11 +959,12 @@ config SCSI_SYM53C8XX_MAX_TAGS This value is used as a compiled-in hard limit. config SCSI_SYM53C8XX_IOMAPPED - bool "use normal IO" + bool "use port IO" depends on SCSI_SYM53C8XX_2 help - If you say Y here, the driver will preferently use normal IO rather than - memory mapped IO. + If you say Y here, the driver will use port IO to access + the card. This is significantly slower then using memory + mapped IO. Most people should answer N. config SCSI_ZALON tristate "Zalon SCSI support" diff -puN drivers/scsi/sym53c8xx_2/sym53c8xx.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym53c8xx.h --- 25/drivers/scsi/sym53c8xx_2/sym53c8xx.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym53c8xx.h 2003-11-04 22:01:46.000000000 -0800 @@ -55,19 +55,7 @@ #include -/* - * 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) +#ifdef CONFIG_SCSI_SYM53C8XX_IOMAPPED #define SYM_CONF_IOMAPPED #endif @@ -93,8 +81,6 @@ */ #if 1 #define SYM_CONF_NVRAM_SUPPORT (1) -#define SYM_SETUP_SYMBIOS_NVRAM (1) -#define SYM_SETUP_TEKRAM_NVRAM (1) #endif /* diff -puN drivers/scsi/sym53c8xx_2/sym_fw1.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_fw1.h --- 25/drivers/scsi/sym53c8xx_2/sym_fw1.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_fw1.h 2003-11-04 22:01:46.000000000 -0800 @@ -234,10 +234,6 @@ struct SYM_FWB_SCR { struct SYM_FWZ_SCR { u32 snooptest [ 9]; u32 snoopend [ 2]; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - u32 start_ram [ 1]; - u32 scripta0_ba [ 4]; -#endif }; static struct SYM_FWA_SCR SYM_FWA_SCR = { @@ -1851,24 +1847,5 @@ static struct SYM_FWZ_SCR SYM_FWZ_SCR = */ SCR_INT, 99, -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - /* - * We may use MEMORY MOVE instructions to load the on chip-RAM, - * if it happens that mapping PCI memory is not possible. - * But writing the RAM from the CPU is the preferred method, - * since PCI 2.2 seems to disallow PCI self-mastering. - */ -}/*-------------------------< START_RAM >------------------------*/,{ - /* - * Load the script into on-chip RAM, - * and jump to start point. - */ - SCR_COPY (sizeof(struct SYM_FWA_SCR)), -}/*-------------------------< SCRIPTA0_BA >----------------------*/,{ - 0, - PADDR_A (start), - SCR_JUMP, - PADDR_A (init), -#endif /* SYM_OPT_NO_BUS_MEMORY_MAPPING */ }/*--------------------------<>----------------------------------*/ }; diff -puN drivers/scsi/sym53c8xx_2/sym_fw2.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_fw2.h --- 25/drivers/scsi/sym53c8xx_2/sym_fw2.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_fw2.h 2003-11-04 22:01:46.000000000 -0800 @@ -228,14 +228,6 @@ struct SYM_FWB_SCR { struct SYM_FWZ_SCR { u32 snooptest [ 6]; u32 snoopend [ 2]; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - u32 start_ram [ 1]; - u32 scripta0_ba [ 4]; - u32 start_ram64 [ 3]; - u32 scripta0_ba64 [ 3]; - u32 scriptb0_ba64 [ 6]; - u32 ram_seg64 [ 1]; -#endif }; static struct SYM_FWA_SCR SYM_FWA_SCR = { @@ -1944,51 +1936,5 @@ static struct SYM_FWZ_SCR SYM_FWZ_SCR = */ SCR_INT, 99, -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - /* - * We may use MEMORY MOVE instructions to load the on chip-RAM, - * if it happens that mapping PCI memory is not possible. - * But writing the RAM from the CPU is the preferred method, - * since PCI 2.2 seems to disallow PCI self-mastering. - */ -}/*-------------------------< START_RAM >------------------------*/,{ - /* - * Load the script into on-chip RAM, - * and jump to start point. - */ - SCR_COPY (sizeof(struct SYM_FWA_SCR)), -}/*-------------------------< SCRIPTA0_BA >----------------------*/,{ - 0, - PADDR_A (start), - SCR_JUMP, - PADDR_A (init), -}/*-------------------------< START_RAM64 >----------------------*/,{ - /* - * Load the RAM and start for 64 bit PCI (895A,896). - * Both scripts (script and scripth) are loaded into - * the RAM which is 8K (4K for 825A/875/895). - * We also need to load some 32-63 bit segments - * address of the SCRIPTS processor. - * LOAD/STORE ABSOLUTE always refers to on-chip RAM - * in our implementation. The main memory is - * accessed using LOAD/STORE DSA RELATIVE. - */ - SCR_LOAD_REL (mmws, 4), - offsetof (struct sym_hcb, scr_ram_seg), - SCR_COPY (sizeof(struct SYM_FWA_SCR)), -}/*-------------------------< SCRIPTA0_BA64 >--------------------*/,{ - 0, - PADDR_A (start), - SCR_COPY (sizeof(struct SYM_FWB_SCR)), -}/*-------------------------< SCRIPTB0_BA64 >--------------------*/,{ - 0, - PADDR_B (start64), - SCR_LOAD_REL (mmrs, 4), - offsetof (struct sym_hcb, scr_ram_seg), - SCR_JUMP64, - PADDR_B (start64), -}/*-------------------------< RAM_SEG64 >------------------------*/,{ - 0, -#endif /* SYM_OPT_NO_BUS_MEMORY_MAPPING */ }/*-------------------------<>-----------------------------------*/ }; diff -puN drivers/scsi/sym53c8xx_2/sym_fw.c~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_fw.c --- 25/drivers/scsi/sym53c8xx_2/sym_fw.c~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_fw.c 2003-11-04 22:01:46.000000000 -0800 @@ -89,9 +89,6 @@ static struct sym_fwb_ofs sym_fw1b_ofs = }; static struct sym_fwz_ofs sym_fw1z_ofs = { SYM_GEN_FW_Z(struct SYM_FWZ_SCR) -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - SYM_GEN_Z(struct SYM_FWZ_SCR, start_ram) -#endif }; #undef SYM_FWA_SCR #undef SYM_FWB_SCR @@ -122,10 +119,6 @@ static struct sym_fwb_ofs sym_fw2b_ofs = }; static struct sym_fwz_ofs sym_fw2z_ofs = { SYM_GEN_FW_Z(struct SYM_FWZ_SCR) -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - SYM_GEN_Z(struct SYM_FWZ_SCR, start_ram) - SYM_GEN_Z(struct SYM_FWZ_SCR, start_ram64) -#endif }; #undef SYM_FWA_SCR #undef SYM_FWB_SCR @@ -146,22 +139,10 @@ sym_fw1_patch(hcb_p np) { struct sym_fw1a_scr *scripta0; struct sym_fw1b_scr *scriptb0; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - struct sym_fw1z_scr *scriptz0 = - (struct sym_fw1z_scr *) np->scriptz0; -#endif scripta0 = (struct sym_fw1a_scr *) np->scripta0; scriptb0 = (struct sym_fw1b_scr *) np->scriptb0; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - /* - * Set up BUS physical address of SCRIPTS that is to - * be copied to on-chip RAM by the SCRIPTS processor. - */ - scriptz0->scripta0_ba[0] = cpu_to_scr(vtobus(scripta0)); -#endif - /* * Remove LED support if not needed. */ @@ -199,25 +180,10 @@ sym_fw2_patch(hcb_p np) { struct sym_fw2a_scr *scripta0; struct sym_fw2b_scr *scriptb0; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - struct sym_fw2z_scr *scriptz0 = - (struct sym_fw2z_scr *) np->scriptz0; -#endif scripta0 = (struct sym_fw2a_scr *) np->scripta0; scriptb0 = (struct sym_fw2b_scr *) np->scriptb0; -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - /* - * Set up BUS physical address of SCRIPTS that is to - * be copied to on-chip RAM by the SCRIPTS processor. - */ - scriptz0->scripta0_ba64[0] = /* Nothing is missing here */ - scriptz0->scripta0_ba[0] = cpu_to_scr(vtobus(scripta0)); - scriptz0->scriptb0_ba64[0] = cpu_to_scr(vtobus(scriptb0)); - scriptz0->ram_seg64[0] = np->scr_ram_seg; -#endif - /* * Remove LED support if not needed. */ diff -puN drivers/scsi/sym53c8xx_2/sym_fw.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_fw.h --- 25/drivers/scsi/sym53c8xx_2/sym_fw.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_fw.h 2003-11-04 22:01:46.000000000 -0800 @@ -113,10 +113,6 @@ struct sym_fwb_ofs { }; struct sym_fwz_ofs { SYM_GEN_FW_Z(u_short) -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - SYM_GEN_Z(u_short, start_ram) - SYM_GEN_Z(u_short, start_ram64) -#endif }; /* @@ -136,10 +132,6 @@ struct sym_fwb_ba { }; struct sym_fwz_ba { SYM_GEN_FW_Z(u32) -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - SYM_GEN_Z(u32, start_ram) - SYM_GEN_Z(u32, start_ram64) -#endif }; #undef SYM_GEN_A #undef SYM_GEN_B diff -puN drivers/scsi/sym53c8xx_2/sym_glue.c~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_glue.c --- 25/drivers/scsi/sym53c8xx_2/sym_glue.c~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_glue.c 2003-11-04 22:01:46.000000000 -0800 @@ -167,34 +167,16 @@ struct sym_ucmd { /* Override the SCSI #define SYM_SCMD_PTR(ucmd) sym_que_entry(ucmd, struct scsi_cmnd, SCp) #define SYM_SOFTC_PTR(cmd) (((struct host_data *)cmd->device->host->hostdata)->ncb) -/* - * Deal with DMA mapping/unmapping. - */ -#define bus_unmap_sg(pdev, sgptr, sgcnt, dir) \ - pci_unmap_sg(pdev, sgptr, sgcnt, dir) -#define bus_unmap_single(pdev, mapping, bufptr, dir) \ - pci_unmap_single(pdev, mapping, bufptr, dir) -#define bus_map_single(pdev, bufptr, bufsiz, dir) \ - pci_map_single(pdev, bufptr, bufsiz, dir) -#define bus_map_sg(pdev, sgptr, sgcnt, dir) \ - pci_map_sg(pdev, sgptr, sgcnt, dir) -#define bus_dma_sync_sg(pdev, sgptr, sgcnt, dir) \ - pci_dma_sync_sg(pdev, sgptr, sgcnt, dir) -#define bus_dma_sync_single(pdev, mapping, bufsiz, dir) \ - pci_dma_sync_single(pdev, mapping, bufsiz, dir) -#define bus_sg_dma_address(sc) sg_dma_address(sc) -#define bus_sg_dma_len(sc) sg_dma_len(sc) - static void __unmap_scsi_data(struct pci_dev *pdev, struct scsi_cmnd *cmd) { int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction); switch(SYM_UCMD_PTR(cmd)->data_mapped) { case 2: - bus_unmap_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); + pci_unmap_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); break; case 1: - bus_unmap_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping, + pci_unmap_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping, cmd->request_bufflen, dma_dir); break; } @@ -206,7 +188,7 @@ static dma_addr_t __map_scsi_single_data dma_addr_t mapping; int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction); - mapping = bus_map_single(pdev, cmd->request_buffer, + mapping = pci_map_single(pdev, cmd->request_buffer, cmd->request_bufflen, dma_dir); if (mapping) { SYM_UCMD_PTR(cmd)->data_mapped = 1; @@ -221,7 +203,7 @@ static int __map_scsi_sg_data(struct pci int use_sg; int dma_dir = scsi_to_pci_dma_dir(cmd->sc_data_direction); - use_sg = bus_map_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); + use_sg = pci_map_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); if (use_sg > 0) { SYM_UCMD_PTR(cmd)->data_mapped = 2; SYM_UCMD_PTR(cmd)->data_mapping = use_sg; @@ -236,10 +218,10 @@ static void __sync_scsi_data(struct pci_ switch(SYM_UCMD_PTR(cmd)->data_mapped) { case 2: - bus_dma_sync_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); + pci_dma_sync_sg(pdev, cmd->buffer, cmd->use_sg, dma_dir); break; case 1: - bus_dma_sync_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping, + pci_dma_sync_single(pdev, SYM_UCMD_PTR(cmd)->data_mapping, cmd->request_bufflen, dma_dir); break; } @@ -469,8 +451,8 @@ static int sym_scatter(struct sym_hcb *n data = &cp->phys.data[SYM_CONF_MAX_SG - use_sg]; for (segment = 0; segment < use_sg; segment++) { - dma_addr_t baddr = bus_sg_dma_address(&scatter[segment]); - unsigned int len = bus_sg_dma_len(&scatter[segment]); + dma_addr_t baddr = sg_dma_address(&scatter[segment]); + unsigned int len = sg_dma_len(&scatter[segment]); sym_build_sge(np, &data[segment], baddr, len); cp->data_len += len; @@ -1595,10 +1577,8 @@ static void sym_free_resources(struct sy if (np->s.mmio_va) iounmap(np->s.mmio_va); #endif -#ifndef SYM_OPT_NO_BUS_MEMORY_MAPPING if (np->s.ram_va) iounmap(np->s.ram_va); -#endif /* * Free O/S independent resources. */ @@ -1650,14 +1630,13 @@ out_err32: * If all is OK, install interrupt handling and * start the timer daemon. */ -static int __devinit -sym_attach (struct scsi_host_template *tpnt, int unit, struct sym_device *dev) +static struct Scsi_Host * __devinit sym_attach(struct scsi_host_template *tpnt, + int unit, struct sym_device *dev) { struct host_data *host_data; struct sym_hcb *np = NULL; struct Scsi_Host *instance = NULL; unsigned long flags; - struct sym_nvram *nvram = dev->nvram; struct sym_fw *fw; printk(KERN_INFO @@ -1762,20 +1741,18 @@ sym_attach (struct scsi_host_template *t np->ram_ws = 8192; else np->ram_ws = 4096; -#ifndef SYM_OPT_NO_BUS_MEMORY_MAPPING np->s.ram_va = ioremap(dev->s.base_2_c, np->ram_ws); if (!np->s.ram_va) { printf_err("%s: can't map PCI MEMORY region\n", sym_name(np)); goto attach_failed; } -#endif } /* * Perform O/S independent stuff. */ - if (sym_hcb_attach(np, fw, nvram)) + if (sym_hcb_attach(np, fw, dev->nvram)) goto attach_failed; @@ -1843,13 +1820,7 @@ sym_attach (struct scsi_host_template *t spin_unlock_irqrestore(instance->host_lock, flags); - /* - * Now let the generic SCSI driver - * look for the SCSI devices on the bus .. - */ - scsi_add_host(instance, &dev->pdev->dev); /* XXX: handle failure */ - scsi_scan_host(instance); - return 0; + return instance; reset_failed: printf_err("%s: FATAL ERROR: CHECK SCSI BUS - CABLES, " @@ -1857,13 +1828,13 @@ sym_attach (struct scsi_host_template *t spin_unlock_irqrestore(instance->host_lock, flags); attach_failed: if (!instance) - return -1; + return NULL; printf_info("%s: giving up ...\n", sym_name(np)); if (np) sym_free_resources(np); scsi_host_put(instance); - return -1; + return NULL; } @@ -2115,7 +2086,7 @@ sym53c8xx_pci_init(struct pci_dev *pdev, * Ignore Symbios chips controlled by various RAID controllers. * These controllers set value 0x52414944 at RAM end - 16. */ -#if defined(__i386__) && !defined(SYM_OPT_NO_BUS_MEMORY_MAPPING) +#if defined(__i386__) if (base_2_c) { unsigned int ram_size, ram_val; void *ram_ptr; @@ -2202,12 +2173,9 @@ sym53c8xx_pci_init(struct pci_dev *pdev, /* - * Linux release module stuff. - * * Called before unloading the module. * Detach the host. * We have to free resources and halt the NCR chip. - * */ static int __devexit sym_detach(struct sym_hcb *np) { @@ -2216,18 +2184,15 @@ static int __devexit sym_detach(struct s del_timer_sync(&np->s.timer); /* - * Reset NCR chip. - * We should use sym_soft_reset(), but we donnot want to do - * so, since we may not be safe if interrupts occur. + * Reset NCR chip. + * We should use sym_soft_reset(), but we don't want to do + * so, since we may not be safe if interrupts occur. */ printk("%s: resetting chip\n", sym_name(np)); OUTB (nc_istat, SRST); UDELAY (10); OUTB (nc_istat, 0); - /* - * Free host resources - */ sym_free_resources(np); return 1; @@ -2336,6 +2301,7 @@ static int __devinit sym2_probe(struct p { struct sym_device sym_dev; struct sym_nvram nvram; + struct Scsi_Host *instance; memset(&sym_dev, 0, sizeof(sym_dev)); memset(&nvram, 0, sizeof(nvram)); @@ -2354,12 +2320,20 @@ static int __devinit sym2_probe(struct p sym_get_nvram(&sym_dev, &nvram); - if (sym_attach(&sym2_template, attach_count, &sym_dev)) + instance = sym_attach(&sym2_template, attach_count, &sym_dev); + if (!instance) goto free; + if (scsi_add_host(instance, &pdev->dev)) + goto detach; + scsi_scan_host(instance); + attach_count++; + return 0; + detach: + sym_detach(pci_get_drvdata(pdev)); free: pci_release_regions(pdev); disable: @@ -2369,7 +2343,13 @@ static int __devinit sym2_probe(struct p static void __devexit sym2_remove(struct pci_dev *pdev) { - sym_detach(pci_get_drvdata(pdev)); + struct sym_hcb *np = pci_get_drvdata(pdev); + struct Scsi_Host *host = np->s.host; + + scsi_remove_host(host); + scsi_host_put(host); + + sym_detach(np); pci_release_regions(pdev); pci_disable_device(pdev); diff -puN drivers/scsi/sym53c8xx_2/sym_glue.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_glue.h --- 25/drivers/scsi/sym53c8xx_2/sym_glue.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_glue.h 2003-11-04 22:01:46.000000000 -0800 @@ -74,10 +74,6 @@ #define bzero(d, n) memset((d), 0, (n)) #endif -#ifndef bcmp -#define bcmp(a, b, n) memcmp((a), (b), (n)) -#endif - /* * General driver includes. */ @@ -96,7 +92,6 @@ #define SYM_OPT_SNIFF_INQUIRY #define SYM_OPT_LIMIT_COMMAND_REORDERING #define SYM_OPT_ANNOUNCE_TRANSFER_RATE -#define SYM_OPT_BUS_DMA_ABSTRACTION /* * Print a message with severity. diff -puN drivers/scsi/sym53c8xx_2/sym_hipd.c~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_hipd.c --- 25/drivers/scsi/sym53c8xx_2/sym_hipd.c~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_hipd.c 2003-11-04 22:01:46.000000000 -0800 @@ -50,7 +50,7 @@ * SUCH DAMAGE. */ -#define SYM_DRIVER_NAME "sym-2.1.18b" +#define SYM_DRIVER_NAME "sym-2.1.18f" #ifdef __FreeBSD__ #include @@ -751,8 +751,6 @@ static u32 parisc_setup_hcb(hcb_p np, u3 &np->maxwide, &scsi_mode)) return period; - printk("scsi_mode = %d, period = %ld\n", scsi_mode, pdc_period); - if (scsi_mode >= 0) { /* C3000 PDC reports period/mode */ SYM_SETUP_SCSI_DIFF = 0; @@ -1963,13 +1961,6 @@ void sym_start_up (hcb_p np, int reason) if (sym_verbose >= 2) printf ("%s: Downloading SCSI SCRIPTS.\n", sym_name(np)); -#ifdef SYM_OPT_NO_BUS_MEMORY_MAPPING - np->fw_patch(np); - if (np->ram_ws == 8192) - phys = SCRIPTZ_BA (np, start_ram64); - else - phys = SCRIPTZ_BA (np, start_ram); -#else if (np->ram_ws == 8192) { OUTRAM_OFF(4096, np->scriptb0, np->scriptb_sz); phys = scr_to_cpu(np->scr_ram_seg); @@ -1981,7 +1972,6 @@ void sym_start_up (hcb_p np, int reason) else phys = SCRIPTA_BA (np, init); OUTRAM_OFF(0, np->scripta0, np->scripta_sz); -#endif } else phys = SCRIPTA_BA (np, init); @@ -4152,8 +4142,10 @@ sym_ppr_nego_check(hcb_p np, int req, in /* * Check values against our limits. */ - if (wide > np->maxwide) - {chg = 1; wide = np->maxwide;} + if (wide > np->maxwide) { + chg = 1; + wide = np->maxwide; + } if (!wide || !(np->features & FE_ULTRA3)) dt &= ~PPR_OPT_DT; if (req) { @@ -4307,8 +4299,10 @@ sym_wide_nego_check(hcb_p np, int req, i /* * Check values against our limits. */ - if (wide > np->maxwide) - {chg = 1; wide = np->maxwide;} + if (wide > np->maxwide) { + chg = 1; + wide = np->maxwide; + } if (req) { if (wide > tp->tinfo.user.width) {chg = 1; wide = tp->tinfo.user.width;} diff -puN drivers/scsi/sym53c8xx_2/sym_hipd.h~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_hipd.h --- 25/drivers/scsi/sym53c8xx_2/sym_hipd.h~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_hipd.h 2003-11-04 22:01:46.000000000 -0800 @@ -59,12 +59,6 @@ * They may be defined in platform specific headers, if they * are useful. * - * SYM_OPT_NO_BUS_MEMORY_MAPPING - * When this option is set, the driver will not load the - * on-chip RAM using MMIO, but let the SCRIPTS processor - * do the work using MOVE MEMORY instructions. - * (set for Linux/PPC) - * * SYM_OPT_HANDLE_DIR_UNKNOWN * When this option is set, the SCRIPTS used by the driver * are able to handle SCSI transfers with direction not @@ -75,12 +69,6 @@ * When this option is set, the driver will use a queue per * device and handle QUEUE FULL status requeuing internally. * - * SYM_OPT_BUS_DMA_ABSTRACTION - * When this option is set, the driver allocator is responsible - * of maintaining bus physical addresses and so provides virtual - * to bus physical address translation of driver data structures. - * (set for FreeBSD-4 and Linux 2.3) - * * SYM_OPT_SNIFF_INQUIRY * When this option is set, the driver sniff out successful * INQUIRY response and performs negotiations accordingly. @@ -92,10 +80,8 @@ * (set for Linux) */ #if 0 -#define SYM_OPT_NO_BUS_MEMORY_MAPPING #define SYM_OPT_HANDLE_DIR_UNKNOWN #define SYM_OPT_HANDLE_DEVICE_QUEUEING -#define SYM_OPT_BUS_DMA_ABSTRACTION #define SYM_OPT_SNIFF_INQUIRY #define SYM_OPT_LIMIT_COMMAND_REORDERING #endif @@ -958,9 +944,7 @@ struct sym_hcb { /* * DMA pool handle for this HBA. */ -#ifdef SYM_OPT_BUS_DMA_ABSTRACTION m_pool_ident_t bus_dmat; -#endif /* * O/S specific data structure @@ -1133,9 +1117,20 @@ struct sym_hcb { /* * NVRAM reading (sym_nvram.c). */ +#if SYM_CONF_NVRAM_SUPPORT void sym_nvram_setup_host (hcb_p np, struct sym_nvram *nvram); void sym_nvram_setup_target (hcb_p np, int target, struct sym_nvram *nvp); int sym_read_nvram (sdev_p np, struct sym_nvram *nvp); +#else +static inline void sym_nvram_setup_host(hcb_p np, struct sym_nvram *nvram) { } +static inline void sym_nvram_setup_target(hcb_p np, struct sym_nvram *nvram) { } +static inline int sym_read_nvram(sdev_p np, struct sym_nvram *nvp) +{ + nvp->type = 0; + return 0; +} +#endif + /* * FIRMWARES (sym_fw.c) @@ -1347,7 +1342,6 @@ typedef struct sym_m_link { * Virtual to bus physical translation for a given cluster. * Such a structure is only useful with DMA abstraction. */ -#ifdef SYM_OPT_BUS_DMA_ABSTRACTION typedef struct sym_m_vtob { /* Virtual to Bus address translation */ struct sym_m_vtob *next; #ifdef SYM_HAVE_M_SVTOB @@ -1363,7 +1357,6 @@ typedef struct sym_m_vtob { /* Virtual t #define VTOB_HASH_MASK (VTOB_HASH_SIZE-1) #define VTOB_HASH_CODE(m) \ ((((m_addr_t) (m)) >> SYM_MEM_CLUSTER_SHIFT) & VTOB_HASH_MASK) -#endif /* SYM_OPT_BUS_DMA_ABSTRACTION */ /* * Memory pool of a given kind. @@ -1375,7 +1368,6 @@ typedef struct sym_m_vtob { /* Virtual t * method are expected to tell the driver about. */ typedef struct sym_m_pool { -#ifdef SYM_OPT_BUS_DMA_ABSTRACTION m_pool_ident_t dev_dmat; /* Identifies the pool (see above) */ m_addr_t (*get_mem_cluster)(struct sym_m_pool *); #ifdef SYM_MEM_FREE_UNUSED @@ -1389,10 +1381,6 @@ typedef struct sym_m_pool { int nump; m_vtob_p vtob[VTOB_HASH_SIZE]; struct sym_m_pool *next; -#else -#define M_GET_MEM_CLUSTER() sym_get_mem_cluster() -#define M_FREE_MEM_CLUSTER(p) sym_free_mem_cluster(p) -#endif /* SYM_OPT_BUS_DMA_ABSTRACTION */ struct sym_m_link h[SYM_MEM_CLUSTER_SHIFT - SYM_MEM_SHIFT + 1]; } *m_pool_p; @@ -1406,12 +1394,10 @@ void *sym_calloc_unlocked(int size, char * Alloc, free and translate addresses to bus physical * for DMAable memory. */ -#ifdef SYM_OPT_BUS_DMA_ABSTRACTION void *__sym_calloc_dma_unlocked(m_pool_ident_t dev_dmat, int size, char *name); void __sym_mfree_dma_unlocked(m_pool_ident_t dev_dmat, void *m,int size, char *name); u32 __vtobus_unlocked(m_pool_ident_t dev_dmat, void *m); -#endif /* * Verbs used by the driver code for DMAable memory handling. diff -puN drivers/scsi/sym53c8xx_2/sym_malloc.c~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_malloc.c --- 25/drivers/scsi/sym53c8xx_2/sym_malloc.c~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_malloc.c 2003-11-04 22:01:46.000000000 -0800 @@ -204,18 +204,9 @@ static void __sym_mfree(m_pool_p mp, voi /* * Default memory pool we donnot need to involve in DMA. * - * If DMA abtraction is not needed, the generic allocator - * calls directly some kernel allocator. - * * With DMA abstraction, we use functions (methods), to * distinguish between non DMAable memory and DMAable memory. */ -#ifndef SYM_OPT_BUS_DMA_ABSTRACTION - -static struct sym_m_pool mp0; - -#else - static m_addr_t ___mp0_get_mem_cluster(m_pool_p mp) { m_addr_t m = (m_addr_t) sym_get_mem_cluster(); @@ -240,8 +231,6 @@ static struct sym_m_pool mp0 = {0, ___mp0_get_mem_cluster}; #endif -#endif /* SYM_OPT_BUS_DMA_ABSTRACTION */ - /* * Actual memory allocation routine for non-DMAed memory. */ @@ -260,7 +249,6 @@ void sym_mfree_unlocked(void *ptr, int s __sym_mfree(&mp0, ptr, size, name); } -#ifdef SYM_OPT_BUS_DMA_ABSTRACTION /* * Methods that maintains DMAable pools according to user allocations. * New pools are created on the fly when a new pool id is provided. @@ -417,5 +405,3 @@ u32 __vtobus_unlocked(m_pool_ident_t dev panic("sym: VTOBUS FAILED!\n"); return (u32)(vp ? vp->baddr + (((m_addr_t) m) - a) : 0); } - -#endif /* SYM_OPT_BUS_DMA_ABSTRACTION */ diff -puN drivers/scsi/sym53c8xx_2/sym_nvram.c~sym-2.1.18f drivers/scsi/sym53c8xx_2/sym_nvram.c --- 25/drivers/scsi/sym53c8xx_2/sym_nvram.c~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/drivers/scsi/sym53c8xx_2/sym_nvram.c 2003-11-04 22:01:46.000000000 -0800 @@ -59,25 +59,22 @@ /* * Some poor and bogus sync table that refers to Tekram NVRAM layout. */ -#if SYM_CONF_NVRAM_SUPPORT static u_char Tekram_sync[16] = {25,31,37,43, 50,62,75,125, 12,15,18,21, 6,7,9,10}; #ifdef SYM_CONF_DEBUG_NVRAM static u_char Tekram_boot_delay[7] = {3, 5, 10, 20, 30, 60, 120}; #endif -#endif /* * Get host setup from NVRAM. */ -void sym_nvram_setup_host (hcb_p np, struct sym_nvram *nvram) +void sym_nvram_setup_host(struct sym_hcb *np, struct sym_nvram *nvram) { -#if SYM_CONF_NVRAM_SUPPORT /* * Get parity checking, host ID, verbose mode * and miscellaneous host flags from NVRAM. */ - switch(nvram->type) { + switch (nvram->type) { case SYM_SYMBIOS_NVRAM: if (!(nvram->data.Symbios.flags & SYMBIOS_PARITY_ENABLE)) np->rv_scntl0 &= ~0x0a; @@ -95,41 +92,15 @@ void sym_nvram_setup_host (hcb_p np, str default: break; } -#endif -} - -/* - * Get target setup from NVRAM. - */ -#if SYM_CONF_NVRAM_SUPPORT -static void sym_Symbios_setup_target(hcb_p np,int target, Symbios_nvram *nvram); -static void sym_Tekram_setup_target(hcb_p np,int target, Tekram_nvram *nvram); -#endif - -void sym_nvram_setup_target (hcb_p np, int target, struct sym_nvram *nvp) -{ -#if SYM_CONF_NVRAM_SUPPORT - switch(nvp->type) { - case SYM_SYMBIOS_NVRAM: - sym_Symbios_setup_target (np, target, &nvp->data.Symbios); - break; - case SYM_TEKRAM_NVRAM: - sym_Tekram_setup_target (np, target, &nvp->data.Tekram); - break; - default: - break; - } -#endif } -#if SYM_CONF_NVRAM_SUPPORT /* * Get target set-up from Symbios format NVRAM. */ static void -sym_Symbios_setup_target(hcb_p np, int target, Symbios_nvram *nvram) +sym_Symbios_setup_target(struct sym_hcb *np, int target, Symbios_nvram *nvram) { - tcb_p tp = &np->target[target]; + struct sym_tcb *tp = &np->target[target]; Symbios_target *tn = &nvram->target[target]; tp->tinfo.user.period = tn->sync_period ? (tn->sync_period + 3) / 4 : 0; @@ -149,9 +120,9 @@ sym_Symbios_setup_target(hcb_p np, int t * Get target set-up from Tekram format NVRAM. */ static void -sym_Tekram_setup_target(hcb_p np, int target, Tekram_nvram *nvram) +sym_Tekram_setup_target(struct sym_hcb *np, int target, Tekram_nvram *nvram) { - tcb_p tp = &np->target[target]; + struct sym_tcb *tp = &np->target[target]; struct Tekram_target *tn = &nvram->target[target]; int i; @@ -160,8 +131,8 @@ sym_Tekram_setup_target(hcb_p np, int ta tp->tinfo.user.period = Tekram_sync[i]; } - tp->tinfo.user.width = - (tn->flags & TEKRAM_WIDE_NEGO) ? BUS_16_BIT : BUS_8_BIT; + tp->tinfo.user.width = (tn->flags & TEKRAM_WIDE_NEGO) ? + BUS_16_BIT : BUS_8_BIT; if (tn->flags & TEKRAM_TAGGED_COMMANDS) { tp->usrtags = 2 << nvram->max_tags_index; @@ -175,11 +146,28 @@ sym_Tekram_setup_target(hcb_p np, int ta np->rv_scntl0 &= ~0x0a; /* SCSI parity checking disabled */ } +/* + * Get target setup from NVRAM. + */ +void sym_nvram_setup_target(struct sym_hcb *np, int target, struct sym_nvram *nvp) +{ + switch (nvp->type) { + case SYM_SYMBIOS_NVRAM: + sym_Symbios_setup_target(np, target, &nvp->data.Symbios); + break; + case SYM_TEKRAM_NVRAM: + sym_Tekram_setup_target(np, target, &nvp->data.Tekram); + break; + default: + break; + } +} + #ifdef SYM_CONF_DEBUG_NVRAM /* * Dump Symbios format NVRAM for debugging purpose. */ -static void sym_display_Symbios_nvram(sdev_p np, Symbios_nvram *nvram) +static void sym_display_Symbios_nvram(struct sym_device *np, Symbios_nvram *nvram) { int i; @@ -211,7 +199,7 @@ static void sym_display_Symbios_nvram(sd /* * Dump TEKRAM format NVRAM for debugging purpose. */ -static void sym_display_Tekram_nvram(sdev_p np, Tekram_nvram *nvram) +static void sym_display_Tekram_nvram(struct sym_device *np, Tekram_nvram *nvram) { int i, tags, boot_delay; char *rem; @@ -221,7 +209,7 @@ static void sym_display_Tekram_nvram(sde boot_delay = 0; if (nvram->boot_delay_index < 6) boot_delay = Tekram_boot_delay[nvram->boot_delay_index]; - switch((nvram->flags & TEKRAM_REMOVABLE_FLAGS) >> 6) { + switch ((nvram->flags & TEKRAM_REMOVABLE_FLAGS) >> 6) { default: case 0: rem = ""; break; case 1: rem = " REMOVABLE=boot device"; break; @@ -257,49 +245,12 @@ static void sym_display_Tekram_nvram(sde sync); } } -#endif /* SYM_CONF_DEBUG_NVRAM */ -#endif /* SYM_CONF_NVRAM_SUPPORT */ - - -/* - * Try reading Symbios or Tekram NVRAM - */ -#if SYM_CONF_NVRAM_SUPPORT -static int sym_read_Symbios_nvram (sdev_p np, Symbios_nvram *nvram); -static int sym_read_Tekram_nvram (sdev_p np, Tekram_nvram *nvram); -#endif - -int sym_read_nvram (sdev_p np, struct sym_nvram *nvp) -{ -#if SYM_CONF_NVRAM_SUPPORT - /* - * Try to read SYMBIOS nvram. - * Try to read TEKRAM nvram if Symbios nvram not found. - */ - if (SYM_SETUP_SYMBIOS_NVRAM && - !sym_read_Symbios_nvram (np, &nvp->data.Symbios)) { - nvp->type = SYM_SYMBIOS_NVRAM; -#ifdef SYM_CONF_DEBUG_NVRAM - sym_display_Symbios_nvram(np, &nvp->data.Symbios); -#endif - } - else if (SYM_SETUP_TEKRAM_NVRAM && - !sym_read_Tekram_nvram (np, &nvp->data.Tekram)) { - nvp->type = SYM_TEKRAM_NVRAM; -#ifdef SYM_CONF_DEBUG_NVRAM - sym_display_Tekram_nvram(np, &nvp->data.Tekram); -#endif - } - else - nvp->type = 0; #else - nvp->type = 0; -#endif - return nvp->type; -} +static void sym_display_Symbios_nvram(struct sym_device *np, Symbios_nvram *nvram) { } +static void sym_display_Tekram_nvram(struct sym_device *np, Tekram_nvram *nvram) { } +#endif /* SYM_CONF_DEBUG_NVRAM */ -#if SYM_CONF_NVRAM_SUPPORT /* * 24C16 EEPROM reading. * @@ -316,11 +267,11 @@ int sym_read_nvram (sdev_p np, struct sy /* * Set/clear data/clock bit in GPIO0 */ -static void S24C16_set_bit(sdev_p np, u_char write_bit, u_char *gpreg, +static void S24C16_set_bit(struct sym_device *np, u_char write_bit, u_char *gpreg, int bit_mode) { UDELAY (5); - switch (bit_mode){ + switch (bit_mode) { case SET_BIT: *gpreg |= write_bit; break; @@ -342,7 +293,7 @@ static void S24C16_set_bit(sdev_p np, u_ /* * Send START condition to NVRAM to wake it up. */ -static void S24C16_start(sdev_p np, u_char *gpreg) +static void S24C16_start(struct sym_device *np, u_char *gpreg) { S24C16_set_bit(np, 1, gpreg, SET_BIT); S24C16_set_bit(np, 0, gpreg, SET_CLK); @@ -353,7 +304,7 @@ static void S24C16_start(sdev_p np, u_ch /* * Send STOP condition to NVRAM - puts NVRAM to sleep... ZZzzzz!! */ -static void S24C16_stop(sdev_p np, u_char *gpreg) +static void S24C16_stop(struct sym_device *np, u_char *gpreg) { S24C16_set_bit(np, 0, gpreg, SET_CLK); S24C16_set_bit(np, 1, gpreg, SET_BIT); @@ -363,7 +314,7 @@ static void S24C16_stop(sdev_p np, u_cha * Read or write a bit to the NVRAM, * read if GPIO0 input else write if GPIO0 output */ -static void S24C16_do_bit(sdev_p np, u_char *read_bit, u_char write_bit, +static void S24C16_do_bit(struct sym_device *np, u_char *read_bit, u_char write_bit, u_char *gpreg) { S24C16_set_bit(np, write_bit, gpreg, SET_BIT); @@ -378,7 +329,7 @@ static void S24C16_do_bit(sdev_p np, u_c * Output an ACK to the NVRAM after reading, * change GPIO0 to output and when done back to an input */ -static void S24C16_write_ack(sdev_p np, u_char write_bit, u_char *gpreg, +static void S24C16_write_ack(struct sym_device *np, u_char write_bit, u_char *gpreg, u_char *gpcntl) { OUTB (nc_gpcntl, *gpcntl & 0xfe); @@ -390,7 +341,7 @@ static void S24C16_write_ack(sdev_p np, * Input an ACK from NVRAM after writing, * change GPIO0 to input and when done back to an output */ -static void S24C16_read_ack(sdev_p np, u_char *read_bit, u_char *gpreg, +static void S24C16_read_ack(struct sym_device *np, u_char *read_bit, u_char *gpreg, u_char *gpcntl) { OUTB (nc_gpcntl, *gpcntl | 0x01); @@ -402,7 +353,7 @@ static void S24C16_read_ack(sdev_p np, u * WRITE a byte to the NVRAM and then get an ACK to see it was accepted OK, * GPIO0 must already be set as an output */ -static void S24C16_write_byte(sdev_p np, u_char *ack_data, u_char write_data, +static void S24C16_write_byte(struct sym_device *np, u_char *ack_data, u_char write_data, u_char *gpreg, u_char *gpcntl) { int x; @@ -417,7 +368,7 @@ static void S24C16_write_byte(sdev_p np, * READ a byte from the NVRAM and then send an ACK to say we have got it, * GPIO0 must already be set as an input */ -static void S24C16_read_byte(sdev_p np, u_char *read_data, u_char ack_data, +static void S24C16_read_byte(struct sym_device *np, u_char *read_data, u_char ack_data, u_char *gpreg, u_char *gpcntl) { int x; @@ -435,7 +386,7 @@ static void S24C16_read_byte(sdev_p np, /* * Read 'len' bytes starting at 'offset'. */ -static int sym_read_S24C16_nvram (sdev_p np, int offset, u_char *data, int len) +static int sym_read_S24C16_nvram(struct sym_device *np, int offset, u_char *data, int len) { u_char gpcntl, gpreg; u_char old_gpcntl, old_gpreg; @@ -514,7 +465,7 @@ out: * Try reading Symbios NVRAM. * Return 0 if OK. */ -static int sym_read_Symbios_nvram (sdev_p np, Symbios_nvram *nvram) +static int sym_read_Symbios_nvram(struct sym_device *np, Symbios_nvram *nvram) { static u_char Symbios_trailer[6] = {0xfe, 0xfe, 0, 0, 0, 0}; u_char *data = (u_char *) nvram; @@ -528,7 +479,7 @@ static int sym_read_Symbios_nvram (sdev_ /* check valid NVRAM signature, verify byte count and checksum */ if (nvram->type != 0 || - bcmp(nvram->trailer, Symbios_trailer, 6) || + memcmp(nvram->trailer, Symbios_trailer, 6) || nvram->byte_count != len - 12) return 1; @@ -555,7 +506,7 @@ static int sym_read_Symbios_nvram (sdev_ /* * Pulse clock bit in GPIO0 */ -static void T93C46_Clk(sdev_p np, u_char *gpreg) +static void T93C46_Clk(struct sym_device *np, u_char *gpreg) { OUTB (nc_gpreg, *gpreg | 0x04); UDELAY (2); @@ -565,7 +516,7 @@ static void T93C46_Clk(sdev_p np, u_char /* * Read bit from NVRAM */ -static void T93C46_Read_Bit(sdev_p np, u_char *read_bit, u_char *gpreg) +static void T93C46_Read_Bit(struct sym_device *np, u_char *read_bit, u_char *gpreg) { UDELAY (2); T93C46_Clk(np, gpreg); @@ -575,7 +526,7 @@ static void T93C46_Read_Bit(sdev_p np, u /* * Write bit to GPIO0 */ -static void T93C46_Write_Bit(sdev_p np, u_char write_bit, u_char *gpreg) +static void T93C46_Write_Bit(struct sym_device *np, u_char write_bit, u_char *gpreg) { if (write_bit & 0x01) *gpreg |= 0x02; @@ -593,7 +544,7 @@ static void T93C46_Write_Bit(sdev_p np, /* * Send STOP condition to NVRAM - puts NVRAM to sleep... ZZZzzz!! */ -static void T93C46_Stop(sdev_p np, u_char *gpreg) +static void T93C46_Stop(struct sym_device *np, u_char *gpreg) { *gpreg &= 0xef; OUTB (nc_gpreg, *gpreg); @@ -605,7 +556,7 @@ static void T93C46_Stop(sdev_p np, u_cha /* * Send read command and address to NVRAM */ -static void T93C46_Send_Command(sdev_p np, u_short write_data, +static void T93C46_Send_Command(struct sym_device *np, u_short write_data, u_char *read_bit, u_char *gpreg) { int x; @@ -620,7 +571,8 @@ static void T93C46_Send_Command(sdev_p n /* * READ 2 bytes from the NVRAM */ -static void T93C46_Read_Word(sdev_p np, u_short *nvram_data, u_char *gpreg) +static void T93C46_Read_Word(struct sym_device *np, + unsigned short *nvram_data, unsigned char *gpreg) { int x; u_char read_bit; @@ -639,13 +591,13 @@ static void T93C46_Read_Word(sdev_p np, /* * Read Tekram NvRAM data. */ -static int T93C46_Read_Data(sdev_p np, u_short *data,int len,u_char *gpreg) +static int T93C46_Read_Data(struct sym_device *np, unsigned short *data, + int len, unsigned char *gpreg) { - u_char read_bit; - int x; + int x; for (x = 0; x < len; x++) { - + unsigned char read_bit; /* output read command and address */ T93C46_Send_Command(np, 0x180 | x, &read_bit, gpreg); if (read_bit & 0x01) @@ -660,7 +612,7 @@ static int T93C46_Read_Data(sdev_p np, u /* * Try reading 93C46 Tekram NVRAM. */ -static int sym_read_T93C46_nvram (sdev_p np, Tekram_nvram *nvram) +static int sym_read_T93C46_nvram(struct sym_device *np, Tekram_nvram *nvram) { u_char gpcntl, gpreg; u_char old_gpcntl, old_gpreg; @@ -692,7 +644,7 @@ static int sym_read_T93C46_nvram (sdev_p * Try reading Tekram NVRAM. * Return 0 if OK. */ -static int sym_read_Tekram_nvram (sdev_p np, Tekram_nvram *nvram) +static int sym_read_Tekram_nvram (struct sym_device *np, Tekram_nvram *nvram) { u_char *data = (u_char *) nvram; int len = sizeof(*nvram); @@ -700,13 +652,13 @@ static int sym_read_Tekram_nvram (sdev_p int x; switch (np->device_id) { - case PCI_ID_SYM53C885: - case PCI_ID_SYM53C895: - case PCI_ID_SYM53C896: + case PCI_DEVICE_ID_NCR_53C885: + case PCI_DEVICE_ID_NCR_53C895: + case PCI_DEVICE_ID_NCR_53C896: x = sym_read_S24C16_nvram(np, TEKRAM_24C16_NVRAM_ADDRESS, data, len); break; - case PCI_ID_SYM53C875: + case PCI_DEVICE_ID_NCR_53C875: x = sym_read_S24C16_nvram(np, TEKRAM_24C16_NVRAM_ADDRESS, data, len); if (!x) @@ -727,4 +679,19 @@ static int sym_read_Tekram_nvram (sdev_p return 0; } -#endif /* SYM_CONF_NVRAM_SUPPORT */ +/* + * Try reading Symbios or Tekram NVRAM + */ +int sym_read_nvram(struct sym_device *np, struct sym_nvram *nvp) +{ + if (!sym_read_Symbios_nvram(np, &nvp->data.Symbios)) { + nvp->type = SYM_SYMBIOS_NVRAM; + sym_display_Symbios_nvram(np, &nvp->data.Symbios); + } else if (!sym_read_Tekram_nvram(np, &nvp->data.Tekram)) { + nvp->type = SYM_TEKRAM_NVRAM; + sym_display_Tekram_nvram(np, &nvp->data.Tekram); + } else { + nvp->type = 0; + } + return nvp->type; +} diff -puN MAINTAINERS~sym-2.1.18f MAINTAINERS --- 25/MAINTAINERS~sym-2.1.18f 2003-11-04 22:01:46.000000000 -0800 +++ 25-akpm/MAINTAINERS 2003-11-04 22:01:46.000000000 -0800 @@ -1240,8 +1240,8 @@ W: http://ldm.sourceforge.net S: Maintained LSILOGIC/SYMBIOS/NCR 53C8XX and 53C1010 PCI-SCSI drivers -P: Gerard Roudier -M: groudier@free.fr +P: Matthew Wilcox +M: matthew@wil.cx L: linux-scsi@vger.kernel.org S: Maintained _