2  * Detection routine for the NCR53c710 based Amiga SCSI Controllers for Linux.
 
   3  *              Amiga MacroSystemUS WarpEngine SCSI controller.
 
   4  *              Amiga Technologies A4000T SCSI controller.
 
   5  *              Amiga Technologies/DKB A4091 SCSI controller.
 
   7  * Written 1997 by Alan Hourihane <alanh@fairlite.demon.co.uk>
 
   8  * plus modifications of the 53c7xx.c driver to support the Amiga.
 
  10 #include <linux/types.h>
 
  12 #include <linux/blkdev.h>
 
  13 #include <linux/sched.h>
 
  14 #include <linux/version.h>
 
  15 #include <linux/config.h>
 
  16 #include <linux/zorro.h>
 
  17 #include <linux/stat.h>
 
  19 #include <asm/setup.h>
 
  21 #include <asm/pgtable.h>
 
  22 #include <asm/amigaints.h>
 
  23 #include <asm/amigahw.h>
 
  28 #include <scsi/scsi_host.h>
 
  33 static int amiga7xx_register_one(Scsi_Host_Template *tpnt,
 
  34                                  unsigned long address)
 
  39     if (!request_mem_region(address, 0x1000, "ncr53c710"))
 
  42     address = (unsigned long)z_ioremap(address, 0x1000);
 
  43     options = OPTION_MEMORY_MAPPED | OPTION_DEBUG_TEST1 | OPTION_INTFLY |
 
  44               OPTION_SYNCHRONOUS | OPTION_ALWAYS_SYNCHRONOUS |
 
  46     clock = 50000000;   /* 50 MHz SCSI Clock */
 
  47     ncr53c7xx_init(tpnt, 0, 710, address, 0, IRQ_AMIGA_PORTS, DMA_NONE,
 
  58     int absolute;       /* offset is absolute address */
 
  59 } amiga7xx_table[] = {
 
  60     { .id = ZORRO_PROD_PHASE5_BLIZZARD_603E_PLUS, .offset = 0xf40000,
 
  62     { .id = ZORRO_PROD_MACROSYSTEMS_WARP_ENGINE_40xx, .offset = 0x40000 },
 
  63     { .id = ZORRO_PROD_CBM_A4091_1, .offset = 0x800000 },
 
  64     { .id = ZORRO_PROD_CBM_A4091_2, .offset = 0x800000 },
 
  65     { .id = ZORRO_PROD_GVP_GFORCE_040_060, .offset = 0x40000 },
 
  69 static int __init amiga7xx_zorro_detect(Scsi_Host_Template *tpnt)
 
  72     struct zorro_dev *z = NULL;
 
  73     unsigned long address;
 
  75     while ((z = zorro_find_device(ZORRO_WILDCARD, z))) {
 
  76         for (i = 0; amiga7xx_table[i].id; i++)
 
  77             if (z->id == amiga7xx_table[i].id)
 
  79         if (!amiga7xx_table[i].id)
 
  81         if (amiga7xx_table[i].absolute)
 
  82             address = amiga7xx_table[i].offset;
 
  84             address = z->resource.start + amiga7xx_table[i].offset;
 
  85         num += amiga7xx_register_one(tpnt, address);
 
  90 #endif /* CONFIG_ZORRO */
 
  93 int __init amiga7xx_detect(Scsi_Host_Template *tpnt)
 
  95     static unsigned char called = 0;
 
  98     if (called || !MACH_IS_AMIGA)
 
 101     tpnt->proc_name = "Amiga7xx";
 
 103     if (AMIGAHW_PRESENT(A4000_SCSI))
 
 104         num += amiga7xx_register_one(tpnt, 0xdd0040);
 
 107     num += amiga7xx_zorro_detect(tpnt);
 
 114 static int amiga7xx_release(struct Scsi_Host *shost)
 
 117                 free_irq(shost->irq, NULL);
 
 118         if (shost->dma_channel != 0xff)
 
 119                 free_dma(shost->dma_channel);
 
 120         if (shost->io_port && shost->n_io_port)
 
 121                 release_region(shost->io_port, shost->n_io_port);
 
 122         scsi_unregister(shost);
 
 126 static Scsi_Host_Template driver_template = {
 
 127         .name                   = "Amiga NCR53c710 SCSI",
 
 128         .detect                 = amiga7xx_detect,
 
 129         .release                = amiga7xx_release,
 
 130         .queuecommand           = NCR53c7xx_queue_command,
 
 131         .abort                  = NCR53c7xx_abort,
 
 132         .reset                  = NCR53c7xx_reset,
 
 137         .use_clustering         = DISABLE_CLUSTERING
 
 141 #include "scsi_module.c"