2  * 53c710 driver.  Modified from Drew Eckhardts driver
 
   3  * for 53c810 by Richard Hirst [richard@sleepie.demon.co.uk]
 
   4  * Check out PERM_OPTIONS and EXPECTED_CLOCK, which may be defined in the
 
   5  * relevant machine specific file (eg. mvme16x.[ch], amiga7xx.[ch]).
 
   6  * There are also currently some defines at the top of 53c7xx.scr.
 
   7  * The chip type is #defined in script_asm.pl, as well as the Makefile.
 
   8  * Host scsi ID expected to be 7 - see NCR53c7x0_init().
 
  10  * I have removed the PCI code and some of the 53c8xx specific code - 
 
  11  * simply to make this file smaller and easier to manage.
 
  14  *   Problems trying to read any chip registers in NCR53c7x0_init(), as they
 
  15  *   may never have been set by 16xBug (eg. If kernel has come in over tftp).
 
  19  * Adapted for Linux/m68k Amiga platforms for the A4000T/A4091 and
 
  20  * WarpEngine SCSI controllers.
 
  21  * By Alan Hourihane <alanh@fairlite.demon.co.uk>
 
  22  * Thanks to Richard Hirst for making it possible with the MVME additions
 
  26  * 53c710 rev 0 doesn't support add with carry.  Rev 1 and 2 does.  To
 
  27  * overcome this problem you can define FORCE_DSA_ALIGNMENT, which ensures
 
  28  * that the DSA address is always xxxxxx00.  If disconnection is not allowed,
 
  29  * then the script only ever tries to add small (< 256) positive offsets to
 
  30  * DSA, so lack of carry isn't a problem.  FORCE_DSA_ALIGNMENT can, of course,
 
  31  * be defined for all chip revisions at a small cost in memory usage.
 
  34 #define FORCE_DSA_ALIGNMENT
 
  37  * Selection timer does not always work on the 53c710, depending on the
 
  38  * timing at the last disconnect, if this is a problem for you, try
 
  39  * using validids as detailed below.
 
  41  * Options for the NCR7xx driver
 
  43  * noasync:0            -       disables sync and asynchronous negotiation
 
  44  * nosync:0             -       disables synchronous negotiation (does async)
 
  45  * nodisconnect:0       -       disables disconnection
 
  46  * validids:0x??        -       Bitmask field that disallows certain ID's.
 
  47  *                      -       e.g.    0x03    allows ID 0,1
 
  48  *                      -               0x1F    allows ID 0,1,2,3,4
 
  49  * opthi:n              -       replace top word of options with 'n'
 
  50  * optlo:n              -       replace bottom word of options with 'n'
 
  51  *                      -       ALWAYS SPECIFY opthi THEN optlo <<<<<<<<<<
 
  55  * PERM_OPTIONS are driver options which will be enabled for all NCR boards
 
  56  * in the system at driver initialization time.
 
  58  * Don't THINK about touching these in PERM_OPTIONS : 
 
  59  *   OPTION_MEMORY_MAPPED 
 
  60  *      680x0 doesn't have an IO map!
 
  63  *      Test 1 does bus mastering and interrupt tests, which will help weed 
 
  64  *      out brain damaged main boards.
 
  66  * Other PERM_OPTIONS settings are listed below.  Note the actual options
 
  67  * required are set in the relevant file (mvme16x.c, amiga7xx.c, etc):
 
  70  *      Don't negotiate for asynchronous transfers on the first command 
 
  71  *      when OPTION_ALWAYS_SYNCHRONOUS is set.  Useful for dain bramaged
 
  72  *      devices which do something bad rather than sending a MESSAGE 
 
  73  *      REJECT back to us like they should if they can't cope.
 
  76  *      Enable support for synchronous transfers.  Target negotiated 
 
  77  *      synchronous transfers will be responded to.  To initiate 
 
  78  *      a synchronous transfer request,  call 
 
  80  *          request_synchronous (hostno, target) 
 
  84  *   OPTION_ALWAYS_SYNCHRONOUS
 
  85  *      Negotiate for synchronous transfers with every target after
 
  86  *      driver initialization or a SCSI bus reset.  This is a bit dangerous, 
 
  87  *      since there are some dain bramaged SCSI devices which will accept
 
  88  *      SDTR messages but keep talking asynchronously.
 
  91  *      Enable support for disconnect/reconnect.  To change the 
 
  92  *      default setting on a given host adapter, call
 
  94  *          request_disconnect (hostno, allow)
 
  96  *      where allow is non-zero to allow, 0 to disallow.
 
  98  *  If you really want to run 10MHz FAST SCSI-II transfers, you should 
 
  99  *  know that the NCR driver currently ignores parity information.  Most
 
 100  *  systems do 5MHz SCSI fine.  I've seen a lot that have problems faster
 
 101  *  than 8MHz.  To play it safe, we only request 5MHz transfers.
 
 103  *  If you'd rather get 10MHz transfers, edit sdtr_message and change 
 
 104  *  the fourth byte from 50 to 25.
 
 109  *      iX Multiuser Multitasking Magazine
 
 113  * Copyright 1993, 1994, 1995 Drew Eckhardt
 
 114  *      Visionary Computing 
 
 115  *      (Unix and Linux consulting and custom programming)
 
 116  *      drew@PoohSticks.ORG
 
 119  * TolerANT and SCSI SCRIPTS are registered trademarks of NCR Corporation.
 
 121  * For more information, please consult 
 
 128  * PCI-SCSI I/O Processor
 
 132  * PCI-SCSI I/O Processor Design In Guide
 
 134  * For literature on Symbios Logic Inc. formerly NCR, SCSI, 
 
 135  * and Communication products please call (800) 334-5454 or
 
 138  * PCI BIOS Specification Revision
 
 139  * PCI Local Bus Specification
 
 140  * PCI System Design Guide
 
 142  * PCI Special Interest Group
 
 144  * 5200 N.E. Elam Young Parkway
 
 145  * Hillsboro, Oregon 97124-6497
 
 152  * The cumulative latency needed to propagate a read/write request 
 
 153  * through the file system, buffer cache, driver stacks, SCSI host, and 
 
 154  * SCSI device is ultimately the limiting factor in throughput once we 
 
 155  * have a sufficiently fast host adapter.
 
 157  * So, to maximize performance we want to keep the ratio of latency to data 
 
 158  * transfer time to a minimum by
 
 159  * 1.  Minimizing the total number of commands sent (typical command latency
 
 160  *      including drive and bus mastering host overhead is as high as 4.5ms)
 
 161  *      to transfer a given amount of data.  
 
 163  *      This is accomplished by placing no arbitrary limit on the number
 
 164  *      of scatter/gather buffers supported, since we can transfer 1K
 
 165  *      per scatter/gather buffer without Eric's cluster patches, 
 
 168  * 2.  Minimizing the number of fatal interrupts serviced, since
 
 169  *      fatal interrupts halt the SCSI I/O processor.  Basically,
 
 170  *      this means offloading the practical maximum amount of processing 
 
 173  *      On the NCR53c810/820/720,  this is accomplished by using 
 
 174  *              interrupt-on-the-fly signals when commands complete, 
 
 175  *              and only handling fatal errors and SDTR / WDTR  messages 
 
 178  *      On the NCR53c710, interrupts are generated as on the NCR53c8x0,
 
 179  *              only the lack of a interrupt-on-the-fly facility complicates
 
 180  *              things.   Also, SCSI ID registers and commands are 
 
 181  *              bit fielded rather than binary encoded.
 
 183  *      On the NCR53c700 and NCR53c700-66, operations that are done via 
 
 184  *              indirect, table mode on the more advanced chips must be
 
 185  *              replaced by calls through a jump table which 
 
 186  *              acts as a surrogate for the DSA.  Unfortunately, this 
 
 187  *              will mean that we must service an interrupt for each 
 
 188  *              disconnect/reconnect.
 
 190  * 3.  Eliminating latency by pipelining operations at the different levels.
 
 192  *      This driver allows a configurable number of commands to be enqueued
 
 193  *      for each target/lun combination (experimentally, I have discovered
 
 194  *      that two seems to work best) and will ultimately allow for 
 
 195  *      SCSI-II tagged queuing.
 
 199  * This driver is built around a Linux queue of commands waiting to 
 
 200  * be executed, and a shared Linux/NCR array of commands to start.  Commands
 
 201  * are transferred to the array  by the run_process_issue_queue() function 
 
 202  * which is called whenever a command completes.
 
 204  * As commands are completed, the interrupt routine is triggered,
 
 205  * looks for commands in the linked list of completed commands with
 
 206  * valid status, removes these commands from a list of running commands, 
 
 207  * calls the done routine, and flags their target/luns as not busy.
 
 209  * Due to limitations in the intelligence of the NCR chips, certain
 
 210  * concessions are made.  In many cases, it is easier to dynamically 
 
 211  * generate/fix-up code rather than calculate on the NCR at run time.  
 
 212  * So, code is generated or fixed up for
 
 214  * - Handling data transfers, using a variable number of MOVE instructions
 
 215  *      interspersed with CALL MSG_IN, WHEN MSGIN instructions.
 
 217  *      The DATAIN and DATAOUT routines are separate, so that an incorrect
 
 218  *      direction can be trapped, and space isn't wasted. 
 
 220  *      It may turn out that we're better off using some sort 
 
 221  *      of table indirect instruction in a loop with a variable
 
 222  *      sized table on the NCR53c710 and newer chips.
 
 224  * - Checking for reselection (NCR53c710 and better)
 
 226  * - Handling the details of SCSI context switches (NCR53c710 and better),
 
 227  *      such as reprogramming appropriate synchronous parameters, 
 
 228  *      removing the dsa structure from the NCR's queue of outstanding
 
 233 #include <linux/module.h>
 
 235 #include <linux/config.h>
 
 237 #include <linux/types.h>
 
 238 #include <asm/setup.h>
 
 241 #include <asm/system.h>
 
 242 #include <linux/delay.h>
 
 243 #include <linux/signal.h>
 
 244 #include <linux/sched.h>
 
 245 #include <linux/errno.h>
 
 246 #include <linux/string.h>
 
 247 #include <linux/slab.h>
 
 248 #include <linux/vmalloc.h>
 
 249 #include <linux/mm.h>
 
 250 #include <linux/ioport.h>
 
 251 #include <linux/time.h>
 
 252 #include <linux/blkdev.h>
 
 253 #include <linux/spinlock.h>
 
 254 #include <linux/interrupt.h>
 
 255 #include <asm/pgtable.h>
 
 258 #include <asm/amigahw.h>
 
 259 #include <asm/amigaints.h>
 
 266 #ifdef CONFIG_MVME16x
 
 267 #include <asm/mvme16xhw.h>
 
 274 #ifdef CONFIG_BVME6000
 
 275 #include <asm/bvme6000hw.h>
 
 283 #include <scsi/scsi_dbg.h>
 
 284 #include <scsi/scsi_host.h>
 
 286 #include <linux/stat.h>
 
 287 #include <linux/stddef.h>
 
 291  * The following make the definitions in 53c7xx.h (write8, etc) smaller,
 
 292  * we don't have separate i/o space anyway.
 
 308 static int check_address (unsigned long addr, int size);
 
 309 static void dump_events (struct Scsi_Host *host, int count);
 
 310 static Scsi_Cmnd * return_outstanding_commands (struct Scsi_Host *host, 
 
 311     int free, int issue);
 
 312 static void hard_reset (struct Scsi_Host *host);
 
 313 static void ncr_scsi_reset (struct Scsi_Host *host);
 
 314 static void print_lots (struct Scsi_Host *host);
 
 315 static void set_synchronous (struct Scsi_Host *host, int target, int sxfer, 
 
 316     int scntl3, int now_connected);
 
 317 static int datapath_residual (struct Scsi_Host *host);
 
 318 static const char * sbcl_to_phase (int sbcl);
 
 319 static void print_progress (Scsi_Cmnd *cmd);
 
 320 static void print_queues (struct Scsi_Host *host);
 
 321 static void process_issue_queue (unsigned long flags);
 
 322 static int shutdown (struct Scsi_Host *host);
 
 323 static void abnormal_finished (struct NCR53c7x0_cmd *cmd, int result);
 
 324 static int disable (struct Scsi_Host *host);
 
 325 static int NCR53c7xx_run_tests (struct Scsi_Host *host);
 
 326 static irqreturn_t NCR53c7x0_intr(int irq, void *dev_id, struct pt_regs * regs);
 
 327 static void NCR53c7x0_intfly (struct Scsi_Host *host);
 
 328 static int ncr_halt (struct Scsi_Host *host);
 
 329 static void intr_phase_mismatch (struct Scsi_Host *host, struct NCR53c7x0_cmd 
 
 331 static void intr_dma (struct Scsi_Host *host, struct NCR53c7x0_cmd *cmd);
 
 332 static void print_dsa (struct Scsi_Host *host, u32 *dsa,
 
 334 static int print_insn (struct Scsi_Host *host, const u32 *insn,
 
 335     const char *prefix, int kernel);
 
 337 static void NCR53c7xx_dsa_fixup (struct NCR53c7x0_cmd *cmd);
 
 338 static void NCR53c7x0_init_fixup (struct Scsi_Host *host);
 
 339 static int NCR53c7x0_dstat_sir_intr (struct Scsi_Host *host, struct 
 
 341 static void NCR53c7x0_soft_reset (struct Scsi_Host *host);
 
 343 /* Size of event list (per host adapter) */
 
 344 static int track_events = 0;
 
 345 static struct Scsi_Host *first_host = NULL;     /* Head of list of NCR boards */
 
 346 static Scsi_Host_Template *the_template = NULL; 
 
 348 /* NCR53c710 script handling code */
 
 350 #include "53c7xx_d.h"
 
 351 #ifdef A_int_debug_sync
 
 352 #define DEBUG_SYNC_INTR A_int_debug_sync
 
 354 int NCR53c7xx_script_len = sizeof (SCRIPT);
 
 355 int NCR53c7xx_dsa_len = A_dsa_end + Ent_dsa_zero - Ent_dsa_code_template;
 
 356 #ifdef FORCE_DSA_ALIGNMENT
 
 357 int CmdPageStart = (0 - Ent_dsa_zero - sizeof(struct NCR53c7x0_cmd)) & 0xff;
 
 360 static char *setup_strings[] =
 
 361         {"","","","","","","",""};
 
 363 #define MAX_SETUP_STRINGS (sizeof(setup_strings) / sizeof(char *))
 
 364 #define SETUP_BUFFER_SIZE 200
 
 365 static char setup_buffer[SETUP_BUFFER_SIZE];
 
 366 static char setup_used[MAX_SETUP_STRINGS];
 
 368 void ncr53c7xx_setup (char *str, int *ints)
 
 376       strncpy(p1, str, SETUP_BUFFER_SIZE - strlen(setup_buffer));
 
 377    setup_buffer[SETUP_BUFFER_SIZE - 1] = '\0';
 
 380    while (*p1 && (i < MAX_SETUP_STRINGS)) {
 
 381       p2 = strchr(p1, ',');
 
 385             setup_strings[i] = p1;
 
 390          setup_strings[i] = p1;
 
 394    for (i=0; i<MAX_SETUP_STRINGS; i++)
 
 399 /* check_setup_strings() returns index if key found, 0 if not
 
 402 static int check_setup_strings(char *key, int *flags, int *val, char *buf)
 
 407    for  (x=0; x<MAX_SETUP_STRINGS; x++) {
 
 410       if (!strncmp(setup_strings[x], key, strlen(key)))
 
 412       if (!strncmp(setup_strings[x], "next", strlen("next")))
 
 415    if (x == MAX_SETUP_STRINGS)
 
 418    cp = setup_strings[x] + strlen(key);
 
 423    if ((*cp >= '0') && (*cp <= '9')) {
 
 424       *val = simple_strtoul(cp,NULL,0);
 
 433  * - There is some sort of conflict when the PPP driver is compiled with 
 
 434  *      support for 16 channels?
 
 436  * - On systems which predate the 1.3.x initialization order change,
 
 437  *      the NCR driver will cause Cannot get free page messages to appear.  
 
 438  *      These are harmless, but I don't know of an easy way to avoid them.
 
 440  * - With OPTION_DISCONNECT, on two systems under unknown circumstances,
 
 441  *      we get a PHASE MISMATCH with DSA set to zero (suggests that we 
 
 442  *      are occurring somewhere in the reselection code) where 
 
 443  *      DSP=some value DCMD|DBC=same value.  
 
 445  *      Closer inspection suggests that we may be trying to execute
 
 446  *      some portion of the DSA?
 
 447  * scsi0 : handling residual transfer (+ 0 bytes from DMA FIFO)
 
 448  * scsi0 : handling residual transfer (+ 0 bytes from DMA FIFO)
 
 449  * scsi0 : no current command : unexpected phase MSGIN.
 
 450  *         DSP=0x1c46cc, DCMD|DBC=0x1c46ac, DSA=0x0
 
 451  *         DSPS=0x0, TEMP=0x1c3e70, DMODE=0x80
 
 453  * 001c46cc : 0x001c46cc 0x00000000
 
 454  * 001c46d4 : 0x001c5ea0 0x000011f8
 
 456  *      Changed the print code in the phase_mismatch handler so
 
 457  *      that we call print_lots to try to diagnose this.
 
 462  * Possible future direction of architecture for max performance :
 
 464  * We're using a single start array for the NCR chip.  This is 
 
 465  * sub-optimal, because we cannot add a command which would conflict with 
 
 466  * an executing command to this start queue, and therefore must insert the 
 
 467  * next command for a given I/T/L combination after the first has completed;
 
 468  * incurring our interrupt latency between SCSI commands.
 
 470  * To allow further pipelining of the NCR and host CPU operation, we want 
 
 471  * to set things up so that immediately on termination of a command destined 
 
 472  * for a given LUN, we get that LUN busy again.  
 
 474  * To do this, we need to add a 32 bit pointer to which is jumped to 
 
 475  * on completion of a command.  If no new command is available, this 
 
 476  * would point to the usual DSA issue queue select routine.
 
 478  * If one were, it would point to a per-NCR53c7x0_cmd select routine 
 
 479  * which starts execution immediately, inserting the command at the head 
 
 480  * of the start queue if the NCR chip is selected or reselected.
 
 482  * We would change so that we keep a list of outstanding commands 
 
 483  * for each unit, rather than a single running_list.  We'd insert 
 
 484  * a new command into the right running list; if the NCR didn't 
 
 485  * have something running for that yet, we'd put it in the 
 
 486  * start queue as well.  Some magic needs to happen to handle the 
 
 487  * race condition between the first command terminating before the 
 
 488  * new one is written.
 
 490  * Potential for profiling : 
 
 491  * Call do_gettimeofday(struct timeval *tv) to get 800ns resolution.
 
 497  * 1.  To support WIDE transfers, not much needs to happen.  We
 
 498  *      should do CHMOVE instructions instead of MOVEs when
 
 499  *      we have scatter/gather segments of uneven length.  When
 
 500  *      we do this, we need to handle the case where we disconnect
 
 503  * 2.  Currently, when Icky things happen we do a FATAL().  Instead,
 
 504  *     we want to do an integrity check on the parts of the NCR hostdata
 
 505  *     structure which were initialized at boot time; FATAL() if that 
 
 506  *     fails, and otherwise try to recover.  Keep track of how many
 
 507  *     times this has happened within a single SCSI command; if it 
 
 508  *     gets excessive, then FATAL().
 
 510  * 3.  Parity checking is currently disabled, and a few things should 
 
 511  *     happen here now that we support synchronous SCSI transfers :
 
 512  *     1.  On soft-reset, we shoould set the EPC (Enable Parity Checking)
 
 513  *         and AAP (Assert SATN/ on parity error) bits in SCNTL0.
 
 515  *     2.  We should enable the parity interrupt in the SIEN0 register.
 
 517  *     3.  intr_phase_mismatch() needs to believe that message out is 
 
 518  *         always an "acceptable" phase to have a mismatch in.  If 
 
 519  *         the old phase was MSG_IN, we should send a MESSAGE PARITY 
 
 520  *         error.  If the old phase was something else, we should send
 
 521  *         a INITIATOR_DETECTED_ERROR message.  Note that this could
 
 522  *         cause a RESTORE POINTERS message; so we should handle that 
 
 523  *         correctly first.  Instead, we should probably do an 
 
 526  * 4.  MPEE bit of CTEST4 should be set so we get interrupted if 
 
 527  *     we detect an error.
 
 530  * 5.  The initial code has been tested on the NCR53c810.  I don't 
 
 531  *     have access to NCR53c700, 700-66 (Forex boards), NCR53c710
 
 532  *     (NCR Pentium systems), NCR53c720, NCR53c820, or NCR53c825 boards to 
 
 533  *     finish development on those platforms.
 
 535  *     NCR53c820/825/720 - need to add wide transfer support, including WDTR 
 
 536  *              negotiation, programming of wide transfer capabilities
 
 537  *              on reselection and table indirect selection.
 
 539  *     NCR53c710 - need to add fatal interrupt or GEN code for 
 
 540  *              command completion signaling.   Need to modify all 
 
 541  *              SDID, SCID, etc. registers, and table indirect select code 
 
 542  *              since these use bit fielded (ie 1<<target) instead of 
 
 543  *              binary encoded target ids.  Need to accommodate
 
 544  *              different register mappings, probably scan through
 
 545  *              the SCRIPT code and change the non SFBR register operand
 
 546  *              of all MOVE instructions.
 
 548  *              It is rather worse than this actually, the 710 corrupts
 
 549  *              both TEMP and DSA when you do a MOVE MEMORY.  This
 
 550  *              screws you up all over the place.  MOVE MEMORY 4 with a
 
 551  *              destination of DSA seems to work OK, which helps some.
 
 552  *              Richard Hirst  richard@sleepie.demon.co.uk
 
 554  *     NCR53c700/700-66 - need to add code to refix addresses on 
 
 555  *              every nexus change, eliminate all table indirect code,
 
 558  * 6.  The NCR53c7x0 series is very popular on other platforms that 
 
 559  *     could be running Linux - ie, some high performance AMIGA SCSI 
 
 562  *     So, I should include #ifdef'd code so that it is 
 
 563  *     compatible with these systems.
 
 565  *     Specifically, the little Endian assumptions I made in my 
 
 566  *     bit fields need to change, and if the NCR doesn't see memory
 
 567  *     the right way, we need to provide options to reverse words
 
 568  *     when the scripts are relocated.
 
 570  * 7.  Use vremap() to access memory mapped boards.  
 
 574  * Allow for simultaneous existence of multiple SCSI scripts so we 
 
 575  * can have a single driver binary for all of the family.
 
 577  * - one for NCR53c700 and NCR53c700-66 chips   (not yet supported)
 
 578  * - one for rest (only the NCR53c810, 815, 820, and 825 are currently 
 
 581  * So that we only need two SCSI scripts, we need to modify things so
 
 582  * that we fixup register accesses in READ/WRITE instructions, and 
 
 583  * we'll also have to accommodate the bit vs. binary encoding of IDs
 
 584  * with the 7xx chips.
 
 587 #define ROUNDUP(adr,type)       \
 
 588   ((void *) (((long) (adr) + sizeof(type) - 1) & ~(sizeof(type) - 1)))
 
 592  * Function: issue_to_cmd
 
 594  * Purpose: convert jump instruction in issue array to NCR53c7x0_cmd
 
 597  * Inputs; issue - pointer to start of NOP or JUMP instruction
 
 600  * Returns: pointer to command on success; 0 if opcode is NOP.
 
 603 static inline struct NCR53c7x0_cmd *
 
 604 issue_to_cmd (struct Scsi_Host *host, struct NCR53c7x0_hostdata *hostdata,
 
 607     return (issue[0] != hostdata->NOP_insn) ? 
 
 609      * If the IF TRUE bit is set, it's a JUMP instruction.  The
 
 610      * operand is a bus pointer to the dsa_begin routine for this DSA.  The
 
 611      * dsa field of the NCR53c7x0_cmd structure starts with the 
 
 612      * DSA code template.  By converting to a virtual address,
 
 613      * subtracting the code template size, and offset of the 
 
 614      * dsa field, we end up with a pointer to the start of the 
 
 615      * structure (alternatively, we could use the 
 
 616      * dsa_cmnd field, an anachronism from when we weren't
 
 617      * sure what the relationship between the NCR structures
 
 618      * and host structures were going to be.
 
 620         (struct NCR53c7x0_cmd *) ((char *) bus_to_virt (issue[1]) - 
 
 621             (hostdata->E_dsa_code_begin - hostdata->E_dsa_code_template) -
 
 622             offsetof(struct NCR53c7x0_cmd, dsa)) 
 
 623     /* If the IF TRUE bit is not set, it's a NOP */
 
 629  * FIXME: we should junk these, in favor of synchronous_want and 
 
 630  * wide_want in the NCR53c7x0_hostdata structure.
 
 633 /* Template for "preferred" synchronous transfer parameters. */
 
 635 static const unsigned char sdtr_message[] = {
 
 636 #ifdef CONFIG_SCSI_NCR53C7xx_FAST
 
 637     EXTENDED_MESSAGE, 3 /* length */, EXTENDED_SDTR, 25 /* *4ns */, 8 /* off */
 
 639     EXTENDED_MESSAGE, 3 /* length */, EXTENDED_SDTR, 50 /* *4ns */, 8 /* off */ 
 
 643 /* Template to request asynchronous transfers */
 
 645 static const unsigned char async_message[] = {
 
 646     EXTENDED_MESSAGE, 3 /* length */, EXTENDED_SDTR, 0, 0 /* asynchronous */
 
 649 /* Template for "preferred" WIDE transfer parameters */
 
 651 static const unsigned char wdtr_message[] = {
 
 652     EXTENDED_MESSAGE, 2 /* length */, EXTENDED_WDTR, 1 /* 2^1 bytes */
 
 657  * Function : struct Scsi_Host *find_host (int host)
 
 659  * Purpose : KGDB support function which translates a host number 
 
 660  *      to a host structure. 
 
 662  * Inputs : host - number of SCSI host
 
 664  * Returns : NULL on failure, pointer to host structure on success.
 
 667 static struct Scsi_Host *
 
 668 find_host (int host) {
 
 670     for (h = first_host; h && h->host_no != host; h = h->next);
 
 672         printk (KERN_ALERT "scsi%d not found\n", host);
 
 674     } else if (h->hostt != the_template) {
 
 675         printk (KERN_ALERT "scsi%d is not a NCR board\n", host);
 
 683  * Function : request_synchronous (int host, int target)
 
 685  * Purpose : KGDB interface which will allow us to negotiate for 
 
 686  *      synchronous transfers.  This ill be replaced with a more 
 
 687  *      integrated function; perhaps a new entry in the scsi_host 
 
 688  *      structure, accessible via an ioctl() or perhaps /proc/scsi.
 
 690  * Inputs : host - number of SCSI host; target - number of target.
 
 692  * Returns : 0 when negotiation has been setup for next SCSI command,
 
 697 request_synchronous (int host, int target) {
 
 699     struct NCR53c7x0_hostdata *hostdata;
 
 702         printk (KERN_ALERT "target %d is bogus\n", target);
 
 705     if (!(h = find_host (host)))
 
 707     else if (h->this_id == target) {
 
 708         printk (KERN_ALERT "target %d is host ID\n", target);
 
 711     else if (target > h->max_id) {
 
 712         printk (KERN_ALERT "target %d exceeds maximum of %d\n", target,
 
 716     hostdata = (struct NCR53c7x0_hostdata *)h->hostdata[0];
 
 718     local_irq_save(flags);
 
 719     if (hostdata->initiate_sdtr & (1 << target)) {
 
 720         local_irq_restore(flags);
 
 721         printk (KERN_ALERT "target %d already doing SDTR\n", target);
 
 724     hostdata->initiate_sdtr |= (1 << target);
 
 725     local_irq_restore(flags);
 
 731  * Function : request_disconnect (int host, int on_or_off)
 
 733  * Purpose : KGDB support function, tells us to allow or disallow 
 
 736  * Inputs : host - number of SCSI host; on_or_off - non-zero to allow,
 
 739  * Returns : 0 on success, *    -1 on failure.
 
 743 request_disconnect (int host, int on_or_off) {
 
 745     struct NCR53c7x0_hostdata *hostdata;
 
 746     if (!(h = find_host (host)))
 
 748     hostdata = (struct NCR53c7x0_hostdata *) h->hostdata[0];
 
 750         hostdata->options |= OPTION_DISCONNECT;
 
 752         hostdata->options &= ~OPTION_DISCONNECT;
 
 758  * Function : static void NCR53c7x0_driver_init (struct Scsi_Host *host)
 
 760  * Purpose : Initialize internal structures, as required on startup, or 
 
 761  *      after a SCSI bus reset.
 
 763  * Inputs : host - pointer to this host adapter's structure
 
 767 NCR53c7x0_driver_init (struct Scsi_Host *host) {
 
 768     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
 773     for (i = 0; i < 16; ++i) {
 
 774         hostdata->request_sense[i] = 0;
 
 775         for (j = 0; j < 8; ++j) 
 
 776             hostdata->busy[i][j] = 0;
 
 777         set_synchronous (host, i, /* sxfer */ 0, hostdata->saved_scntl3, 0);
 
 779     hostdata->issue_queue = NULL;
 
 780     hostdata->running_list = hostdata->finished_queue = 
 
 781         hostdata->ncrcurrent = NULL;
 
 782     for (i = 0, ncrcurrent = (u32 *) hostdata->schedule; 
 
 783         i < host->can_queue; ++i, ncrcurrent += 2) {
 
 784         ncrcurrent[0] = hostdata->NOP_insn;
 
 785         ncrcurrent[1] = 0xdeadbeef;
 
 787     ncrcurrent[0] = ((DCMD_TYPE_TCI|DCMD_TCI_OP_JUMP) << 24) | DBC_TCI_TRUE;
 
 788     ncrcurrent[1] = (u32) virt_to_bus (hostdata->script) +
 
 789         hostdata->E_wait_reselect;
 
 790     hostdata->reconnect_dsa_head = 0;
 
 791     hostdata->addr_reconnect_dsa_head = (u32) 
 
 792         virt_to_bus((void *) &(hostdata->reconnect_dsa_head));
 
 793     hostdata->expecting_iid = 0;
 
 794     hostdata->expecting_sto = 0;
 
 795     if (hostdata->options & OPTION_ALWAYS_SYNCHRONOUS) 
 
 796         hostdata->initiate_sdtr = 0xffff; 
 
 798         hostdata->initiate_sdtr = 0;
 
 799     hostdata->talked_to = 0;
 
 804  * Function : static int clock_to_ccf_710 (int clock)
 
 806  * Purpose :  Return the clock conversion factor for a given SCSI clock.
 
 808  * Inputs : clock - SCSI clock expressed in Hz.
 
 810  * Returns : ccf on success, -1 on failure.
 
 814 clock_to_ccf_710 (int clock) {
 
 815     if (clock <= 16666666)
 
 817     if (clock <= 25000000)
 
 818         return 2;       /* Divide by 1.0 */
 
 819     else if (clock <= 37500000)
 
 820         return 1;       /* Divide by 1.5 */
 
 821     else if (clock <= 50000000)
 
 822         return 0;       /* Divide by 2.0 */
 
 823     else if (clock <= 66000000)
 
 824         return 3;       /* Divide by 3.0 */
 
 830  * Function : static int NCR53c7x0_init (struct Scsi_Host *host)
 
 832  * Purpose :  initialize the internal structures for a given SCSI host
 
 834  * Inputs : host - pointer to this host adapter's structure
 
 836  * Preconditions : when this function is called, the chip_type 
 
 837  *      field of the hostdata structure MUST have been set.
 
 839  * Returns : 0 on success, -1 on failure.
 
 843 NCR53c7x0_init (struct Scsi_Host *host) {
 
 844     NCR53c7x0_local_declare();
 
 846     unsigned char revision;
 
 847     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
 850      * There are some things which we need to know about in order to provide
 
 851      * a semblance of support.  Print 'em if they aren't what we expect, 
 
 852      * otherwise don't add to the noise.
 
 854      * -1 means we don't know what to expect.
 
 858     int expected_id = -1;
 
 859     int expected_clock = -1;
 
 860     int uninitialized = 0;
 
 862     int expected_mapping = OPTION_MEMORY_MAPPED;
 
 864     int expected_mapping = OPTION_IO_MAPPED;
 
 867         hostdata->valid_ids[i] = 1;     /* Default all ID's to scan */
 
 869     /* Parse commandline flags */
 
 870     if (check_setup_strings("noasync",&flags,&val,buf))
 
 872         hostdata->options |= OPTION_NO_ASYNC;
 
 873         hostdata->options &= ~(OPTION_SYNCHRONOUS | OPTION_ALWAYS_SYNCHRONOUS);
 
 876     if (check_setup_strings("nosync",&flags,&val,buf))
 
 878         hostdata->options &= ~(OPTION_SYNCHRONOUS | OPTION_ALWAYS_SYNCHRONOUS);
 
 881     if (check_setup_strings("nodisconnect",&flags,&val,buf))
 
 882         hostdata->options &= ~OPTION_DISCONNECT;
 
 884     if (check_setup_strings("validids",&flags,&val,buf))
 
 887                 hostdata->valid_ids[i] = val & (1<<i);
 
 890     if  ((i = check_setup_strings("next",&flags,&val,buf)))
 
 896     if (check_setup_strings("opthi",&flags,&val,buf))
 
 897         hostdata->options = (long long)val << 32;
 
 898     if (check_setup_strings("optlo",&flags,&val,buf))
 
 899         hostdata->options |= val;
 
 901     NCR53c7x0_local_setup(host);
 
 902     switch (hostdata->chip) {
 
 905         hostdata->dstat_sir_intr = NCR53c7x0_dstat_sir_intr;
 
 906         hostdata->init_save_regs = NULL;
 
 907         hostdata->dsa_fixup = NCR53c7xx_dsa_fixup;
 
 908         hostdata->init_fixup = NCR53c7x0_init_fixup;
 
 909         hostdata->soft_reset = NCR53c7x0_soft_reset;
 
 910         hostdata->run_tests = NCR53c7xx_run_tests;
 
 911         expected_clock = hostdata->scsi_clock;
 
 915         printk ("scsi%d : chip type of %d is not supported yet, detaching.\n",
 
 916             host->host_no, hostdata->chip);
 
 917         scsi_unregister (host);
 
 921     /* Assign constants accessed by NCR */
 
 922     hostdata->NCR53c7xx_zero = 0;                       
 
 923     hostdata->NCR53c7xx_msg_reject = MESSAGE_REJECT;
 
 924     hostdata->NCR53c7xx_msg_abort = ABORT;
 
 925     hostdata->NCR53c7xx_msg_nop = NOP;
 
 926     hostdata->NOP_insn = (DCMD_TYPE_TCI|DCMD_TCI_OP_JUMP) << 24;
 
 927     if (expected_mapping == -1 || 
 
 928         (hostdata->options & (OPTION_MEMORY_MAPPED)) != 
 
 929         (expected_mapping & OPTION_MEMORY_MAPPED))
 
 930         printk ("scsi%d : using %s mapped access\n", host->host_no, 
 
 931             (hostdata->options & OPTION_MEMORY_MAPPED) ? "memory" : 
 
 934     hostdata->dmode = (hostdata->chip == 700 || hostdata->chip == 70066) ? 
 
 935         DMODE_REG_00 : DMODE_REG_10;
 
 936     hostdata->istat = ((hostdata->chip / 100) == 8) ? 
 
 937         ISTAT_REG_800 : ISTAT_REG_700;
 
 939 /* We have to assume that this may be the first access to the chip, so
 
 940  * we must set EA in DCNTL. */
 
 942     NCR53c7x0_write8 (DCNTL_REG, DCNTL_10_EA|DCNTL_10_COM);
 
 945 /* Only the ISTAT register is readable when the NCR is running, so make 
 
 950  * XXX - the NCR53c700 uses bitfielded registers for SCID, SDID, etc,
 
 951  *      as does the 710 with one bit per SCSI ID.  Conversely, the NCR
 
 952  *      uses a normal, 3 bit binary representation of these values.
 
 954  * Get the rest of the NCR documentation, and FIND OUT where the change
 
 959         /* May not be able to do this - chip my not have been set up yet */
 
 960         tmp = hostdata->this_id_mask = NCR53c7x0_read8(SCID_REG);
 
 961         for (host->this_id = 0; tmp != 1; tmp >>=1, ++host->this_id);
 
 967  * Note : we should never encounter a board setup for ID0.  So,
 
 968  *      if we see ID0, assume that it was uninitialized and set it
 
 969  *      to the industry standard 7.
 
 971     if (!host->this_id) {
 
 972         printk("scsi%d : initiator ID was %d, changing to 7\n",
 
 973             host->host_no, host->this_id);
 
 975         hostdata->this_id_mask = 1 << 7;
 
 979     if (expected_id == -1 || host->this_id != expected_id)
 
 980         printk("scsi%d : using initiator ID %d\n", host->host_no,
 
 984      * Save important registers to allow a soft reset.
 
 988      * CTEST7 controls cache snooping, burst mode, and support for 
 
 989      * external differential drivers.  This isn't currently used - the
 
 990      * default value may not be optimal anyway.
 
 991      * Even worse, it may never have been set up since reset.
 
 993     hostdata->saved_ctest7 = NCR53c7x0_read8(CTEST7_REG) & CTEST7_SAVE;
 
 994     revision = (NCR53c7x0_read8(CTEST8_REG) & 0xF0) >> 4;
 
 996         case 1: revision = 0;    break;
 
 997         case 2: revision = 1;    break;
 
 998         case 4: revision = 2;    break;
 
 999         case 8: revision = 3;    break;
 
1000         default: revision = 255; break;
 
1002     printk("scsi%d: Revision 0x%x\n",host->host_no,revision);
 
1004     if ((revision == 0 || revision == 255) && (hostdata->options & (OPTION_SYNCHRONOUS|OPTION_DISCONNECT|OPTION_ALWAYS_SYNCHRONOUS)))
 
1006         printk ("scsi%d: Disabling sync working and disconnect/reselect\n",
 
1008         hostdata->options &= ~(OPTION_SYNCHRONOUS|OPTION_DISCONNECT|OPTION_ALWAYS_SYNCHRONOUS);
 
1012      * On NCR53c700 series chips, DCNTL controls the SCSI clock divisor,
 
1013      * on 800 series chips, it allows for a totem-pole IRQ driver.
 
1014      * NOTE saved_dcntl currently overwritten in init function.
 
1015      * The value read here may be garbage anyway, MVME16x board at least
 
1016      * does not initialise chip if kernel arrived via tftp.
 
1019     hostdata->saved_dcntl = NCR53c7x0_read8(DCNTL_REG);
 
1022      * DMODE controls DMA burst length, and on 700 series chips,
 
1023      * 286 mode and bus width  
 
1024      * NOTE:  On MVME16x, chip may have been reset, so this could be a
 
1025      * power-on/reset default value.
 
1027     hostdata->saved_dmode = NCR53c7x0_read8(hostdata->dmode);
 
1030      * Now that burst length and enabled/disabled status is known, 
 
1031      * clue the user in on it.  
 
1034     ccf = clock_to_ccf_710 (expected_clock);
 
1036     for (i = 0; i < 16; ++i) 
 
1037         hostdata->cmd_allocated[i] = 0;
 
1039     if (hostdata->init_save_regs)
 
1040         hostdata->init_save_regs (host);
 
1041     if (hostdata->init_fixup)
 
1042         hostdata->init_fixup (host);
 
1044     if (!the_template) {
 
1045         the_template = host->hostt;
 
1050      * Linux SCSI drivers have always been plagued with initialization 
 
1051      * problems - some didn't work with the BIOS disabled since they expected
 
1052      * initialization from it, some didn't work when the networking code
 
1053      * was enabled and registers got scrambled, etc.
 
1055      * To avoid problems like this, in the future, we will do a soft 
 
1056      * reset on the SCSI chip, taking it back to a sane state.
 
1059     hostdata->soft_reset (host);
 
1062     hostdata->debug_count_limit = -1;
 
1064     hostdata->debug_count_limit = 1;
 
1066     hostdata->intrs = -1;
 
1067     hostdata->resets = -1;
 
1068     memcpy ((void *) hostdata->synchronous_want, (void *) sdtr_message, 
 
1069         sizeof (hostdata->synchronous_want));
 
1071     NCR53c7x0_driver_init (host);
 
1073     if (request_irq(host->irq, NCR53c7x0_intr, SA_SHIRQ, "53c7xx", host))
 
1075         printk("scsi%d : IRQ%d not free, detaching\n",
 
1076                 host->host_no, host->irq);
 
1077         goto err_unregister;
 
1080     if ((hostdata->run_tests && hostdata->run_tests(host) == -1) ||
 
1081         (hostdata->options & OPTION_DEBUG_TESTS_ONLY)) {
 
1082         /* XXX Should disable interrupts, etc. here */
 
1085         if (host->io_port)  {
 
1086             host->n_io_port = 128;
 
1087             if (!request_region (host->io_port, host->n_io_port, "ncr53c7xx"))
 
1092     if (NCR53c7x0_read8 (SBCL_REG) & SBCL_BSY) {
 
1093         printk ("scsi%d : bus wedge, doing SCSI reset\n", host->host_no);
 
1099     free_irq(host->irq,  NCR53c7x0_intr);
 
1101     scsi_unregister(host);
 
1106  * Function : int ncr53c7xx_init(Scsi_Host_Template *tpnt, int board, int chip,
 
1107  *      unsigned long base, int io_port, int irq, int dma, long long options,
 
1110  * Purpose : initializes a NCR53c7,8x0 based on base addresses,
 
1111  *      IRQ, and DMA channel.   
 
1113  * Inputs : tpnt - Template for this SCSI adapter, board - board level
 
1114  *      product, chip - 710
 
1116  * Returns : 0 on success, -1 on failure.
 
1121 ncr53c7xx_init (Scsi_Host_Template *tpnt, int board, int chip,
 
1122     unsigned long base, int io_port, int irq, int dma, 
 
1123     long long options, int clock)
 
1125     struct Scsi_Host *instance;
 
1126     struct NCR53c7x0_hostdata *hostdata;
 
1128     int script_len = 0, dsa_len = 0, size = 0, max_cmd_size = 0,
 
1129         schedule_size = 0, ok = 0;
 
1136         schedule_size = (tpnt->can_queue + 1) * 8 /* JUMP instruction size */;
 
1137         script_len = NCR53c7xx_script_len;
 
1138         dsa_len = NCR53c7xx_dsa_len;
 
1139         options |= OPTION_INTFLY;
 
1140         sprintf (chip_str, "NCR53c%d", chip);
 
1143         printk("scsi-ncr53c7xx : unsupported SCSI chip %d\n", chip);
 
1147     printk("scsi-ncr53c7xx : %s at memory 0x%lx, io 0x%x, irq %d",
 
1148         chip_str, base, io_port, irq);
 
1149     if (dma == DMA_NONE)
 
1152         printk(", dma %d\n", dma);
 
1154     if (options & OPTION_DEBUG_PROBE_ONLY) {
 
1155         printk ("scsi-ncr53c7xx : probe only enabled, aborting initialization\n");
 
1159     max_cmd_size = sizeof(struct NCR53c7x0_cmd) + dsa_len +
 
1160         /* Size of dynamic part of command structure : */
 
1161         2 * /* Worst case : we don't know if we need DATA IN or DATA out */
 
1162                 ( 2 * /* Current instructions per scatter/gather segment */ 
 
1163                   tpnt->sg_tablesize + 
 
1164                   3 /* Current startup / termination required per phase */
 
1166         8 /* Each instruction is eight bytes */;
 
1168     /* Allocate fixed part of hostdata, dynamic part to hold appropriate
 
1169        SCSI SCRIPT(tm) plus a single, maximum-sized NCR53c7x0_cmd structure.
 
1171        We need a NCR53c7x0_cmd structure for scan_scsis() when we are 
 
1172        not loaded as a module, and when we're loaded as a module, we 
 
1173        can't use a non-dynamically allocated structure because modules
 
1174        are vmalloc()'d, which can allow structures to cross page 
 
1175        boundaries and breaks our physical/virtual address assumptions
 
1178        So, we stick it past the end of our hostdata structure.
 
1181          Regardless of how many simultaneous SCSI commands we allow,
 
1182          the probe code only executes a _single_ instruction at a time,
 
1183          so we only need one here, and don't need to allocate NCR53c7x0_cmd
 
1184          structures for each target until we are no longer in scan_scsis
 
1185          and kmalloc() has become functional (memory_init() happens 
 
1186          after all device driver initialization).
 
1189     size = sizeof(struct NCR53c7x0_hostdata) + script_len + 
 
1190     /* Note that alignment will be guaranteed, since we put the command
 
1191        allocated at probe time after the fixed-up SCSI script, which 
 
1192        consists of 32 bit words, aligned on a 32 bit boundary.  But
 
1193        on a 64bit machine we need 8 byte alignment for hostdata->free, so
 
1194        we add in another 4 bytes to take care of potential misalignment
 
1196         (sizeof(void *) - sizeof(u32)) + max_cmd_size + schedule_size;
 
1198     page = __get_free_pages(GFP_ATOMIC,1);
 
1201         printk(KERN_ERR "53c7xx: out of memory.\n");
 
1204 #ifdef FORCE_DSA_ALIGNMENT
 
1206      * 53c710 rev.0 doesn't have an add-with-carry instruction.
 
1207      * Ensure we allocate enough memory to force DSA alignment.
 
1211     /* Size should be < 8K, so we can fit it in two pages. */
 
1213       printk(KERN_ERR "53c7xx: hostdata > 8K\n");
 
1217     instance = scsi_register (tpnt, 4);
 
1223     instance->hostdata[0] = page;
 
1224     memset((void *)instance->hostdata[0], 0, 8192);
 
1225     cache_push(virt_to_phys((void *)(instance->hostdata[0])), 8192);
 
1226     cache_clear(virt_to_phys((void *)(instance->hostdata[0])), 8192);
 
1227     kernel_set_cachemode((void *)instance->hostdata[0], 8192, IOMAP_NOCACHE_SER);
 
1229     /* FIXME : if we ever support an ISA NCR53c7xx based board, we
 
1230        need to check if the chip is running in a 16 bit mode, and if so 
 
1231        unregister it if it is past the 16M (0x1000000) mark */
 
1233     hostdata = (struct NCR53c7x0_hostdata *)instance->hostdata[0];
 
1234     hostdata->size = size;
 
1235     hostdata->script_count = script_len / sizeof(u32);
 
1236     hostdata->board = board;
 
1237     hostdata->chip = chip;
 
1240      * Being memory mapped is more desirable, since 
 
1242      * - Memory accesses may be faster.
 
1244      * - The destination and source address spaces are the same for 
 
1245      *   all instructions, meaning we don't have to twiddle dmode or 
 
1246      *   any other registers.
 
1248      * So, we try for memory mapped, and if we don't get it,
 
1249      * we go for port mapped, and that failing we tell the user
 
1254         instance->base = base;
 
1255         /* Check for forced I/O mapping */
 
1256         if (!(options & OPTION_IO_MAPPED)) {
 
1257             options |= OPTION_MEMORY_MAPPED;
 
1261         options &= ~OPTION_MEMORY_MAPPED;
 
1265         instance->io_port = io_port;
 
1266         options |= OPTION_IO_MAPPED;
 
1269         options &= ~OPTION_IO_MAPPED;
 
1273         printk ("scsi%d : not initializing, no I/O or memory mapping known \n",
 
1275         scsi_unregister (instance);
 
1278     instance->irq = irq;
 
1279     instance->dma_channel = dma;
 
1281     hostdata->options = options;
 
1282     hostdata->dsa_len = dsa_len;
 
1283     hostdata->max_cmd_size = max_cmd_size;
 
1284     hostdata->num_cmds = 1;
 
1285     hostdata->scsi_clock = clock;
 
1286     /* Initialize single command */
 
1287     tmp = (hostdata->script + hostdata->script_count);
 
1288 #ifdef FORCE_DSA_ALIGNMENT
 
1290         void *t = ROUNDUP(tmp, void *);
 
1291         if (((u32)t & 0xff) > CmdPageStart)
 
1292             t = (void *)((u32)t + 255);
 
1293         t = (void *)(((u32)t & ~0xff) + CmdPageStart);
 
1296         printk ("scsi: Registered size increased by 256 to %d\n", size);
 
1297         printk ("scsi: CmdPageStart = 0x%02x\n", CmdPageStart);
 
1298         printk ("scsi: tmp = 0x%08x, hostdata->free set to 0x%08x\n",
 
1303     hostdata->free = ROUNDUP(tmp, void *);
 
1305     hostdata->free->real = tmp;
 
1306     hostdata->free->size = max_cmd_size;
 
1307     hostdata->free->free = NULL;
 
1308     hostdata->free->next = NULL;
 
1309     hostdata->extra_allocate = 0;
 
1311     /* Allocate command start code space */
 
1312     hostdata->schedule = (chip == 700 || chip == 70066) ?
 
1313         NULL : (u32 *) ((char *)hostdata->free + max_cmd_size);
 
1316  * For diagnostic purposes, we don't really care how fast things blaze.
 
1317  * For profiling, we want to access the 800ns resolution system clock,
 
1318  * using a 'C' call on the host processor.
 
1320  * Therefore, there's no need for the NCR chip to directly manipulate
 
1321  * this data, and we should put it wherever is most convenient for 
 
1325         hostdata->events = (struct NCR53c7x0_event *) (track_events ? 
 
1326             vmalloc (sizeof (struct NCR53c7x0_event) * track_events) : NULL);
 
1328         hostdata->events = NULL;
 
1330     if (hostdata->events) {
 
1331         memset ((void *) hostdata->events, 0, sizeof(struct NCR53c7x0_event) *
 
1333         hostdata->event_size = track_events;
 
1334         hostdata->event_index = 0;
 
1336         hostdata->event_size = 0;
 
1338     return NCR53c7x0_init(instance);
 
1343  * Function : static void NCR53c7x0_init_fixup (struct Scsi_Host *host)
 
1345  * Purpose :  copy and fixup the SCSI SCRIPTS(tm) code for this device.
 
1347  * Inputs : host - pointer to this host adapter's structure
 
1352 NCR53c7x0_init_fixup (struct Scsi_Host *host) {
 
1353     NCR53c7x0_local_declare();
 
1354     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
1357     int i, ncr_to_memory, memory_to_ncr;
 
1359     NCR53c7x0_local_setup(host);
 
1362     /* XXX - NOTE : this code MUST be made endian aware */
 
1363     /*  Copy code into buffer that was allocated at detection time.  */
 
1364     memcpy ((void *) hostdata->script, (void *) SCRIPT, 
 
1367     for (i = 0; i < PATCHES; ++i) 
 
1368         hostdata->script[LABELPATCHES[i]] += 
 
1369             virt_to_bus(hostdata->script);
 
1370     /* Fixup addresses of constants that used to be EXTERNAL */
 
1372     patch_abs_32 (hostdata->script, 0, NCR53c7xx_msg_abort, 
 
1373         virt_to_bus(&(hostdata->NCR53c7xx_msg_abort)));
 
1374     patch_abs_32 (hostdata->script, 0, NCR53c7xx_msg_reject, 
 
1375         virt_to_bus(&(hostdata->NCR53c7xx_msg_reject)));
 
1376     patch_abs_32 (hostdata->script, 0, NCR53c7xx_zero, 
 
1377         virt_to_bus(&(hostdata->NCR53c7xx_zero)));
 
1378     patch_abs_32 (hostdata->script, 0, NCR53c7xx_sink, 
 
1379         virt_to_bus(&(hostdata->NCR53c7xx_sink)));
 
1380     patch_abs_32 (hostdata->script, 0, NOP_insn,
 
1381         virt_to_bus(&(hostdata->NOP_insn)));
 
1382     patch_abs_32 (hostdata->script, 0, schedule,
 
1383         virt_to_bus((void *) hostdata->schedule));
 
1385     /* Fixup references to external variables: */
 
1386     for (i = 0; i < EXTERNAL_PATCHES_LEN; ++i)
 
1387        hostdata->script[EXTERNAL_PATCHES[i].offset] +=
 
1388          virt_to_bus(EXTERNAL_PATCHES[i].address);
 
1391      * Fixup absolutes set at boot-time.
 
1393      * All non-code absolute variables suffixed with "dsa_" and "int_"
 
1394      * are constants, and need no fixup provided the assembler has done 
 
1395      * it for us (I don't know what the "real" NCR assembler does in 
 
1396      * this case, my assembler does the right magic).
 
1399     patch_abs_rwri_data (hostdata->script, 0, dsa_save_data_pointer, 
 
1400         Ent_dsa_code_save_data_pointer - Ent_dsa_zero);
 
1401     patch_abs_rwri_data (hostdata->script, 0, dsa_restore_pointers,
 
1402         Ent_dsa_code_restore_pointers - Ent_dsa_zero);
 
1403     patch_abs_rwri_data (hostdata->script, 0, dsa_check_reselect,
 
1404         Ent_dsa_code_check_reselect - Ent_dsa_zero);
 
1407      * Just for the hell of it, preserve the settings of 
 
1408      * Burst Length and Enable Read Line bits from the DMODE 
 
1409      * register.  Make sure SCRIPTS start automagically.
 
1412 #if defined(CONFIG_MVME16x) || defined(CONFIG_BVME6000)
 
1413     /* We know better what we want than 16xBug does! */
 
1414     tmp = DMODE_10_BL_8 | DMODE_10_FC2;
 
1416     tmp = NCR53c7x0_read8(DMODE_REG_10);
 
1417     tmp &= (DMODE_BL_MASK | DMODE_10_FC2 | DMODE_10_FC1 | DMODE_710_PD |
 
1421     if (!(hostdata->options & OPTION_MEMORY_MAPPED)) {
 
1422         base = (u32) host->io_port;
 
1423         memory_to_ncr = tmp|DMODE_800_DIOM;
 
1424         ncr_to_memory = tmp|DMODE_800_SIOM;
 
1426         base = virt_to_bus((void *)host->base);
 
1427         memory_to_ncr = ncr_to_memory = tmp;
 
1430     /* SCRATCHB_REG_10 == SCRATCHA_REG_800, as it happens */
 
1431     patch_abs_32 (hostdata->script, 0, addr_scratch, base + SCRATCHA_REG_800);
 
1432     patch_abs_32 (hostdata->script, 0, addr_temp, base + TEMP_REG);
 
1433     patch_abs_32 (hostdata->script, 0, addr_dsa, base + DSA_REG);
 
1436      * I needed some variables in the script to be accessible to 
 
1437      * both the NCR chip and the host processor. For these variables,
 
1438      * I made the arbitrary decision to store them directly in the 
 
1439      * hostdata structure rather than in the RELATIVE area of the 
 
1444     patch_abs_rwri_data (hostdata->script, 0, dmode_memory_to_memory, tmp);
 
1445     patch_abs_rwri_data (hostdata->script, 0, dmode_memory_to_ncr, memory_to_ncr);
 
1446     patch_abs_rwri_data (hostdata->script, 0, dmode_ncr_to_memory, ncr_to_memory);
 
1448     patch_abs_32 (hostdata->script, 0, msg_buf, 
 
1449         virt_to_bus((void *)&(hostdata->msg_buf)));
 
1450     patch_abs_32 (hostdata->script, 0, reconnect_dsa_head, 
 
1451         virt_to_bus((void *)&(hostdata->reconnect_dsa_head)));
 
1452     patch_abs_32 (hostdata->script, 0, addr_reconnect_dsa_head, 
 
1453         virt_to_bus((void *)&(hostdata->addr_reconnect_dsa_head)));
 
1454     patch_abs_32 (hostdata->script, 0, reselected_identify, 
 
1455         virt_to_bus((void *)&(hostdata->reselected_identify)));
 
1456 /* reselected_tag is currently unused */
 
1458     patch_abs_32 (hostdata->script, 0, reselected_tag, 
 
1459         virt_to_bus((void *)&(hostdata->reselected_tag)));
 
1462     patch_abs_32 (hostdata->script, 0, test_dest, 
 
1463         virt_to_bus((void*)&hostdata->test_dest));
 
1464     patch_abs_32 (hostdata->script, 0, test_src, 
 
1465         virt_to_bus(&hostdata->test_source));
 
1466     patch_abs_32 (hostdata->script, 0, saved_dsa,
 
1467         virt_to_bus((void *)&hostdata->saved2_dsa));
 
1468     patch_abs_32 (hostdata->script, 0, emulfly,
 
1469         virt_to_bus((void *)&hostdata->emulated_intfly));
 
1471     patch_abs_rwri_data (hostdata->script, 0, dsa_check_reselect, 
 
1472         (unsigned char)(Ent_dsa_code_check_reselect - Ent_dsa_zero));
 
1474 /* These are for event logging; the ncr_event enum contains the 
 
1475    actual interrupt numbers. */
 
1476 #ifdef A_int_EVENT_SELECT
 
1477    patch_abs_32 (hostdata->script, 0, int_EVENT_SELECT, (u32) EVENT_SELECT);
 
1479 #ifdef A_int_EVENT_DISCONNECT
 
1480    patch_abs_32 (hostdata->script, 0, int_EVENT_DISCONNECT, (u32) EVENT_DISCONNECT);
 
1482 #ifdef A_int_EVENT_RESELECT
 
1483    patch_abs_32 (hostdata->script, 0, int_EVENT_RESELECT, (u32) EVENT_RESELECT);
 
1485 #ifdef A_int_EVENT_COMPLETE
 
1486    patch_abs_32 (hostdata->script, 0, int_EVENT_COMPLETE, (u32) EVENT_COMPLETE);
 
1488 #ifdef A_int_EVENT_IDLE
 
1489    patch_abs_32 (hostdata->script, 0, int_EVENT_IDLE, (u32) EVENT_IDLE);
 
1491 #ifdef A_int_EVENT_SELECT_FAILED
 
1492    patch_abs_32 (hostdata->script, 0, int_EVENT_SELECT_FAILED, 
 
1493         (u32) EVENT_SELECT_FAILED);
 
1495 #ifdef A_int_EVENT_BEFORE_SELECT
 
1496    patch_abs_32 (hostdata->script, 0, int_EVENT_BEFORE_SELECT,
 
1497         (u32) EVENT_BEFORE_SELECT);
 
1499 #ifdef A_int_EVENT_RESELECT_FAILED
 
1500    patch_abs_32 (hostdata->script, 0, int_EVENT_RESELECT_FAILED, 
 
1501         (u32) EVENT_RESELECT_FAILED);
 
1505      * Make sure the NCR and Linux code agree on the location of 
 
1509     hostdata->E_accept_message = Ent_accept_message;
 
1510     hostdata->E_command_complete = Ent_command_complete;                
 
1511     hostdata->E_cmdout_cmdout = Ent_cmdout_cmdout;
 
1512     hostdata->E_data_transfer = Ent_data_transfer;
 
1513     hostdata->E_debug_break = Ent_debug_break;  
 
1514     hostdata->E_dsa_code_template = Ent_dsa_code_template;
 
1515     hostdata->E_dsa_code_template_end = Ent_dsa_code_template_end;
 
1516     hostdata->E_end_data_transfer = Ent_end_data_transfer;
 
1517     hostdata->E_initiator_abort = Ent_initiator_abort;
 
1518     hostdata->E_msg_in = Ent_msg_in;
 
1519     hostdata->E_other_transfer = Ent_other_transfer;
 
1520     hostdata->E_other_in = Ent_other_in;
 
1521     hostdata->E_other_out = Ent_other_out;
 
1522     hostdata->E_reject_message = Ent_reject_message;
 
1523     hostdata->E_respond_message = Ent_respond_message;
 
1524     hostdata->E_select = Ent_select;
 
1525     hostdata->E_select_msgout = Ent_select_msgout;
 
1526     hostdata->E_target_abort = Ent_target_abort;
 
1528     hostdata->E_test_0 = Ent_test_0;
 
1530     hostdata->E_test_1 = Ent_test_1;
 
1531     hostdata->E_test_2 = Ent_test_2;
 
1533     hostdata->E_test_3 = Ent_test_3;
 
1535     hostdata->E_wait_reselect = Ent_wait_reselect;
 
1536     hostdata->E_dsa_code_begin = Ent_dsa_code_begin;
 
1538     hostdata->dsa_cmdout = A_dsa_cmdout;
 
1539     hostdata->dsa_cmnd = A_dsa_cmnd;
 
1540     hostdata->dsa_datain = A_dsa_datain;
 
1541     hostdata->dsa_dataout = A_dsa_dataout;
 
1542     hostdata->dsa_end = A_dsa_end;                      
 
1543     hostdata->dsa_msgin = A_dsa_msgin;
 
1544     hostdata->dsa_msgout = A_dsa_msgout;
 
1545     hostdata->dsa_msgout_other = A_dsa_msgout_other;
 
1546     hostdata->dsa_next = A_dsa_next;
 
1547     hostdata->dsa_select = A_dsa_select;
 
1548     hostdata->dsa_start = Ent_dsa_code_template - Ent_dsa_zero;
 
1549     hostdata->dsa_status = A_dsa_status;
 
1550     hostdata->dsa_jump_dest = Ent_dsa_code_fix_jump - Ent_dsa_zero + 
 
1551         8 /* destination operand */;
 
1554     if (A_dsa_fields_start != Ent_dsa_code_template_end - 
 
1556         printk("scsi%d : NCR dsa_fields start is %d not %d\n",
 
1557             host->host_no, A_dsa_fields_start, Ent_dsa_code_template_end - 
 
1560     printk("scsi%d : NCR code relocated to 0x%lx (virt 0x%p)\n", host->host_no,
 
1561         virt_to_bus(hostdata->script), hostdata->script);
 
1565  * Function : static int NCR53c7xx_run_tests (struct Scsi_Host *host)
 
1567  * Purpose : run various verification tests on the NCR chip, 
 
1568  *      including interrupt generation, and proper bus mastering
 
1571  * Inputs : host - a properly initialized Scsi_Host structure
 
1573  * Preconditions : the NCR chip must be in a halted state.
 
1575  * Returns : 0 if all tests were successful, -1 on error.
 
1580 NCR53c7xx_run_tests (struct Scsi_Host *host) {
 
1581     NCR53c7x0_local_declare();
 
1582     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
1584     unsigned long timeout;
 
1587     unsigned long flags;
 
1588     NCR53c7x0_local_setup(host);
 
1590     /* The NCR chip _must_ be idle to run the test scripts */
 
1592     local_irq_save(flags);
 
1593     if (!hostdata->idle) {
 
1594         printk ("scsi%d : chip not idle, aborting tests\n", host->host_no);
 
1595         local_irq_restore(flags);
 
1600      * Check for functional interrupts, this could work as an
 
1601      * autoprobe routine.
 
1604     if ((hostdata->options & OPTION_DEBUG_TEST1) && 
 
1605             hostdata->state != STATE_DISABLED) {
 
1607         hostdata->test_running = 1;
 
1608         hostdata->test_completed = -1;
 
1609         hostdata->test_dest = 0;
 
1610         hostdata->test_source = 0xdeadbeef;
 
1611         start = virt_to_bus (hostdata->script) + hostdata->E_test_1;
 
1612         hostdata->state = STATE_RUNNING;
 
1613         printk ("scsi%d : test 1", host->host_no);
 
1614         NCR53c7x0_write32 (DSP_REG, start);
 
1615         if (hostdata->options & OPTION_DEBUG_TRACE)
 
1616             NCR53c7x0_write8 (DCNTL_REG, hostdata->saved_dcntl | DCNTL_SSM |
 
1618         printk (" started\n");
 
1619         local_irq_restore(flags);
 
1622          * This is currently a .5 second timeout, since (in theory) no slow 
 
1623          * board will take that long.  In practice, we've seen one 
 
1624          * pentium which occassionally fails with this, but works with 
 
1628         timeout = jiffies + 5 * HZ / 10;
 
1629         while ((hostdata->test_completed == -1) && time_before(jiffies, timeout))
 
1633         if (hostdata->test_completed == -1)
 
1634             printk ("scsi%d : driver test 1 timed out%s\n",host->host_no ,
 
1635                 (hostdata->test_dest == 0xdeadbeef) ? 
 
1636                     " due to lost interrupt.\n"
 
1637                     "         Please verify that the correct IRQ is being used for your board,\n"
 
1639         else if (hostdata->test_completed != 1) 
 
1640             printk ("scsi%d : test 1 bad interrupt value (%d)\n", 
 
1641                 host->host_no, hostdata->test_completed);
 
1643             failed = (hostdata->test_dest != 0xdeadbeef);
 
1645         if (hostdata->test_dest != 0xdeadbeef) {
 
1646             printk ("scsi%d : driver test 1 read 0x%x instead of 0xdeadbeef indicating a\n"
 
1647                     "         probable cache invalidation problem.  Please configure caching\n"
 
1648                     "         as write-through or disabled\n",
 
1649                 host->host_no, hostdata->test_dest);
 
1653             printk ("scsi%d : DSP = 0x%p (script at 0x%p, start at 0x%x)\n",
 
1654                 host->host_no, bus_to_virt(NCR53c7x0_read32(DSP_REG)),
 
1655                 hostdata->script, start);
 
1656             printk ("scsi%d : DSPS = 0x%x\n", host->host_no,
 
1657                 NCR53c7x0_read32(DSPS_REG));
 
1658             local_irq_restore(flags);
 
1661         hostdata->test_running = 0;
 
1664     if ((hostdata->options & OPTION_DEBUG_TEST2) && 
 
1665         hostdata->state != STATE_DISABLED) {
 
1667         unsigned char identify = IDENTIFY(0, 0);
 
1668         unsigned char cmd[6];
 
1669         unsigned char data[36];
 
1670         unsigned char status = 0xff;
 
1671         unsigned char msg = 0xff;
 
1674         cmd[1] = cmd[2] = cmd[3] = cmd[5] = 0;
 
1675         cmd[4] = sizeof(data); 
 
1678         dsa[3] = virt_to_bus(&identify);
 
1680         dsa[5] = virt_to_bus(&cmd);
 
1681         dsa[6] = sizeof(data);
 
1682         dsa[7] = virt_to_bus(&data);
 
1684         dsa[9] = virt_to_bus(&status);
 
1686         dsa[11] = virt_to_bus(&msg);
 
1688         for (i = 0; i < 6; ++i) {
 
1690             if (!hostdata->valid_ids[i])
 
1693             local_irq_disable();
 
1694             if (!hostdata->idle) {
 
1695                 printk ("scsi%d : chip not idle, aborting tests\n", host->host_no);
 
1696                 local_irq_restore(flags);
 
1700             /* 710: bit mapped scsi ID, async   */
 
1701             dsa[0] = (1 << i) << 16;
 
1703             hostdata->test_running = 2;
 
1704             hostdata->test_completed = -1;
 
1705             start = virt_to_bus(hostdata->script) + hostdata->E_test_2;
 
1706             hostdata->state = STATE_RUNNING;
 
1707             NCR53c7x0_write32 (DSA_REG, virt_to_bus(dsa));
 
1708             NCR53c7x0_write32 (DSP_REG, start);
 
1709             if (hostdata->options & OPTION_DEBUG_TRACE)
 
1710                 NCR53c7x0_write8 (DCNTL_REG, hostdata->saved_dcntl |
 
1711                                 DCNTL_SSM | DCNTL_STD);
 
1712             local_irq_restore(flags);
 
1714             timeout = jiffies + 5 * HZ; /* arbitrary */
 
1715             while ((hostdata->test_completed == -1) && time_before(jiffies, timeout))
 
1718             NCR53c7x0_write32 (DSA_REG, 0);
 
1720             if (hostdata->test_completed == 2) {
 
1722                 printk ("scsi%d : test 2 INQUIRY to target %d, lun 0 : %s\n",
 
1723                     host->host_no, i, data + 8);
 
1724                 printk ("scsi%d : status ", host->host_no);
 
1725                 scsi_print_status (status);
 
1726                 printk ("\nscsi%d : message ", host->host_no);
 
1727                 scsi_print_msg (&msg);
 
1729             } else if (hostdata->test_completed == 3) {
 
1730                 printk("scsi%d : test 2 no connection with target %d\n",
 
1732                 if (!hostdata->idle) {
 
1733                     printk("scsi%d : not idle\n", host->host_no);
 
1734                     local_irq_restore(flags);
 
1737             } else if (hostdata->test_completed == -1) {
 
1738                 printk ("scsi%d : test 2 timed out\n", host->host_no);
 
1739                 local_irq_restore(flags);
 
1742             hostdata->test_running = 0;
 
1746     local_irq_restore(flags);
 
1751  * Function : static void NCR53c7xx_dsa_fixup (struct NCR53c7x0_cmd *cmd)
 
1753  * Purpose : copy the NCR53c8xx dsa structure into cmd's dsa buffer,
 
1754  *      performing all necessary relocation.
 
1756  * Inputs : cmd, a NCR53c7x0_cmd structure with a dsa area large
 
1757  *      enough to hold the NCR53c8xx dsa.
 
1761 NCR53c7xx_dsa_fixup (struct NCR53c7x0_cmd *cmd) {
 
1762     Scsi_Cmnd *c = cmd->cmd;
 
1763     struct Scsi_Host *host = c->device->host;
 
1764     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
1768     memcpy (cmd->dsa, hostdata->script + (hostdata->E_dsa_code_template / 4),
 
1769         hostdata->E_dsa_code_template_end - hostdata->E_dsa_code_template);
 
1772      * Note : within the NCR 'C' code, dsa points to the _start_
 
1773      * of the DSA structure, and _not_ the offset of dsa_zero within
 
1774      * that structure used to facilitate shorter signed offsets
 
1775      * for the 8 bit ALU.
 
1777      * The implications of this are that 
 
1779      * - 32 bit A_dsa_* absolute values require an additional 
 
1780      *   dsa_zero added to their value to be correct, since they are 
 
1781      *   relative to dsa_zero which is in essentially a separate
 
1782      *   space from the code symbols.
 
1784      * - All other symbols require no special treatment.
 
1787     patch_abs_tci_data (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1788         dsa_temp_lun, c->device->lun);
 
1789     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1790         dsa_temp_addr_next, virt_to_bus(&cmd->dsa_next_addr));
 
1791     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1792         dsa_temp_next, virt_to_bus(cmd->dsa) + Ent_dsa_zero -
 
1793         Ent_dsa_code_template + A_dsa_next);
 
1794     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32), 
 
1795         dsa_temp_sync, virt_to_bus((void *)hostdata->sync[c->device->id].script));
 
1796     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32), 
 
1797         dsa_sscf_710, virt_to_bus((void *)&hostdata->sync[c->device->id].sscf_710));
 
1798     patch_abs_tci_data (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1799             dsa_temp_target, 1 << c->device->id);
 
1800     /* XXX - new pointer stuff */
 
1801     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1802         dsa_temp_addr_saved_pointer, virt_to_bus(&cmd->saved_data_pointer));
 
1803     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1804         dsa_temp_addr_saved_residual, virt_to_bus(&cmd->saved_residual));
 
1805     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1806         dsa_temp_addr_residual, virt_to_bus(&cmd->residual));
 
1808     /*  XXX - new start stuff */
 
1810     patch_abs_32 (cmd->dsa, Ent_dsa_code_template / sizeof(u32),
 
1811         dsa_temp_addr_dsa_value, virt_to_bus(&cmd->dsa_addr));
 
1815  * Function : run_process_issue_queue (void)
 
1817  * Purpose : insure that the coroutine is running and will process our 
 
1818  *      request.  process_issue_queue_running is checked/set here (in an 
 
1819  *      inline function) rather than in process_issue_queue itself to reduce 
 
1820  *      the chances of stack overflow.
 
1824 static volatile int process_issue_queue_running = 0;
 
1826 static __inline__ void 
 
1827 run_process_issue_queue(void) {
 
1828     unsigned long flags;
 
1829     local_irq_save(flags);
 
1830     if (!process_issue_queue_running) {
 
1831         process_issue_queue_running = 1;
 
1832         process_issue_queue(flags);
 
1834          * process_issue_queue_running is cleared in process_issue_queue 
 
1835          * once it can't do more work, and process_issue_queue exits with 
 
1836          * interrupts disabled.
 
1839     local_irq_restore(flags);
 
1843  * Function : static void abnormal_finished (struct NCR53c7x0_cmd *cmd, int
 
1846  * Purpose : mark SCSI command as finished, OR'ing the host portion 
 
1847  *      of the result word into the result field of the corresponding
 
1848  *      Scsi_Cmnd structure, and removing it from the internal queues.
 
1850  * Inputs : cmd - command, result - entire result field
 
1852  * Preconditions : the  NCR chip should be in a halted state when 
 
1853  *      abnormal_finished is run, since it modifies structures which
 
1854  *      the NCR expects to have exclusive access to.
 
1858 abnormal_finished (struct NCR53c7x0_cmd *cmd, int result) {
 
1859     Scsi_Cmnd *c = cmd->cmd;
 
1860     struct Scsi_Host *host = c->device->host;
 
1861     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
1863     unsigned long flags;
 
1865     volatile struct NCR53c7x0_cmd * linux_search;
 
1866     volatile struct NCR53c7x0_cmd * volatile *linux_prev;
 
1867     volatile u32 *ncr_prev, *ncrcurrent, ncr_search;
 
1870     printk ("scsi%d: abnormal finished\n", host->host_no);
 
1873     local_irq_save(flags);
 
1876      * Traverse the NCR issue array until we find a match or run out 
 
1877      * of instructions.  Instructions in the NCR issue array are 
 
1878      * either JUMP or NOP instructions, which are 2 words in length.
 
1882     for (found = 0, left = host->can_queue, ncrcurrent = hostdata->schedule; 
 
1883         left > 0; --left, ncrcurrent += 2)
 
1885         if (issue_to_cmd (host, hostdata, (u32 *) ncrcurrent) == cmd) 
 
1887             ncrcurrent[0] = hostdata->NOP_insn;
 
1888             ncrcurrent[1] = 0xdeadbeef;
 
1895      * Traverse the NCR reconnect list of DSA structures until we find 
 
1896      * a pointer to this dsa or have found too many command structures.  
 
1897      * We let prev point at the next field of the previous element or 
 
1898      * head of the list, so we don't do anything different for removing 
 
1902     for (left = host->can_queue,
 
1903             ncr_search = hostdata->reconnect_dsa_head, 
 
1904             ncr_prev = &hostdata->reconnect_dsa_head;
 
1905         left >= 0 && ncr_search && 
 
1906             ((char*)bus_to_virt(ncr_search) + hostdata->dsa_start) 
 
1907                 != (char *) cmd->dsa;
 
1908         ncr_prev = (u32*) ((char*)bus_to_virt(ncr_search) + 
 
1909             hostdata->dsa_next), ncr_search = *ncr_prev, --left);
 
1912         printk("scsi%d: loop detected in ncr reconncect list\n",
 
1914     else if (ncr_search) {
 
1916             printk("scsi%d: scsi %ld in ncr issue array and reconnect lists\n",
 
1917                 host->host_no, c->pid);
 
1919             volatile u32 * next = (u32 *) 
 
1920                 ((char *)bus_to_virt(ncr_search) + hostdata->dsa_next);
 
1922 /* If we're at the tail end of the issue queue, update that pointer too. */
 
1928      * Traverse the host running list until we find this command or discover
 
1929      * we have too many elements, pointing linux_prev at the next field of the 
 
1930      * linux_previous element or head of the list, search at this element.
 
1933     for (left = host->can_queue, linux_search = hostdata->running_list, 
 
1934             linux_prev = &hostdata->running_list;
 
1935         left >= 0 && linux_search && linux_search != cmd;
 
1936         linux_prev = &(linux_search->next), 
 
1937             linux_search = linux_search->next, --left);
 
1940         printk ("scsi%d: loop detected in host running list for scsi pid %ld\n",
 
1941             host->host_no, c->pid);
 
1942     else if (linux_search) {
 
1943         *linux_prev = linux_search->next;
 
1944         --hostdata->busy[c->device->id][c->device->lun];
 
1947     /* Return the NCR command structure to the free list */
 
1948     cmd->next = hostdata->free;
 
1949     hostdata->free = cmd;
 
1950     c->host_scribble = NULL;
 
1956     local_irq_restore(flags);
 
1957     run_process_issue_queue();
 
1961  * Function : static void intr_break (struct Scsi_Host *host,
 
1962  *      struct NCR53c7x0_cmd *cmd)
 
1964  * Purpose :  Handler for breakpoint interrupts from a SCSI script
 
1966  * Inputs : host - pointer to this host adapter's structure,
 
1967  *      cmd - pointer to the command (if any) dsa was pointing 
 
1973 intr_break (struct Scsi_Host *host, struct 
 
1974     NCR53c7x0_cmd *cmd) {
 
1975     NCR53c7x0_local_declare();
 
1976     struct NCR53c7x0_break *bp;
 
1978     Scsi_Cmnd *c = cmd ? cmd->cmd : NULL;
 
1981     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
1983     unsigned long flags;
 
1984     NCR53c7x0_local_setup(host);
 
1987      * Find the break point corresponding to this address, and 
 
1988      * dump the appropriate debugging information to standard 
 
1991     local_irq_save(flags);
 
1992     dsp = (u32 *) bus_to_virt(NCR53c7x0_read32(DSP_REG));
 
1993     for (bp = hostdata->breakpoints; bp && bp->address != dsp; 
 
1996         panic("scsi%d : break point interrupt from %p with no breakpoint!",
 
1997             host->host_no, dsp);
 
2000      * Configure the NCR chip for manual start mode, so that we can 
 
2001      * point the DSP register at the instruction that follows the 
 
2002      * INT int_debug_break instruction.
 
2005     NCR53c7x0_write8 (hostdata->dmode, 
 
2006         NCR53c7x0_read8(hostdata->dmode)|DMODE_MAN);
 
2009      * And update the DSP register, using the size of the old 
 
2010      * instruction in bytes.
 
2013     local_irq_restore(flags);
 
2016  * Function : static void print_synchronous (const char *prefix, 
 
2017  *      const unsigned char *msg)
 
2019  * Purpose : print a pretty, user and machine parsable representation
 
2020  *      of a SDTR message, including the "real" parameters, data
 
2021  *      clock so we can tell transfer rate at a glance.
 
2023  * Inputs ; prefix - text to prepend, msg - SDTR message (5 bytes)
 
2027 print_synchronous (const char *prefix, const unsigned char *msg) {
 
2029         int Hz = 1000000000 / (msg[3] * 4);
 
2030         int integer = Hz / 1000000;
 
2031         int fraction = (Hz - (integer * 1000000)) / 10000;
 
2032         printk ("%speriod %dns offset %d %d.%02dMHz %s SCSI%s\n",
 
2033             prefix, (int) msg[3] * 4, (int) msg[4], integer, fraction,
 
2034             (((msg[3] * 4) < 200) ? "FAST" : "synchronous"),
 
2035             (((msg[3] * 4) < 200) ? "-II" : ""));
 
2037         printk ("%sasynchronous SCSI\n", prefix);
 
2041  * Function : static void set_synchronous (struct Scsi_Host *host, 
 
2042  *              int target, int sxfer, int scntl3, int now_connected)
 
2044  * Purpose : reprogram transfers between the selected SCSI initiator and 
 
2045  *      target with the given register values; in the indirect
 
2046  *      select operand, reselection script, and chip registers.
 
2048  * Inputs : host - NCR53c7,8xx SCSI host, target - number SCSI target id,
 
2049  *      sxfer and scntl3 - NCR registers. now_connected - if non-zero, 
 
2050  *      we should reprogram the registers now too.
 
2052  *      NOTE:  For 53c710, scntl3 is actually used for SCF bits from
 
2053  *      SBCL, as we don't have a SCNTL3.
 
2057 set_synchronous (struct Scsi_Host *host, int target, int sxfer, int scntl3,
 
2058     int now_connected) {
 
2059     NCR53c7x0_local_declare();
 
2060     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *) 
 
2063     NCR53c7x0_local_setup(host);
 
2065     /* These are eight bit registers */
 
2069     hostdata->sync[target].sxfer_sanity = sxfer;
 
2070     hostdata->sync[target].scntl3_sanity = scntl3;
 
2073  * HARD CODED : synchronous script is EIGHT words long.  This 
 
2074  * must agree with 53c7.8xx.h
 
2077     if ((hostdata->chip != 700) && (hostdata->chip != 70066)) {
 
2078         hostdata->sync[target].select_indirect = (1 << target) << 16 |
 
2080         hostdata->sync[target].sscf_710 = scntl3;
 
2082         script = (u32 *) hostdata->sync[target].script;
 
2084         /* XXX - add NCR53c7x0 code to reprogram SCF bits if we want to */
 
2085         script[0] = ((DCMD_TYPE_RWRI | DCMD_RWRI_OPC_MODIFY |
 
2086                 DCMD_RWRI_OP_MOVE) << 24) |
 
2087                 (SBCL_REG << 16) | (scntl3 << 8);
 
2091         script[0] = ((DCMD_TYPE_RWRI | DCMD_RWRI_OPC_MODIFY |
 
2092             DCMD_RWRI_OP_MOVE) << 24) |
 
2093                 (SXFER_REG << 16) | (sxfer << 8);
 
2097 #ifdef DEBUG_SYNC_INTR
 
2098         if (hostdata->options & OPTION_DEBUG_DISCONNECT) {
 
2099             script[0] = ((DCMD_TYPE_TCI|DCMD_TCI_OP_INT) << 24) | DBC_TCI_TRUE;
 
2100             script[1] = DEBUG_SYNC_INTR;
 
2105         script[0] = ((DCMD_TYPE_TCI|DCMD_TCI_OP_RETURN) << 24) | DBC_TCI_TRUE;
 
2110     if (hostdata->options & OPTION_DEBUG_SYNCHRONOUS) 
 
2111         printk ("scsi%d : target %d sync parameters are sxfer=0x%x, scntl3=0x%x\n",
 
2112         host->host_no, target, sxfer, scntl3);
 
2114     if (now_connected) {
 
2115         NCR53c7x0_write8(SBCL_REG, scntl3);
 
2116         NCR53c7x0_write8(SXFER_REG, sxfer);
 
2122  * Function : static int asynchronous (struct Scsi_Host *host, int target)
 
2124  * Purpose : reprogram between the selected SCSI Host adapter and target 
 
2125  *      (assumed to be currently connected) for asynchronous transfers.
 
2127  * Inputs : host - SCSI host structure, target - numeric target ID.
 
2129  * Preconditions : the NCR chip should be in one of the halted states
 
2133 asynchronous (struct Scsi_Host *host, int target) {
 
2134     NCR53c7x0_local_declare();
 
2135     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
2137     NCR53c7x0_local_setup(host);
 
2138     set_synchronous (host, target, /* no offset */ 0, hostdata->saved_scntl3,
 
2140     printk ("scsi%d : setting target %d to asynchronous SCSI\n",
 
2141         host->host_no, target);
 
2145  * XXX - do we want to go out of our way (ie, add extra code to selection
 
2146  *      in the NCR53c710/NCR53c720 script) to reprogram the synchronous
 
2147  *      conversion bits, or can we be content in just setting the 
 
2148  *      sxfer bits?  I chose to do so [richard@sleepie.demon.co.uk]
 
2151 /* Table for NCR53c8xx synchronous values */
 
2153 /* This table is also correct for 710, allowing that scf=4 is equivalent
 
2154  * of SSCF=0 (ie use DCNTL, divide by 3) for a 50.01-66.00MHz clock.
 
2155  * For any other clock values, we cannot use entries with SCF values of
 
2156  * 4.  I guess that for a 66MHz clock, the slowest it will set is 2MHz,
 
2157  * and for a 50MHz clock, the slowest will be 2.27Mhz.  Should check
 
2158  * that a device doesn't try and negotiate sync below these limits!
 
2161 static const struct {
 
2162     int div;            /* Total clock divisor * 10 */
 
2163     unsigned char scf;  /* */
 
2164     unsigned char tp;   /* 4 + tp = xferp divisor */
 
2166 /*      div     scf     tp      div     scf     tp      div     scf     tp */
 
2167     {   40,     1,      0}, {   50,     1,      1}, {   60,     1,      2}, 
 
2168     {   70,     1,      3}, {   75,     2,      1}, {   80,     1,      4},
 
2169     {   90,     1,      5}, {   100,    1,      6}, {   105,    2,      3},
 
2170     {   110,    1,      7}, {   120,    2,      4}, {   135,    2,      5},
 
2171     {   140,    3,      3}, {   150,    2,      6}, {   160,    3,      4},
 
2172     {   165,    2,      7}, {   180,    3,      5}, {   200,    3,      6},
 
2173     {   210,    4,      3}, {   220,    3,      7}, {   240,    4,      4},
 
2174     {   270,    4,      5}, {   300,    4,      6}, {   330,    4,      7}
 
2178  * Function : static void synchronous (struct Scsi_Host *host, int target, 
 
2181  * Purpose : reprogram transfers between the selected SCSI initiator and 
 
2182  *      target for synchronous SCSI transfers such that the synchronous 
 
2183  *      offset is less than that requested and period at least as long 
 
2184  *      as that requested.  Also modify *msg such that it contains 
 
2185  *      an appropriate response. 
 
2187  * Inputs : host - NCR53c7,8xx SCSI host, target - number SCSI target id,
 
2188  *      msg - synchronous transfer request.
 
2193 synchronous (struct Scsi_Host *host, int target, char *msg) {
 
2194     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
2196     int desire, divisor, i, limit;
 
2197     unsigned char scntl3, sxfer;
 
2198 /* The diagnostic message fits on one line, even with max. width integers */
 
2201 /* Desired transfer clock in Hz */
 
2202     desire = 1000000000L / (msg[3] * 4);
 
2203 /* Scale the available SCSI clock by 10 so we get tenths */
 
2204     divisor = (hostdata->scsi_clock * 10) / desire;
 
2206 /* NCR chips can handle at most an offset of 8 */
 
2210     if (hostdata->options & OPTION_DEBUG_SDTR)
 
2211         printk("scsi%d : optimal synchronous divisor of %d.%01d\n", 
 
2212             host->host_no, divisor / 10, divisor % 10);
 
2214     limit = (sizeof(syncs) / sizeof(syncs[0]) -1);
 
2215     for (i = 0; (i < limit) && (divisor > syncs[i].div); ++i);
 
2217     if (hostdata->options & OPTION_DEBUG_SDTR)
 
2218         printk("scsi%d : selected synchronous divisor of %d.%01d\n", 
 
2219             host->host_no, syncs[i].div / 10, syncs[i].div % 10);
 
2221     msg[3] = ((1000000000L / hostdata->scsi_clock) * syncs[i].div / 10 / 4);
 
2223     if (hostdata->options & OPTION_DEBUG_SDTR)
 
2224         printk("scsi%d : selected synchronous period of %dns\n", host->host_no,
 
2227     scntl3 = syncs[i].scf;
 
2228     sxfer = (msg[4] << SXFER_MO_SHIFT) | (syncs[i].tp << 4);
 
2229     if (hostdata->options & OPTION_DEBUG_SDTR)
 
2230         printk ("scsi%d : sxfer=0x%x scntl3=0x%x\n", 
 
2231             host->host_no, (int) sxfer, (int) scntl3);
 
2232     set_synchronous (host, target, sxfer, scntl3, 1);
 
2233     sprintf (buf, "scsi%d : setting target %d to ", host->host_no, target);
 
2234     print_synchronous (buf, msg);
 
2238  * Function : static int NCR53c7x0_dstat_sir_intr (struct Scsi_Host *host,
 
2239  *      struct NCR53c7x0_cmd *cmd)
 
2241  * Purpose :  Handler for INT generated instructions for the 
 
2242  *      NCR53c810/820 SCSI SCRIPT
 
2244  * Inputs : host - pointer to this host adapter's structure,
 
2245  *      cmd - pointer to the command (if any) dsa was pointing 
 
2251 NCR53c7x0_dstat_sir_intr (struct Scsi_Host *host, struct 
 
2252     NCR53c7x0_cmd *cmd) {
 
2253     NCR53c7x0_local_declare();
 
2255     Scsi_Cmnd *c = cmd ? cmd->cmd : NULL;
 
2256     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
2258     u32 dsps,*dsp;      /* Argument of the INT instruction */
 
2260     NCR53c7x0_local_setup(host);
 
2261     dsps = NCR53c7x0_read32(DSPS_REG);
 
2262     dsp = (u32 *) bus_to_virt(NCR53c7x0_read32(DSP_REG));
 
2264     /* RGH 150597:  Frig.  Commands which fail with Check Condition are
 
2265      * Flagged as successful - hack dsps to indicate check condition */
 
2267     /* RGH 200597:  Need to disable for BVME6000, as it gets Check Conditions
 
2268      * and then dies.  Seems to handle Check Condition at startup, but
 
2269      * not mid kernel build. */
 
2270     if (dsps == A_int_norm_emulateintfly && cmd && cmd->result == 2)
 
2271         dsps = A_int_err_check_condition;
 
2274     if (hostdata->options & OPTION_DEBUG_INTR) 
 
2275         printk ("scsi%d : DSPS = 0x%x\n", host->host_no, dsps);
 
2280         switch (hostdata->msg_buf[0]) {
 
2282          * Unless we've initiated synchronous negotiation, I don't
 
2283          * think that this should happen.
 
2285         case MESSAGE_REJECT:
 
2286             hostdata->dsp = hostdata->script + hostdata->E_accept_message /
 
2288             hostdata->dsp_changed = 1;
 
2289             if (cmd && (cmd->flags & CMD_FLAG_SDTR)) {
 
2290                 printk ("scsi%d : target %d rejected SDTR\n", host->host_no, 
 
2292                 cmd->flags &= ~CMD_FLAG_SDTR;
 
2293                 asynchronous (host, c->device->id);
 
2297         case INITIATE_RECOVERY:
 
2298             printk ("scsi%d : extended contingent allegiance not supported yet, rejecting\n",
 
2300             /* Fall through to default */
 
2301             hostdata->dsp = hostdata->script + hostdata->E_reject_message /
 
2303             hostdata->dsp_changed = 1;
 
2306             printk ("scsi%d : unsupported message, rejecting\n",
 
2308             hostdata->dsp = hostdata->script + hostdata->E_reject_message /
 
2310             hostdata->dsp_changed = 1;
 
2313             printk ("scsi%d : received message", host->host_no);
 
2315                 printk (" from target %d lun %d ", c->device->id, c->device->lun);
 
2316             scsi_print_msg ((unsigned char *) hostdata->msg_buf);
 
2320         return SPECIFIC_INT_NOTHING;
 
2323     case A_int_msg_sdtr:
 
2325  * At this point, hostdata->msg_buf contains
 
2326  * 0 EXTENDED MESSAGE
 
2335             sprintf (buf, "scsi%d : target %d %s ", host->host_no, c->device->id,
 
2336                 (cmd->flags & CMD_FLAG_SDTR) ? "accepting" : "requesting");
 
2337             print_synchronous (buf, (unsigned char *) hostdata->msg_buf);
 
2340          * Initiator initiated, won't happen unless synchronous 
 
2341          *      transfers are enabled.  If we get a SDTR message in
 
2342          *      response to our SDTR, we should program our parameters
 
2344          *              offset <= requested offset
 
2345          *              period >= requested period                      
 
2347             if (cmd->flags & CMD_FLAG_SDTR) {
 
2348                 cmd->flags &= ~CMD_FLAG_SDTR; 
 
2349                 if (hostdata->msg_buf[4]) 
 
2350                     synchronous (host, c->device->id, (unsigned char *) 
 
2353                     asynchronous (host, c->device->id);
 
2354                 hostdata->dsp = hostdata->script + hostdata->E_accept_message /
 
2356                 hostdata->dsp_changed = 1;
 
2357                 return SPECIFIC_INT_NOTHING;
 
2359                 if (hostdata->options & OPTION_SYNCHRONOUS)  {
 
2360                     cmd->flags |= CMD_FLAG_DID_SDTR;
 
2361                     synchronous (host, c->device->id, (unsigned char *) 
 
2364                     hostdata->msg_buf[4] = 0;           /* 0 offset = async */
 
2365                     asynchronous (host, c->device->id);
 
2367                 patch_dsa_32 (cmd->dsa, dsa_msgout_other, 0, 5);
 
2368                 patch_dsa_32 (cmd->dsa, dsa_msgout_other, 1, (u32) 
 
2369                     virt_to_bus ((void *)&hostdata->msg_buf));
 
2370                 hostdata->dsp = hostdata->script + 
 
2371                     hostdata->E_respond_message / sizeof(u32);
 
2372                 hostdata->dsp_changed = 1;
 
2374             return SPECIFIC_INT_NOTHING;
 
2376         /* Fall through to abort if we couldn't find a cmd, and 
 
2377            therefore a dsa structure to twiddle */
 
2378     case A_int_msg_wdtr:
 
2379         hostdata->dsp = hostdata->script + hostdata->E_reject_message /
 
2381         hostdata->dsp_changed = 1;
 
2382         return SPECIFIC_INT_NOTHING;
 
2383     case A_int_err_unexpected_phase:
 
2384         if (hostdata->options & OPTION_DEBUG_INTR) 
 
2385             printk ("scsi%d : unexpected phase\n", host->host_no);
 
2386         return SPECIFIC_INT_ABORT;
 
2387     case A_int_err_selected:
 
2388         if ((hostdata->chip / 100) == 8)
 
2389             printk ("scsi%d : selected by target %d\n", host->host_no,
 
2390                 (int) NCR53c7x0_read8(SDID_REG_800) &7);
 
2392             printk ("scsi%d : selected by target LCRC=0x%02x\n", host->host_no,
 
2393                 (int) NCR53c7x0_read8(LCRC_REG_10));
 
2394         hostdata->dsp = hostdata->script + hostdata->E_target_abort / 
 
2396         hostdata->dsp_changed = 1;
 
2397         return SPECIFIC_INT_NOTHING;
 
2398     case A_int_err_unexpected_reselect:
 
2399         if ((hostdata->chip / 100) == 8)
 
2400             printk ("scsi%d : unexpected reselect by target %d lun %d\n", 
 
2401                 host->host_no, (int) NCR53c7x0_read8(SDID_REG_800) & 7,
 
2402                 hostdata->reselected_identify & 7);
 
2404             printk ("scsi%d : unexpected reselect LCRC=0x%02x\n", host->host_no,
 
2405                 (int) NCR53c7x0_read8(LCRC_REG_10));
 
2406         hostdata->dsp = hostdata->script + hostdata->E_initiator_abort /
 
2408         hostdata->dsp_changed = 1;
 
2409         return SPECIFIC_INT_NOTHING;
 
2411  * Since contingent allegiance conditions are cleared by the next 
 
2412  * command issued to a target, we must issue a REQUEST SENSE 
 
2413  * command after receiving a CHECK CONDITION status, before
 
2414  * another command is issued.
 
2416  * Since this NCR53c7x0_cmd will be freed after use, we don't 
 
2417  * care if we step on the various fields, so modify a few things.
 
2419     case A_int_err_check_condition: 
 
2421         if (hostdata->options & OPTION_DEBUG_INTR) 
 
2423             printk ("scsi%d : CHECK CONDITION\n", host->host_no);
 
2425             printk("scsi%d : CHECK CONDITION with no SCSI command\n",
 
2427             return SPECIFIC_INT_PANIC;
 
2431          * FIXME : this uses the normal one-byte selection message.
 
2432          *      We may want to renegotiate for synchronous & WIDE transfers
 
2433          *      since these could be the crux of our problem.
 
2435          hostdata->NOP_insn* FIXME : once SCSI-II tagged queuing is implemented, we'll
 
2436          *      have to set this up so that the rest of the DSA
 
2437          *      agrees with this being an untagged queue'd command.
 
2440         patch_dsa_32 (cmd->dsa, dsa_msgout, 0, 1);
 
2443          * Modify the table indirect for COMMAND OUT phase, since 
 
2444          * Request Sense is a six byte command.
 
2447         patch_dsa_32 (cmd->dsa, dsa_cmdout, 0, 6);
 
2450          * The CDB is now mirrored in our local non-cached
 
2451          * structure, but keep the old structure up to date as well,
 
2452          * just in case anyone looks at it.
 
2456          * XXX Need to worry about data buffer alignment/cache state
 
2457          * XXX here, but currently never get A_int_err_check_condition,
 
2458          * XXX so ignore problem for now.
 
2460         cmd->cmnd[0] = c->cmnd[0] = REQUEST_SENSE;
 
2461         cmd->cmnd[0] = c->cmnd[1] &= 0xe0;      /* Zero all but LUN */
 
2462         cmd->cmnd[0] = c->cmnd[2] = 0;
 
2463         cmd->cmnd[0] = c->cmnd[3] = 0;
 
2464         cmd->cmnd[0] = c->cmnd[4] = sizeof(c->sense_buffer);
 
2465         cmd->cmnd[0] = c->cmnd[5] = 0; 
 
2468          * Disable dataout phase, and program datain to transfer to the 
 
2469          * sense buffer, and add a jump to other_transfer after the 
 
2470          * command so overflow/underrun conditions are detected.
 
2473         patch_dsa_32 (cmd->dsa, dsa_dataout, 0, 
 
2474             virt_to_bus(hostdata->script) + hostdata->E_other_transfer);
 
2475         patch_dsa_32 (cmd->dsa, dsa_datain, 0, 
 
2476             virt_to_bus(cmd->data_transfer_start));
 
2477         cmd->data_transfer_start[0] = (((DCMD_TYPE_BMI | DCMD_BMI_OP_MOVE_I | 
 
2478             DCMD_BMI_IO)) << 24) | sizeof(c->sense_buffer);
 
2479         cmd->data_transfer_start[1] = (u32) virt_to_bus(c->sense_buffer);
 
2481         cmd->data_transfer_start[2] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_JUMP) 
 
2482             << 24) | DBC_TCI_TRUE;
 
2483         cmd->data_transfer_start[3] = (u32) virt_to_bus(hostdata->script) + 
 
2484             hostdata->E_other_transfer;
 
2487          * Currently, this command is flagged as completed, ie 
 
2488          * it has valid status and message data.  Reflag it as
 
2489          * incomplete.  Q - need to do something so that original
 
2490          * status, etc are used.
 
2493         cmd->result = cmd->cmd->result = 0xffff;                
 
2496          * Restart command as a REQUEST SENSE.
 
2498         hostdata->dsp = (u32 *) hostdata->script + hostdata->E_select /
 
2500         hostdata->dsp_changed = 1;
 
2501         return SPECIFIC_INT_NOTHING;
 
2502     case A_int_debug_break:
 
2503         return SPECIFIC_INT_BREAK;
 
2504     case A_int_norm_aborted:
 
2505         hostdata->dsp = (u32 *) hostdata->schedule;
 
2506         hostdata->dsp_changed = 1;
 
2508             abnormal_finished (cmd, DID_ERROR << 16);
 
2509         return SPECIFIC_INT_NOTHING;
 
2510     case A_int_norm_emulateintfly:
 
2511         NCR53c7x0_intfly(host);
 
2512         return SPECIFIC_INT_NOTHING;
 
2516         hostdata->test_completed = (dsps - A_int_test_1) / 0x00010000 + 1;
 
2517         if (hostdata->options & OPTION_DEBUG_INTR)
 
2518             printk("scsi%d : test%d complete\n", host->host_no,
 
2519                 hostdata->test_completed);
 
2520         return SPECIFIC_INT_NOTHING;
 
2521 #ifdef A_int_debug_reselected_ok
 
2522     case A_int_debug_reselected_ok:
 
2523         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2524                 OPTION_DEBUG_DISCONNECT)) {
 
2526              * Note - this dsa is not based on location relative to 
 
2527              * the command structure, but to location relative to the 
 
2531             dsa = (u32 *) bus_to_virt (NCR53c7x0_read32(DSA_REG));
 
2533             printk("scsi%d : reselected_ok (DSA = 0x%x (virt 0x%p)\n", 
 
2534                 host->host_no, NCR53c7x0_read32(DSA_REG), dsa);
 
2535             printk("scsi%d : resume address is 0x%x (virt 0x%p)\n",
 
2536                     host->host_no, cmd->saved_data_pointer,
 
2537                     bus_to_virt(cmd->saved_data_pointer));
 
2538             print_insn (host, hostdata->script + Ent_reselected_ok / 
 
2539                     sizeof(u32), "", 1);
 
2540             if ((hostdata->chip / 100) == 8)
 
2541                 printk ("scsi%d : sxfer=0x%x, scntl3=0x%x\n",
 
2542                     host->host_no, NCR53c7x0_read8(SXFER_REG),
 
2543                     NCR53c7x0_read8(SCNTL3_REG_800));
 
2545                 printk ("scsi%d : sxfer=0x%x, cannot read SBCL\n",
 
2546                     host->host_no, NCR53c7x0_read8(SXFER_REG));
 
2548                 print_insn (host, (u32 *) 
 
2549                     hostdata->sync[c->device->id].script, "", 1);
 
2550                 print_insn (host, (u32 *) 
 
2551                     hostdata->sync[c->device->id].script + 2, "", 1);
 
2554         return SPECIFIC_INT_RESTART;
 
2556 #ifdef A_int_debug_reselect_check
 
2557     case A_int_debug_reselect_check:
 
2558         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2564              * Note - this dsa is not based on location relative to 
 
2565              * the command structure, but to location relative to the 
 
2568             dsa = bus_to_virt (NCR53c7x0_read32(DSA_REG));
 
2569             printk("scsi%d : reselected_check_next (DSA = 0x%lx (virt 0x%p))\n",
 
2570                 host->host_no, virt_to_bus(dsa), dsa);
 
2572                 printk("scsi%d : resume address is 0x%x (virt 0x%p)\n",
 
2573                     host->host_no, cmd->saved_data_pointer,
 
2574                     bus_to_virt (cmd->saved_data_pointer));
 
2576                 printk("scsi%d : template code :\n", host->host_no);
 
2577                 for (code = dsa + (Ent_dsa_code_check_reselect - Ent_dsa_zero) 
 
2578                     / sizeof(u32); code < (dsa + Ent_dsa_zero / sizeof(u32)); 
 
2579                     code += print_insn (host, code, "", 1));
 
2582             print_insn (host, hostdata->script + Ent_reselected_ok / 
 
2583                     sizeof(u32), "", 1);
 
2585         return SPECIFIC_INT_RESTART;
 
2587 #ifdef A_int_debug_dsa_schedule
 
2588     case A_int_debug_dsa_schedule:
 
2589         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2592              * Note - this dsa is not based on location relative to 
 
2593              * the command structure, but to location relative to the 
 
2596             dsa = (u32 *) bus_to_virt (NCR53c7x0_read32(DSA_REG));
 
2597             printk("scsi%d : dsa_schedule (old DSA = 0x%lx (virt 0x%p))\n", 
 
2598                 host->host_no, virt_to_bus(dsa), dsa);
 
2600                 printk("scsi%d : resume address is 0x%x (virt 0x%p)\n"
 
2601                        "         (temp was 0x%x (virt 0x%p))\n",
 
2602                     host->host_no, cmd->saved_data_pointer,
 
2603                     bus_to_virt (cmd->saved_data_pointer),
 
2604                     NCR53c7x0_read32 (TEMP_REG),
 
2605                     bus_to_virt (NCR53c7x0_read32(TEMP_REG)));
 
2607         return SPECIFIC_INT_RESTART;
 
2609 #ifdef A_int_debug_scheduled
 
2610     case A_int_debug_scheduled:
 
2611         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2612             printk("scsi%d : new I/O 0x%x (virt 0x%p) scheduled\n", 
 
2613                 host->host_no, NCR53c7x0_read32(DSA_REG),
 
2614                 bus_to_virt(NCR53c7x0_read32(DSA_REG)));
 
2616         return SPECIFIC_INT_RESTART;
 
2618 #ifdef A_int_debug_idle
 
2619     case A_int_debug_idle:
 
2620         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2621             printk("scsi%d : idle\n", host->host_no);
 
2623         return SPECIFIC_INT_RESTART;
 
2625 #ifdef A_int_debug_cmd
 
2626     case A_int_debug_cmd:
 
2627         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2628             printk("scsi%d : command sent\n");
 
2630         return SPECIFIC_INT_RESTART;
 
2632 #ifdef A_int_debug_dsa_loaded
 
2633     case A_int_debug_dsa_loaded:
 
2634         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2635             printk("scsi%d : DSA loaded with 0x%x (virt 0x%p)\n", host->host_no,
 
2636                 NCR53c7x0_read32(DSA_REG), 
 
2637                 bus_to_virt(NCR53c7x0_read32(DSA_REG)));
 
2639         return SPECIFIC_INT_RESTART; 
 
2641 #ifdef A_int_debug_reselected
 
2642     case A_int_debug_reselected:
 
2643         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2644             OPTION_DEBUG_DISCONNECT)) {
 
2645             if ((hostdata->chip / 100) == 8)
 
2646                 printk("scsi%d : reselected by target %d lun %d\n",
 
2647                     host->host_no, (int) NCR53c7x0_read8(SDID_REG_800) & ~0x80, 
 
2648                     (int) hostdata->reselected_identify & 7);
 
2650                 printk("scsi%d : reselected by LCRC=0x%02x lun %d\n",
 
2651                     host->host_no, (int) NCR53c7x0_read8(LCRC_REG_10),
 
2652                     (int) hostdata->reselected_identify & 7);
 
2655         return SPECIFIC_INT_RESTART;
 
2657 #ifdef A_int_debug_disconnect_msg
 
2658     case A_int_debug_disconnect_msg:
 
2659         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR)) {
 
2661                 printk("scsi%d : target %d lun %d disconnecting\n", 
 
2662                     host->host_no, c->device->id, c->device->lun);
 
2664                 printk("scsi%d : unknown target disconnecting\n",
 
2667         return SPECIFIC_INT_RESTART;
 
2669 #ifdef A_int_debug_disconnected
 
2670     case A_int_debug_disconnected:
 
2671         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2672                 OPTION_DEBUG_DISCONNECT)) {
 
2673             printk ("scsi%d : disconnected, new queues are\n", 
 
2677             /* Not valid on ncr53c710! */
 
2678             printk ("scsi%d : sxfer=0x%x, scntl3=0x%x\n",
 
2679                 host->host_no, NCR53c7x0_read8(SXFER_REG),
 
2680                 NCR53c7x0_read8(SCNTL3_REG_800));
 
2683                 print_insn (host, (u32 *) 
 
2684                     hostdata->sync[c->device->id].script, "", 1);
 
2685                 print_insn (host, (u32 *) 
 
2686                     hostdata->sync[c->device->id].script + 2, "", 1);
 
2689         return SPECIFIC_INT_RESTART;
 
2691 #ifdef A_int_debug_panic
 
2692     case A_int_debug_panic:
 
2693         printk("scsi%d : int_debug_panic received\n", host->host_no);
 
2695         return SPECIFIC_INT_PANIC;
 
2697 #ifdef A_int_debug_saved
 
2698     case A_int_debug_saved:
 
2699         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2700             OPTION_DEBUG_DISCONNECT)) {
 
2701             printk ("scsi%d : saved data pointer 0x%x (virt 0x%p)\n",
 
2702                 host->host_no, cmd->saved_data_pointer,
 
2703                 bus_to_virt (cmd->saved_data_pointer));
 
2706         return SPECIFIC_INT_RESTART;
 
2708 #ifdef A_int_debug_restored
 
2709     case A_int_debug_restored:
 
2710         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2711             OPTION_DEBUG_DISCONNECT)) {
 
2714                 printk ("scsi%d : restored data pointer 0x%x (virt 0x%p)\n",
 
2715                     host->host_no, cmd->saved_data_pointer, bus_to_virt (
 
2716                     cmd->saved_data_pointer));
 
2717                 size = print_insn (host, (u32 *) 
 
2718                     bus_to_virt(cmd->saved_data_pointer), "", 1);
 
2719                 size = print_insn (host, (u32 *) 
 
2720                     bus_to_virt(cmd->saved_data_pointer) + size, "", 1);
 
2724             printk ("scsi%d : datapath residual %d\n",
 
2725                 host->host_no, datapath_residual (host)) ;
 
2728         return SPECIFIC_INT_RESTART;
 
2730 #ifdef A_int_debug_sync
 
2731     case A_int_debug_sync:
 
2732         if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2733             OPTION_DEBUG_DISCONNECT|OPTION_DEBUG_SDTR)) {
 
2734             unsigned char sxfer = NCR53c7x0_read8 (SXFER_REG), scntl3;
 
2735             if ((hostdata->chip / 100) == 8) {
 
2736                 scntl3 = NCR53c7x0_read8 (SCNTL3_REG_800);
 
2738                   if (sxfer != hostdata->sync[c->device->id].sxfer_sanity ||
 
2739                     scntl3 != hostdata->sync[c->device->id].scntl3_sanity) {
 
2740                         printk ("scsi%d :  sync sanity check failed sxfer=0x%x, scntl3=0x%x",
 
2741                             host->host_no, sxfer, scntl3);
 
2742                         NCR53c7x0_write8 (SXFER_REG, sxfer);
 
2743                         NCR53c7x0_write8 (SCNTL3_REG_800, scntl3);
 
2746                   printk ("scsi%d : unknown command sxfer=0x%x, scntl3=0x%x\n",
 
2747                     host->host_no, (int) sxfer, (int) scntl3);
 
2750                   if (sxfer != hostdata->sync[c->device->id].sxfer_sanity) {
 
2751                         printk ("scsi%d :  sync sanity check failed sxfer=0x%x",
 
2752                             host->host_no, sxfer);
 
2753                         NCR53c7x0_write8 (SXFER_REG, sxfer);
 
2754                         NCR53c7x0_write8 (SBCL_REG,
 
2755                                 hostdata->sync[c->device->id].sscf_710);
 
2758                   printk ("scsi%d : unknown command sxfer=0x%x\n",
 
2759                     host->host_no, (int) sxfer);
 
2762         return SPECIFIC_INT_RESTART;
 
2764 #ifdef A_int_debug_datain
 
2765         case A_int_debug_datain:
 
2766             if (hostdata->options & (OPTION_DEBUG_SCRIPT|OPTION_DEBUG_INTR|
 
2767                 OPTION_DEBUG_DISCONNECT|OPTION_DEBUG_SDTR)) {
 
2769                 if ((hostdata->chip / 100) == 8)
 
2770                   printk ("scsi%d : In do_datain (%s) sxfer=0x%x, scntl3=0x%x\n"
 
2771                         "         datapath residual=%d\n",
 
2772                     host->host_no, sbcl_to_phase (NCR53c7x0_read8 (SBCL_REG)),
 
2773                     (int) NCR53c7x0_read8(SXFER_REG), 
 
2774                     (int) NCR53c7x0_read8(SCNTL3_REG_800),
 
2775                     datapath_residual (host)) ;
 
2777                   printk ("scsi%d : In do_datain (%s) sxfer=0x%x\n"
 
2778                         "         datapath residual=%d\n",
 
2779                     host->host_no, sbcl_to_phase (NCR53c7x0_read8 (SBCL_REG)),
 
2780                     (int) NCR53c7x0_read8(SXFER_REG), 
 
2781                     datapath_residual (host)) ;
 
2782                 print_insn (host, dsp, "", 1);
 
2783                 size = print_insn (host, (u32 *) bus_to_virt(dsp[1]), "", 1);
 
2784                 print_insn (host, (u32 *) bus_to_virt(dsp[1]) + size, "", 1);
 
2786         return SPECIFIC_INT_RESTART;
 
2788 #ifdef A_int_debug_check_dsa
 
2789         case A_int_debug_check_dsa:
 
2790             if (NCR53c7x0_read8 (SCNTL1_REG) & SCNTL1_CON) {
 
2794                 if (hostdata->chip / 100 == 8)
 
2795                     sdid = NCR53c7x0_read8 (SDID_REG_800) & 15;
 
2797                     tmp = NCR53c7x0_read8 (SDID_REG_700);
 
2799                         panic ("SDID_REG_700 = 0");
 
2807                 where = dsp - NCR53c7x0_insn_size(NCR53c7x0_read8 
 
2808                         (DCMD_REG)) == hostdata->script + 
 
2809                         Ent_select_check_dsa / sizeof(u32) ?
 
2810                     "selection" : "reselection";
 
2811                 if (c && sdid != c->device->id) {
 
2812                     printk ("scsi%d : SDID target %d != DSA target %d at %s\n",
 
2813                         host->host_no, sdid, c->device->id, where);
 
2815                     dump_events (host, 20);
 
2816                     return SPECIFIC_INT_PANIC;
 
2819             return SPECIFIC_INT_RESTART;
 
2822         if ((dsps & 0xff000000) == 0x03000000) {
 
2823              printk ("scsi%d : misc debug interrupt 0x%x\n",
 
2824                 host->host_no, dsps);
 
2825             return SPECIFIC_INT_RESTART;
 
2826         } else if ((dsps & 0xff000000) == 0x05000000) {
 
2827             if (hostdata->events) {
 
2828                 struct NCR53c7x0_event *event;
 
2829                 ++hostdata->event_index;
 
2830                 if (hostdata->event_index >= hostdata->event_size)
 
2831                     hostdata->event_index = 0;
 
2832                 event = (struct NCR53c7x0_event *) hostdata->events + 
 
2833                     hostdata->event_index;
 
2834                 event->event = (enum ncr_event) dsps;
 
2835                 event->dsa = bus_to_virt(NCR53c7x0_read32(DSA_REG));
 
2836                 if (NCR53c7x0_read8 (SCNTL1_REG) & SCNTL1_CON) {
 
2837                     if (hostdata->chip / 100 == 8)
 
2838                         event->target = NCR53c7x0_read8(SSID_REG_800);
 
2840                         unsigned char tmp, sdid;
 
2841                         tmp = NCR53c7x0_read8 (SDID_REG_700);
 
2843                             panic ("SDID_REG_700 = 0");
 
2850                         event->target = sdid;
 
2854                         event->target = 255;
 
2856                 if (event->event == EVENT_RESELECT)
 
2857                     event->lun = hostdata->reselected_identify & 0xf;
 
2859                     event->lun = c->device->lun;
 
2862                 do_gettimeofday(&(event->time));
 
2864                     event->pid = c->pid;
 
2865                     memcpy ((void *) event->cmnd, (void *) c->cmnd, 
 
2866                         sizeof (event->cmnd));
 
2871             return SPECIFIC_INT_RESTART;
 
2874         printk ("scsi%d : unknown user interrupt 0x%x\n", 
 
2875             host->host_no, (unsigned) dsps);
 
2876         return SPECIFIC_INT_PANIC;
 
2881  * XXX - the stock NCR assembler won't output the scriptu.h file,
 
2882  * which undefine's all #define'd CPP symbols from the script.h
 
2883  * file, which will create problems if you use multiple scripts
 
2884  * with the same  symbol names.
 
2886  * If you insist on using NCR's assembler, you could generate
 
2887  * scriptu.h from script.h using something like 
 
2889  * grep #define script.h | \
 
2890  * sed 's/#define[      ][      ]*\([_a-zA-Z][_a-zA-Z0-9]*\).*$/#undefine \1/' \
 
2894 #include "53c7xx_u.h"
 
2896 /* XXX - add alternate script handling code here */
 
2900  * Function : static void NCR537xx_soft_reset (struct Scsi_Host *host)
 
2902  * Purpose :  perform a soft reset of the NCR53c7xx chip
 
2904  * Inputs : host - pointer to this host adapter's structure
 
2906  * Preconditions : NCR53c7x0_init must have been called for this 
 
2912 NCR53c7x0_soft_reset (struct Scsi_Host *host) {
 
2913     NCR53c7x0_local_declare();
 
2914     unsigned long flags;
 
2915     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
2917     NCR53c7x0_local_setup(host);
 
2919     local_irq_save(flags);
 
2921     /* Disable scsi chip and s/w level 7 ints */
 
2923 #ifdef CONFIG_MVME16x
 
2924     if (MACH_IS_MVME16x)
 
2926         volatile unsigned long v;
 
2928         v = *(volatile unsigned long *)0xfff4006c;
 
2930         *(volatile unsigned long *)0xfff4006c = v;
 
2931         v = *(volatile unsigned long *)0xfff4202c;
 
2933         *(volatile unsigned long *)0xfff4202c = v;
 
2936     /* Anything specific for your hardware? */
 
2939      * Do a soft reset of the chip so that everything is 
 
2940      * reinitialized to the power-on state.
 
2942      * Basically follow the procedure outlined in the NCR53c700
 
2943      * data manual under Chapter Six, How to Use, Steps Necessary to
 
2944      * Start SCRIPTS, with the exception of actually starting the 
 
2945      * script and setting up the synchronous transfer gunk.
 
2948     /* Should we reset the scsi bus here??????????????????? */
 
2950     NCR53c7x0_write8(ISTAT_REG_700, ISTAT_10_SRST);
 
2951     NCR53c7x0_write8(ISTAT_REG_700, 0);
 
2954      * saved_dcntl is set up in NCR53c7x0_init() before it is overwritten
 
2955      * here.  We should have some better way of working out the CF bit
 
2959     hostdata->saved_dcntl = DCNTL_10_EA|DCNTL_10_COM;
 
2960     if (hostdata->scsi_clock > 50000000)
 
2961         hostdata->saved_dcntl |= DCNTL_700_CF_3;
 
2963     if (hostdata->scsi_clock > 37500000)
 
2964         hostdata->saved_dcntl |= DCNTL_700_CF_2;
 
2967         /* Any clocks less than 37.5MHz? */
 
2970     if (hostdata->options & OPTION_DEBUG_TRACE)
 
2971         NCR53c7x0_write8(DCNTL_REG, hostdata->saved_dcntl | DCNTL_SSM);
 
2973         NCR53c7x0_write8(DCNTL_REG, hostdata->saved_dcntl);
 
2974     /* Following disables snooping - snooping is not required, as non-
 
2975      * cached pages are used for shared data, and appropriate use is
 
2976      * made of cache_push/cache_clear.  Indeed, for 68060
 
2977      * enabling snooping causes disk corruption of ext2fs free block
 
2978      * bitmaps and the like.  If you have a 68060 with snooping hardwared
 
2979      * on, then you need to enable CONFIG_060_WRITETHROUGH.
 
2981     NCR53c7x0_write8(CTEST7_REG, CTEST7_10_TT1|CTEST7_STD);
 
2982     /* Actually burst of eight, according to my 53c710 databook */
 
2983     NCR53c7x0_write8(hostdata->dmode, DMODE_10_BL_8 | DMODE_10_FC2);
 
2984     NCR53c7x0_write8(SCID_REG, 1 << host->this_id);
 
2985     NCR53c7x0_write8(SBCL_REG, 0);
 
2986     NCR53c7x0_write8(SCNTL1_REG, SCNTL1_ESR_700);
 
2987     NCR53c7x0_write8(SCNTL0_REG, ((hostdata->options & OPTION_PARITY) ? 
 
2988             SCNTL0_EPC : 0) | SCNTL0_EPG_700 | SCNTL0_ARB1 | SCNTL0_ARB2);
 
2991      * Enable all interrupts, except parity which we only want when
 
2992      * the user requests it.
 
2995     NCR53c7x0_write8(DIEN_REG, DIEN_700_BF |
 
2996                 DIEN_ABRT | DIEN_SSI | DIEN_SIR | DIEN_700_OPC);
 
2998     NCR53c7x0_write8(SIEN_REG_700, ((hostdata->options & OPTION_PARITY) ?
 
2999             SIEN_PAR : 0) | SIEN_700_STO | SIEN_RST | SIEN_UDC |
 
3000                 SIEN_SGE | SIEN_MA);
 
3002 #ifdef CONFIG_MVME16x
 
3003     if (MACH_IS_MVME16x)
 
3005         volatile unsigned long v;
 
3007         /* Enable scsi chip and s/w level 7 ints */
 
3008         v = *(volatile unsigned long *)0xfff40080;
 
3009         v = (v & ~(0xf << 28)) | (4 << 28);
 
3010         *(volatile unsigned long *)0xfff40080 = v;
 
3011         v = *(volatile unsigned long *)0xfff4006c;
 
3013         *(volatile unsigned long *)0xfff4006c = v;
 
3014         v = *(volatile unsigned long *)0xfff4202c;
 
3015         v = (v & ~0xff) | 0x10 | 4;
 
3016         *(volatile unsigned long *)0xfff4202c = v;
 
3019     /* Anything needed for your hardware? */
 
3020     local_irq_restore(flags);
 
3025  * Function static struct NCR53c7x0_cmd *allocate_cmd (Scsi_Cmnd *cmd)
 
3027  * Purpose : Return the first free NCR53c7x0_cmd structure (which are 
 
3028  *      reused in a LIFO manner to minimize cache thrashing).
 
3030  * Side effects : If we haven't yet scheduled allocation of NCR53c7x0_cmd
 
3031  *      structures for this device, do so.  Attempt to complete all scheduled
 
3032  *      allocations using get_zeroed_page(), putting NCR53c7x0_cmd structures on
 
3033  *      the free list.  Teach programmers not to drink and hack.
 
3035  * Inputs : cmd - SCSI command
 
3037  * Returns : NCR53c7x0_cmd structure allocated on behalf of cmd;
 
3042 my_free_page (void *addr, int dummy)
 
3044     /* XXX This assumes default cache mode to be IOMAP_FULL_CACHING, which
 
3045      * XXX may be invalid (CONFIG_060_WRITETHROUGH)
 
3047     kernel_set_cachemode((void *)addr, 4096, IOMAP_FULL_CACHING);
 
3048     free_page ((u32)addr);
 
3051 static struct NCR53c7x0_cmd *
 
3052 allocate_cmd (Scsi_Cmnd *cmd) {
 
3053     struct Scsi_Host *host = cmd->device->host;
 
3054     struct NCR53c7x0_hostdata *hostdata = 
 
3055         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
3056     u32 real;                   /* Real address */
 
3057     int size;                   /* Size of *tmp */
 
3058     struct NCR53c7x0_cmd *tmp;
 
3059     unsigned long flags;
 
3061     if (hostdata->options & OPTION_DEBUG_ALLOCATION)
 
3062         printk ("scsi%d : num_cmds = %d, can_queue = %d\n"
 
3063                 "         target = %d, lun = %d, %s\n",
 
3064             host->host_no, hostdata->num_cmds, host->can_queue,
 
3065             cmd->device->id, cmd->device->lun, (hostdata->cmd_allocated[cmd->device->id] &
 
3066                 (1 << cmd->device->lun)) ? "already allocated" : "not allocated");
 
3069  * If we have not yet reserved commands for this I_T_L nexus, and
 
3070  * the device exists (as indicated by permanent Scsi_Cmnd structures
 
3071  * being allocated under 1.3.x, or being outside of scan_scsis in
 
3072  * 1.2.x), do so now.
 
3074     if (!(hostdata->cmd_allocated[cmd->device->id] & (1 << cmd->device->lun)) &&
 
3075                                 cmd->device && cmd->device->has_cmdblocks) {
 
3076       if ((hostdata->extra_allocate + hostdata->num_cmds) < host->can_queue)
 
3077           hostdata->extra_allocate += host->cmd_per_lun;
 
3078       hostdata->cmd_allocated[cmd->device->id] |= (1 << cmd->device->lun);
 
3081     for (; hostdata->extra_allocate > 0 ; --hostdata->extra_allocate, 
 
3082         ++hostdata->num_cmds) {
 
3083     /* historically, kmalloc has returned unaligned addresses; pad so we
 
3084        have enough room to ROUNDUP */
 
3085         size = hostdata->max_cmd_size + sizeof (void *);
 
3086 #ifdef FORCE_DSA_ALIGNMENT
 
3088          * 53c710 rev.0 doesn't have an add-with-carry instruction.
 
3089          * Ensure we allocate enough memory to force alignment.
 
3093 /* FIXME: for ISA bus '7xx chips, we need to or GFP_DMA in here */
 
3096             printk (KERN_ERR "53c7xx: allocate_cmd size > 4K\n");
 
3099         real = get_zeroed_page(GFP_ATOMIC);
 
3102         memset((void *)real, 0, 4096);
 
3103         cache_push(virt_to_phys((void *)real), 4096);
 
3104         cache_clear(virt_to_phys((void *)real), 4096);
 
3105         kernel_set_cachemode((void *)real, 4096, IOMAP_NOCACHE_SER);
 
3106         tmp = ROUNDUP(real, void *);
 
3107 #ifdef FORCE_DSA_ALIGNMENT
 
3109             if (((u32)tmp & 0xff) > CmdPageStart)
 
3110                 tmp = (struct NCR53c7x0_cmd *)((u32)tmp + 255);
 
3111             tmp = (struct NCR53c7x0_cmd *)(((u32)tmp & ~0xff) + CmdPageStart);
 
3113             printk ("scsi: size = %d, real = 0x%08x, tmp set to 0x%08x\n",
 
3114                         size, real, (u32)tmp);
 
3118         tmp->real = (void *)real;
 
3120         tmp->free = ((void (*)(void *, int)) my_free_page);
 
3121         local_irq_save(flags);
 
3122         tmp->next = hostdata->free;
 
3123         hostdata->free = tmp;
 
3124         local_irq_restore(flags);
 
3126     local_irq_save(flags);
 
3127     tmp = (struct NCR53c7x0_cmd *) hostdata->free;
 
3129         hostdata->free = tmp->next;
 
3131     local_irq_restore(flags);
 
3133         printk ("scsi%d : can't allocate command for target %d lun %d\n",
 
3134             host->host_no, cmd->device->id, cmd->device->lun);
 
3139  * Function static struct NCR53c7x0_cmd *create_cmd (Scsi_Cmnd *cmd) 
 
3142  * Purpose : allocate a NCR53c7x0_cmd structure, initialize it based on the 
 
3143  *      Scsi_Cmnd structure passed in cmd, including dsa and Linux field 
 
3144  *      initialization, and dsa code relocation.
 
3146  * Inputs : cmd - SCSI command
 
3148  * Returns : NCR53c7x0_cmd structure corresponding to cmd,
 
3151 static struct NCR53c7x0_cmd *
 
3152 create_cmd (Scsi_Cmnd *cmd) {
 
3153     NCR53c7x0_local_declare();
 
3154     struct Scsi_Host *host = cmd->device->host;
 
3155     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
3157     struct NCR53c7x0_cmd *tmp;  /* NCR53c7x0_cmd structure for this command */
 
3158     int datain,                 /* Number of instructions per phase */
 
3160     int data_transfer_instructions, /* Count of dynamic instructions */
 
3162     u32 *cmd_datain,            /* Address of datain/dataout code */
 
3163         *cmd_dataout;           /* Incremented as we assemble */
 
3165     unsigned char *msgptr;      /* Current byte in select message */
 
3166     int msglen;                 /* Length of whole select message */
 
3168     unsigned long flags;
 
3169     u32 exp_select_indirect;    /* Used in sanity check */
 
3170     NCR53c7x0_local_setup(cmd->device->host);
 
3172     if (!(tmp = allocate_cmd (cmd)))
 
3176      * Copy CDB and initialised result fields from Scsi_Cmnd to NCR53c7x0_cmd.
 
3177      * We do this because NCR53c7x0_cmd may have a special cache mode
 
3178      * selected to cope with lack of bus snooping, etc.
 
3181     memcpy(tmp->cmnd, cmd->cmnd, 12);
 
3182     tmp->result = cmd->result;
 
3185      * Decide whether we need to generate commands for DATA IN,
 
3186      * DATA OUT, neither, or both based on the SCSI command 
 
3189     switch (cmd->cmnd[0]) {
 
3190     /* These commands do DATA IN */
 
3197     case READ_BLOCK_LIMITS:
 
3199         datain = 2 * (cmd->use_sg ? cmd->use_sg : 1) + 3;
 
3202     /* These commands do DATA OUT */
 
3207         printk("scsi%d : command is ", host->host_no);
 
3208         __scsi_print_command(cmd->cmnd);
 
3211         printk ("scsi%d : %d scatter/gather segments\n", host->host_no,
 
3215         dataout = 2 * (cmd->use_sg ? cmd->use_sg : 1) + 3;
 
3217         hostdata->options |= OPTION_DEBUG_INTR;
 
3221      * These commands do no data transfer, we should force an
 
3222      * interrupt if a data phase is attempted on them.
 
3224     case TEST_UNIT_READY:
 
3225     case ALLOW_MEDIUM_REMOVAL:
 
3227         datain = dataout = 0;
 
3230      * We don't know about these commands, so generate code to handle
 
3231      * both DATA IN and DATA OUT phases.  More efficient to identify them
 
3232      * and add them to the above cases.
 
3235         printk("scsi%d : datain+dataout for command ", host->host_no);
 
3236         __scsi_print_command(cmd->cmnd);
 
3237         datain = dataout = 2 * (cmd->use_sg ? cmd->use_sg : 1) + 3;
 
3241      * New code : so that active pointers work correctly regardless
 
3242      *  of where the saved data pointer is at, we want to immediately
 
3243      *  enter the dynamic code after selection, and on a non-data
 
3244      *  phase perform a CALL to the non-data phase handler, with
 
3245      *  returns back to this address.
 
3247      *  If a phase mismatch is encountered in the middle of a 
 
3248      *  Block MOVE instruction, we want to _leave_ that instruction
 
3249      *  unchanged as the current case is, modify a temporary buffer,
 
3250      *  and point the active pointer (TEMP) at that.
 
3252      *  Furthermore, we want to implement a saved data pointer, 
 
3253      *  set by the SAVE_DATA_POINTERs message.
 
3255      *  So, the data transfer segments will change to 
 
3256      *          CALL data_transfer, WHEN NOT data phase
 
3257      *          MOVE x, x, WHEN data phase
 
3259      *          JUMP other_transfer
 
3262     data_transfer_instructions = datain + dataout;
 
3265      * When we perform a request sense, we overwrite various things,
 
3266      * including the data transfer code.  Make sure we have enough
 
3270     if (data_transfer_instructions < 2)
 
3271         data_transfer_instructions = 2;
 
3275      * The saved data pointer is set up so that a RESTORE POINTERS message 
 
3276      * will start the data transfer over at the beginning.
 
3279     tmp->saved_data_pointer = virt_to_bus (hostdata->script) + 
 
3280         hostdata->E_data_transfer;
 
3283      * Initialize Linux specific fields.
 
3289     tmp->dsa_next_addr = virt_to_bus(tmp->dsa) + hostdata->dsa_next - 
 
3290         hostdata->dsa_start;
 
3291     tmp->dsa_addr = virt_to_bus(tmp->dsa) - hostdata->dsa_start;
 
3294      * Calculate addresses of dynamic code to fill in DSA
 
3297     tmp->data_transfer_start = tmp->dsa + (hostdata->dsa_end - 
 
3298         hostdata->dsa_start) / sizeof(u32);
 
3299     tmp->data_transfer_end = tmp->data_transfer_start + 
 
3300         2 * data_transfer_instructions;
 
3302     cmd_datain = datain ? tmp->data_transfer_start : NULL;
 
3303     cmd_dataout = dataout ? (datain ? cmd_datain + 2 * datain : tmp->
 
3304         data_transfer_start) : NULL;
 
3307      * Fill in the NCR53c7x0_cmd structure as follows
 
3308      * dsa, with fixed up DSA code
 
3313     /* Copy template code into dsa and perform all necessary fixups */
 
3314     if (hostdata->dsa_fixup)
 
3315         hostdata->dsa_fixup(tmp);
 
3317     patch_dsa_32(tmp->dsa, dsa_next, 0, 0);
 
3319      * XXX is this giving 53c710 access to the Scsi_Cmnd in some way?
 
3320      * Do we need to change it for caching reasons?
 
3322     patch_dsa_32(tmp->dsa, dsa_cmnd, 0, virt_to_bus(cmd));
 
3324     if (hostdata->options & OPTION_DEBUG_SYNCHRONOUS) {
 
3326         exp_select_indirect = ((1 << cmd->device->id) << 16) |
 
3327                         (hostdata->sync[cmd->device->id].sxfer_sanity << 8);
 
3329         if (hostdata->sync[cmd->device->id].select_indirect !=
 
3330                                 exp_select_indirect) {
 
3331             printk ("scsi%d :  sanity check failed select_indirect=0x%x\n",
 
3332                 host->host_no, hostdata->sync[cmd->device->id].select_indirect);
 
3338     patch_dsa_32(tmp->dsa, dsa_select, 0,
 
3339                 hostdata->sync[cmd->device->id].select_indirect);
 
3342      * Right now, we'll do the WIDE and SYNCHRONOUS negotiations on
 
3343      * different commands; although it should be trivial to do them
 
3344      * both at the same time.
 
3346     if (hostdata->initiate_wdtr & (1 << cmd->device->id)) {
 
3347         memcpy ((void *) (tmp->select + 1), (void *) wdtr_message,
 
3348             sizeof(wdtr_message));
 
3349         patch_dsa_32(tmp->dsa, dsa_msgout, 0, 1 + sizeof(wdtr_message));
 
3350         local_irq_save(flags);
 
3351         hostdata->initiate_wdtr &= ~(1 << cmd->device->id);
 
3352         local_irq_restore(flags);
 
3353     } else if (hostdata->initiate_sdtr & (1 << cmd->device->id)) {
 
3354         memcpy ((void *) (tmp->select + 1), (void *) sdtr_message, 
 
3355             sizeof(sdtr_message));
 
3356         patch_dsa_32(tmp->dsa, dsa_msgout, 0, 1 + sizeof(sdtr_message));
 
3357         tmp->flags |= CMD_FLAG_SDTR;
 
3358         local_irq_save(flags);
 
3359         hostdata->initiate_sdtr &= ~(1 << cmd->device->id);
 
3360         local_irq_restore(flags);
 
3364     else if (!(hostdata->talked_to & (1 << cmd->device->id)) &&
 
3365                 !(hostdata->options & OPTION_NO_ASYNC)) {
 
3367         memcpy ((void *) (tmp->select + 1), (void *) async_message, 
 
3368             sizeof(async_message));
 
3369         patch_dsa_32(tmp->dsa, dsa_msgout, 0, 1 + sizeof(async_message));
 
3370         tmp->flags |= CMD_FLAG_SDTR;
 
3374         patch_dsa_32(tmp->dsa, dsa_msgout, 0, 1);
 
3376     hostdata->talked_to |= (1 << cmd->device->id);
 
3377     tmp->select[0] = (hostdata->options & OPTION_DISCONNECT) ? 
 
3378         IDENTIFY (1, cmd->device->lun) : IDENTIFY (0, cmd->device->lun);
 
3379     patch_dsa_32(tmp->dsa, dsa_msgout, 1, virt_to_bus(tmp->select));
 
3380     patch_dsa_32(tmp->dsa, dsa_cmdout, 0, cmd->cmd_len);
 
3381     patch_dsa_32(tmp->dsa, dsa_cmdout, 1, virt_to_bus(tmp->cmnd));
 
3382     patch_dsa_32(tmp->dsa, dsa_dataout, 0, cmd_dataout ? 
 
3383             virt_to_bus (cmd_dataout)
 
3384         : virt_to_bus (hostdata->script) + hostdata->E_other_transfer);
 
3385     patch_dsa_32(tmp->dsa, dsa_datain, 0, cmd_datain ? 
 
3386             virt_to_bus (cmd_datain) 
 
3387         : virt_to_bus (hostdata->script) + hostdata->E_other_transfer);
 
3389      * XXX - need to make endian aware, should use separate variables
 
3390      * for both status and message bytes.
 
3392     patch_dsa_32(tmp->dsa, dsa_msgin, 0, 1);
 
3394  * FIXME : these only works for little endian.  We probably want to 
 
3395  *      provide message and status fields in the NCR53c7x0_cmd 
 
3396  *      structure, and assign them to cmd->result when we're done.
 
3399     patch_dsa_32(tmp->dsa, dsa_msgin, 1, virt_to_bus(&tmp->result) + 2);
 
3400     patch_dsa_32(tmp->dsa, dsa_status, 0, 1);
 
3401     patch_dsa_32(tmp->dsa, dsa_status, 1, virt_to_bus(&tmp->result) + 3);
 
3403     patch_dsa_32(tmp->dsa, dsa_msgin, 1, virt_to_bus(&tmp->result) + 1);
 
3404     patch_dsa_32(tmp->dsa, dsa_status, 0, 1);
 
3405     patch_dsa_32(tmp->dsa, dsa_status, 1, virt_to_bus(&tmp->result));
 
3407     patch_dsa_32(tmp->dsa, dsa_msgout_other, 0, 1);
 
3408     patch_dsa_32(tmp->dsa, dsa_msgout_other, 1, 
 
3409         virt_to_bus(&(hostdata->NCR53c7xx_msg_nop)));
 
3412      * Generate code for zero or more of the DATA IN, DATA OUT phases 
 
3415      * CALL data_transfer, WHEN NOT phase
 
3416      * MOVE first buffer length, first buffer address, WHEN phase
 
3418      * MOVE last buffer length, last buffer address, WHEN phase
 
3419      * JUMP other_transfer
 
3423  * See if we're getting to data transfer by generating an unconditional 
 
3428         cmd_datain[0] = 0x98080000;
 
3429         cmd_datain[1] = 0x03ffd00d;
 
3435  * XXX - I'm undecided whether all of this nonsense is faster
 
3436  * in the long run, or whether I should just go and implement a loop
 
3437  * on the NCR chip using table indirect mode?
 
3439  * In any case, this is how it _must_ be done for 53c700/700-66 chips,
 
3440  * so this stays even when we come up with something better.
 
3442  * When we're limited to 1 simultaneous command, no overlapping processing,
 
3443  * we're seeing 630K/sec, with 7% CPU usage on a slow Syquest 45M
 
3446  * Not bad, not good. We'll see.
 
3449     tmp->bounce.len = 0;        /* Assume aligned buffer */
 
3451     for (i = 0; cmd->use_sg ? (i < cmd->use_sg) : !i; cmd_datain += 4, 
 
3452         cmd_dataout += 4, ++i) {
 
3453         u32 vbuf = cmd->use_sg
 
3454             ? (u32)page_address(((struct scatterlist *)cmd->buffer)[i].page)+
 
3455               ((struct scatterlist *)cmd->buffer)[i].offset
 
3456             : (u32)(cmd->request_buffer);
 
3457         u32 bbuf = virt_to_bus((void *)vbuf);
 
3458         u32 count = cmd->use_sg ?
 
3459             ((struct scatterlist *)cmd->buffer)[i].length :
 
3460             cmd->request_bufflen;
 
3463          * If we have buffers which are not aligned with 16 byte cache
 
3464          * lines, then we just hope nothing accesses the other parts of
 
3465          * those cache lines while the transfer is in progress.  That would
 
3466          * fill the cache, and subsequent reads of the dma data would pick
 
3467          * up the wrong thing.
 
3468          * XXX We need a bounce buffer to handle that correctly.
 
3471         if (((bbuf & 15) || (count & 15)) && (datain || dataout))
 
3473             /* Bounce buffer needed */
 
3475                 printk ("53c7xx: Non-aligned buffer with use_sg\n");
 
3476             else if (datain && dataout)
 
3477                 printk ("53c7xx: Non-aligned buffer with datain && dataout\n");
 
3478             else if (count > 256)
 
3479                 printk ("53c7xx: Non-aligned transfer > 256 bytes\n");
 
3484                         tmp->bounce.len = count;
 
3485                         tmp->bounce.addr = vbuf;
 
3486                         bbuf = virt_to_bus(tmp->bounce.buf);
 
3487                         tmp->bounce.buf[0] = 0xff;
 
3488                         tmp->bounce.buf[1] = 0xfe;
 
3489                         tmp->bounce.buf[2] = 0xfd;
 
3490                         tmp->bounce.buf[3] = 0xfc;
 
3494                         memcpy ((void *)tmp->bounce.buf, (void *)vbuf, count);
 
3495                         bbuf = virt_to_bus(tmp->bounce.buf);
 
3501             cache_clear(virt_to_phys((void *)vbuf), count);
 
3502             /* CALL other_in, WHEN NOT DATA_IN */  
 
3503             cmd_datain[0] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_CALL | 
 
3504                 DCMD_TCI_IO) << 24) | 
 
3505                 DBC_TCI_WAIT_FOR_VALID | DBC_TCI_COMPARE_PHASE;
 
3506             cmd_datain[1] = virt_to_bus (hostdata->script) + 
 
3507                 hostdata->E_other_in;
 
3508             /* MOVE count, buf, WHEN DATA_IN */
 
3509             cmd_datain[2] = ((DCMD_TYPE_BMI | DCMD_BMI_OP_MOVE_I | DCMD_BMI_IO) 
 
3511             cmd_datain[3] = bbuf;
 
3513             print_insn (host, cmd_datain, "dynamic ", 1);
 
3514             print_insn (host, cmd_datain + 2, "dynamic ", 1);
 
3518             cache_push(virt_to_phys((void *)vbuf), count);
 
3519             /* CALL other_out, WHEN NOT DATA_OUT */
 
3520             cmd_dataout[0] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_CALL) << 24) | 
 
3521                 DBC_TCI_WAIT_FOR_VALID | DBC_TCI_COMPARE_PHASE;
 
3522             cmd_dataout[1] = virt_to_bus(hostdata->script) + 
 
3523                 hostdata->E_other_out;
 
3524             /* MOVE count, buf, WHEN DATA+OUT */
 
3525             cmd_dataout[2] = ((DCMD_TYPE_BMI | DCMD_BMI_OP_MOVE_I) << 24) 
 
3527             cmd_dataout[3] = bbuf;
 
3529             print_insn (host, cmd_dataout, "dynamic ", 1);
 
3530             print_insn (host, cmd_dataout + 2, "dynamic ", 1);
 
3536      * Install JUMP instructions after the data transfer routines to return
 
3537      * control to the do_other_transfer routines.
 
3542         cmd_datain[0] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_JUMP) << 24) |
 
3544         cmd_datain[1] = virt_to_bus(hostdata->script) + 
 
3545             hostdata->E_other_transfer;
 
3547         print_insn (host, cmd_datain, "dynamic jump ", 1);
 
3553         cmd_datain[0] = 0x98080000;
 
3554         cmd_datain[1] = 0x03ffdeed;
 
3559         cmd_dataout[0] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_JUMP) << 24) |
 
3561         cmd_dataout[1] = virt_to_bus(hostdata->script) + 
 
3562             hostdata->E_other_transfer;
 
3564         print_insn (host, cmd_dataout, "dynamic jump ", 1);
 
3573  * Function : int NCR53c7xx_queue_command (Scsi_Cmnd *cmd,
 
3574  *      void (*done)(Scsi_Cmnd *))
 
3576  * Purpose :  enqueues a SCSI command
 
3578  * Inputs : cmd - SCSI command, done - function called on completion, with
 
3579  *      a pointer to the command descriptor.
 
3584  *      cmd is added to the per instance driver issue_queue, with major
 
3585  *      twiddling done to the host specific fields of cmd.  If the
 
3586  *      process_issue_queue coroutine isn't running, it is restarted.
 
3588  * NOTE : we use the host_scribble field of the Scsi_Cmnd structure to 
 
3589  *      hold our own data, and pervert the ptr field of the SCp field
 
3590  *      to create a linked list.
 
3594 NCR53c7xx_queue_command (Scsi_Cmnd *cmd, void (* done)(Scsi_Cmnd *)) {
 
3595     struct Scsi_Host *host = cmd->device->host;
 
3596     struct NCR53c7x0_hostdata *hostdata = 
 
3597         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
3598     unsigned long flags;
 
3601     cmd->scsi_done = done;
 
3602     cmd->host_scribble = NULL;
 
3603     cmd->SCp.ptr = NULL;
 
3604     cmd->SCp.buffer = NULL;
 
3607     /* Ignore commands on invalid IDs */
 
3608     if (!hostdata->valid_ids[cmd->device->id]) {
 
3609         printk("scsi%d : ignoring target %d lun %d\n", host->host_no,
 
3610             cmd->device->id, cmd->device->lun);
 
3611         cmd->result = (DID_BAD_TARGET << 16);
 
3617     local_irq_save(flags);
 
3618     if ((hostdata->options & (OPTION_DEBUG_INIT_ONLY|OPTION_DEBUG_PROBE_ONLY)) 
 
3619         || ((hostdata->options & OPTION_DEBUG_TARGET_LIMIT) &&
 
3620             !(hostdata->debug_lun_limit[cmd->device->id] & (1 << cmd->device->lun)))
 
3622         || cmd->device->id > 7
 
3624         || cmd->device->id > host->max_id
 
3626         || cmd->device->id == host->this_id
 
3627         || hostdata->state == STATE_DISABLED) {
 
3628         printk("scsi%d : disabled or bad target %d lun %d\n", host->host_no,
 
3629             cmd->device->id, cmd->device->lun);
 
3630         cmd->result = (DID_BAD_TARGET << 16);
 
3632         local_irq_restore(flags);
 
3636     if ((hostdata->options & OPTION_DEBUG_NCOMMANDS_LIMIT) &&
 
3637         (hostdata->debug_count_limit == 0)) {
 
3638         printk("scsi%d : maximum commands exceeded\n", host->host_no);
 
3639         cmd->result = (DID_BAD_TARGET << 16);
 
3641         local_irq_restore(flags);
 
3645     if (hostdata->options & OPTION_DEBUG_READ_ONLY) {
 
3646         switch (cmd->cmnd[0]) {
 
3649             printk("scsi%d : WRITE attempted with NO_WRITE debugging flag set\n",
 
3651             cmd->result = (DID_BAD_TARGET << 16);
 
3653             local_irq_restore(flags);
 
3658     if ((hostdata->options & OPTION_DEBUG_TARGET_LIMIT) &&
 
3659             hostdata->debug_count_limit != -1) 
 
3660         --hostdata->debug_count_limit;
 
3662     cmd->result = 0xffff;       /* The NCR will overwrite message
 
3663                                        and status with valid data */
 
3664     cmd->host_scribble = (unsigned char *) tmp = create_cmd (cmd);
 
3667      * REQUEST SENSE commands are inserted at the head of the queue 
 
3668      * so that we do not clear the contingent allegiance condition
 
3669      * they may be looking at.
 
3672     if (!(hostdata->issue_queue) || (cmd->cmnd[0] == REQUEST_SENSE)) {
 
3673         cmd->SCp.ptr = (unsigned char *) hostdata->issue_queue;
 
3674         hostdata->issue_queue = cmd;
 
3676         for (tmp = (Scsi_Cmnd *) hostdata->issue_queue; tmp->SCp.ptr; 
 
3677                 tmp = (Scsi_Cmnd *) tmp->SCp.ptr);
 
3678         tmp->SCp.ptr = (unsigned char *) cmd;
 
3680     local_irq_restore(flags);
 
3681     run_process_issue_queue();
 
3686  * Function : void to_schedule_list (struct Scsi_Host *host,
 
3687  *      struct NCR53c7x0_hostdata * hostdata, Scsi_Cmnd *cmd)
 
3689  * Purpose : takes a SCSI command which was just removed from the 
 
3690  *      issue queue, and deals with it by inserting it in the first
 
3691  *      free slot in the schedule list or by terminating it immediately.
 
3694  *      host - SCSI host adapter; hostdata - hostdata structure for 
 
3695  *      this adapter; cmd - a pointer to the command; should have 
 
3696  *      the host_scribble field initialized to point to a valid 
 
3699  *      cmd is added to the per instance schedule list, with minor 
 
3700  *      twiddling done to the host specific fields of cmd.
 
3704 static __inline__ void
 
3705 to_schedule_list (struct Scsi_Host *host, struct NCR53c7x0_hostdata *hostdata,
 
3706     struct NCR53c7x0_cmd *cmd) {
 
3707     NCR53c7x0_local_declare();
 
3708     Scsi_Cmnd *tmp = cmd->cmd;
 
3709     unsigned long flags;
 
3710     /* dsa start is negative, so subtraction is used */
 
3711     volatile u32 *ncrcurrent;
 
3714     NCR53c7x0_local_setup(host);
 
3716     printk("scsi%d : new dsa is 0x%lx (virt 0x%p)\n", host->host_no, 
 
3717         virt_to_bus(hostdata->dsa), hostdata->dsa);
 
3720     local_irq_save(flags);
 
3723      * Work around race condition : if an interrupt fired and we 
 
3724      * got disabled forget about this command.
 
3727     if (hostdata->state == STATE_DISABLED) {
 
3728         printk("scsi%d : driver disabled\n", host->host_no);
 
3729         tmp->result = (DID_BAD_TARGET << 16);
 
3730         cmd->next = (struct NCR53c7x0_cmd *) hostdata->free;
 
3731         hostdata->free = cmd;
 
3732         tmp->scsi_done(tmp);
 
3733         local_irq_restore(flags);
 
3737     for (i = host->can_queue, ncrcurrent = hostdata->schedule; 
 
3738         i > 0  && ncrcurrent[0] != hostdata->NOP_insn;
 
3739         --i, ncrcurrent += 2 /* JUMP instructions are two words */);
 
3742         ++hostdata->busy[tmp->device->id][tmp->device->lun];
 
3743         cmd->next = hostdata->running_list;
 
3744         hostdata->running_list = cmd;
 
3746         /* Restore this instruction to a NOP once the command starts */
 
3747         cmd->dsa [(hostdata->dsa_jump_dest - hostdata->dsa_start) / 
 
3748             sizeof(u32)] = (u32) virt_to_bus ((void *)ncrcurrent);
 
3749         /* Replace the current jump operand.  */
 
3751             virt_to_bus ((void *) cmd->dsa) + hostdata->E_dsa_code_begin -
 
3752             hostdata->E_dsa_code_template;
 
3753         /* Replace the NOP instruction with a JUMP */
 
3754         ncrcurrent[0] = ((DCMD_TYPE_TCI|DCMD_TCI_OP_JUMP) << 24) |
 
3757         printk ("scsi%d: no free slot\n", host->host_no);
 
3759         tmp->result = (DID_ERROR << 16);
 
3760         cmd->next = (struct NCR53c7x0_cmd *) hostdata->free;
 
3761         hostdata->free = cmd;
 
3762         tmp->scsi_done(tmp);
 
3763         local_irq_restore(flags);
 
3768      * If the NCR chip is in an idle state, start it running the scheduler
 
3769      * immediately.  Otherwise, signal the chip to jump to schedule as 
 
3770      * soon as it is idle.
 
3773     if (hostdata->idle) {
 
3775         hostdata->state = STATE_RUNNING;
 
3776         NCR53c7x0_write32 (DSP_REG,  virt_to_bus ((void *)hostdata->schedule));
 
3777         if (hostdata->options & OPTION_DEBUG_TRACE)
 
3778             NCR53c7x0_write8 (DCNTL_REG, hostdata->saved_dcntl |
 
3779                                 DCNTL_SSM | DCNTL_STD);
 
3781         NCR53c7x0_write8(hostdata->istat, ISTAT_10_SIGP);
 
3784     local_irq_restore(flags);
 
3788  * Function : busyp (struct Scsi_Host *host, struct NCR53c7x0_hostdata 
 
3789  *      *hostdata, Scsi_Cmnd *cmd)
 
3791  * Purpose : decide if we can pass the given SCSI command on to the 
 
3792  *      device in question or not.
 
3794  * Returns : non-zero when we're busy, 0 when we aren't.
 
3797 static __inline__ int
 
3798 busyp (struct Scsi_Host *host, struct NCR53c7x0_hostdata *hostdata, 
 
3800     /* FIXME : in the future, this needs to accommodate SCSI-II tagged
 
3801        queuing, and we may be able to play with fairness here a bit.
 
3803     return hostdata->busy[cmd->device->id][cmd->device->lun];
 
3807  * Function : process_issue_queue (void)
 
3809  * Purpose : transfer commands from the issue queue to NCR start queue 
 
3810  *      of each NCR53c7/8xx in the system, avoiding kernel stack 
 
3811  *      overflows when the scsi_done() function is invoked recursively.
 
3813  * NOTE : process_issue_queue exits with interrupts *disabled*, so the 
 
3814  *      caller must reenable them if it desires.
 
3816  * NOTE : process_issue_queue should be called from both 
 
3817  *      NCR53c7x0_queue_command() and from the interrupt handler 
 
3818  *      after command completion in case NCR53c7x0_queue_command()
 
3819  *      isn't invoked again but we've freed up resources that are
 
3824 process_issue_queue (unsigned long flags) {
 
3825     Scsi_Cmnd *tmp, *prev;
 
3826     struct Scsi_Host *host;
 
3827     struct NCR53c7x0_hostdata *hostdata;
 
3831      * We run (with interrupts disabled) until we're sure that none of 
 
3832      * the host adapters have anything that can be done, at which point 
 
3833      * we set process_issue_queue_running to 0 and exit.
 
3835      * Interrupts are enabled before doing various other internal 
 
3836      * instructions, after we've decided that we need to run through
 
3842         local_irq_disable(); /* Freeze request queues */
 
3844         for (host = first_host; host && host->hostt == the_template;
 
3845             host = host->next) {
 
3846             hostdata = (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
3847             local_irq_disable();
 
3848             if (hostdata->issue_queue) {
 
3849                 if (hostdata->state == STATE_DISABLED) {
 
3850                     tmp = (Scsi_Cmnd *) hostdata->issue_queue;
 
3851                     hostdata->issue_queue = (Scsi_Cmnd *) tmp->SCp.ptr;
 
3852                     tmp->result = (DID_BAD_TARGET << 16);
 
3853                     if (tmp->host_scribble) {
 
3854                         ((struct NCR53c7x0_cmd *)tmp->host_scribble)->next = 
 
3857                             (struct NCR53c7x0_cmd *)tmp->host_scribble;
 
3858                         tmp->host_scribble = NULL;
 
3860                     tmp->scsi_done (tmp);
 
3863                     for (tmp = (Scsi_Cmnd *) hostdata->issue_queue, 
 
3864                         prev = NULL; tmp; prev = tmp, tmp = (Scsi_Cmnd *) 
 
3866                         if (!tmp->host_scribble || 
 
3867                             !busyp (host, hostdata, tmp)) {
 
3869                                     prev->SCp.ptr = tmp->SCp.ptr;
 
3871                                     hostdata->issue_queue = (Scsi_Cmnd *) 
 
3873                             tmp->SCp.ptr = NULL;
 
3874                             if (tmp->host_scribble) {
 
3875                                 if (hostdata->options & OPTION_DEBUG_QUEUES) 
 
3876                                     printk ("scsi%d : moving command for target %d lun %d to start list\n",
 
3877                                         host->host_no, tmp->device->id, tmp->device->lun);
 
3880                                 to_schedule_list (host, hostdata, 
 
3881                                     (struct NCR53c7x0_cmd *)
 
3882                                     tmp->host_scribble);
 
3884                                 if (((tmp->result & 0xff) == 0xff) ||
 
3885                                     ((tmp->result & 0xff00) == 0xff00)) {
 
3886                                     printk ("scsi%d : danger Will Robinson!\n",
 
3888                                     tmp->result = DID_ERROR << 16;
 
3891                                 tmp->scsi_done(tmp);
 
3894                         } /* if target/lun is not busy */
 
3895             } /* if hostdata->issue_queue */
 
3897                 local_irq_restore(flags);
 
3900     process_issue_queue_running = 0;
 
3904  * Function : static void intr_scsi (struct Scsi_Host *host, 
 
3905  *      struct NCR53c7x0_cmd *cmd)
 
3907  * Purpose : handle all SCSI interrupts, indicated by the setting 
 
3908  *      of the SIP bit in the ISTAT register.
 
3910  * Inputs : host, cmd - host and NCR command causing the interrupt, cmd
 
3915 intr_scsi (struct Scsi_Host *host, struct NCR53c7x0_cmd *cmd) {
 
3916     NCR53c7x0_local_declare();
 
3917     struct NCR53c7x0_hostdata *hostdata = 
 
3918         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
3919     unsigned char sstat0_sist0, sist1,          /* Registers */
 
3920             fatal;                              /* Did a fatal interrupt 
 
3923     NCR53c7x0_local_setup(host);
 
3927     sstat0_sist0 = NCR53c7x0_read8(SSTAT0_REG);
 
3930     if (hostdata->options & OPTION_DEBUG_INTR) 
 
3931         printk ("scsi%d : SIST0 0x%0x, SIST1 0x%0x\n", host->host_no,
 
3932             sstat0_sist0, sist1);
 
3934     /* 250ms selection timeout */
 
3935     if (sstat0_sist0 & SSTAT0_700_STO) {
 
3937         if (hostdata->options & OPTION_DEBUG_INTR) {
 
3938             printk ("scsi%d : Selection Timeout\n", host->host_no);
 
3940                 printk("scsi%d : target %d, lun %d, command ",
 
3941                     host->host_no, cmd->cmd->device->id, cmd->cmd->device->lun);
 
3942                 __scsi_print_command (cmd->cmd->cmnd);
 
3943                 printk("scsi%d : dsp = 0x%x (virt 0x%p)\n", host->host_no,
 
3944                     NCR53c7x0_read32(DSP_REG),
 
3945                     bus_to_virt(NCR53c7x0_read32(DSP_REG)));
 
3947                 printk("scsi%d : no command\n", host->host_no);
 
3951  * XXX - question : how do we want to handle the Illegal Instruction
 
3952  *      interrupt, which may occur before or after the Selection Timeout
 
3958             hostdata->expecting_sto = 0;
 
3960             if (hostdata->test_running) {
 
3961                 hostdata->test_running = 0;
 
3962                 hostdata->test_completed = 3;
 
3964                 abnormal_finished(cmd, DID_BAD_TARGET << 16);
 
3967             hostdata->intrs = 0;
 
3973  * FIXME : in theory, we can also get a UDC when a STO occurs.
 
3975     if (sstat0_sist0 & SSTAT0_UDC) {
 
3978             printk("scsi%d : target %d lun %d unexpected disconnect\n",
 
3979                 host->host_no, cmd->cmd->device->id, cmd->cmd->device->lun);
 
3981             abnormal_finished(cmd, DID_ERROR << 16);
 
3983              printk("scsi%d : unexpected disconnect (no command)\n",
 
3986         hostdata->dsp = (u32 *) hostdata->schedule;
 
3987         hostdata->dsp_changed = 1;
 
3990     /* SCSI PARITY error */
 
3991     if (sstat0_sist0 & SSTAT0_PAR) {
 
3993         if (cmd && cmd->cmd) {
 
3994             printk("scsi%d : target %d lun %d parity error.\n",
 
3995                 host->host_no, cmd->cmd->device->id, cmd->cmd->device->lun);
 
3996             abnormal_finished (cmd, DID_PARITY << 16); 
 
3998             printk("scsi%d : parity error\n", host->host_no);
 
3999         /* Should send message out, parity error */
 
4001         /* XXX - Reduce synchronous transfer rate! */
 
4002         hostdata->dsp = hostdata->script + hostdata->E_initiator_abort /
 
4004         hostdata->dsp_changed = 1; 
 
4005     /* SCSI GROSS error */
 
4008     if (sstat0_sist0 & SSTAT0_SGE) {
 
4010         printk("scsi%d : gross error, saved2_dsa = 0x%x\n", host->host_no,
 
4011                                         (unsigned int)hostdata->saved2_dsa);
 
4015          * A SCSI gross error may occur when we have 
 
4017          * - A synchronous offset which causes the SCSI FIFO to be overwritten.
 
4019          * - A REQ which causes the maximum synchronous offset programmed in 
 
4020          *      the SXFER register to be exceeded.
 
4022          * - A phase change with an outstanding synchronous offset.
 
4024          * - Residual data in the synchronous data FIFO, with a transfer
 
4025          *      other than a synchronous receive is started.$#
 
4029         /* XXX Should deduce synchronous transfer rate! */
 
4030         hostdata->dsp = hostdata->script + hostdata->E_initiator_abort /
 
4032         hostdata->dsp_changed = 1;
 
4033     /* Phase mismatch */
 
4036     if (sstat0_sist0 & SSTAT0_MA) {
 
4038         if (hostdata->options & OPTION_DEBUG_INTR)
 
4039             printk ("scsi%d : SSTAT0_MA\n", host->host_no);
 
4040         intr_phase_mismatch (host, cmd);
 
4044     if (sstat0_sist0 & SIST0_800_RSL) 
 
4045         printk ("scsi%d : Oh no Mr. Bill!\n", host->host_no);
 
4049  * If a fatal SCSI interrupt occurs, we must insure that the DMA and
 
4050  * SCSI FIFOs were flushed.
 
4054         if (!hostdata->dstat_valid) {
 
4055             hostdata->dstat = NCR53c7x0_read8(DSTAT_REG);
 
4056             hostdata->dstat_valid = 1;
 
4059         if (!(hostdata->dstat & DSTAT_DFE)) {
 
4060           printk ("scsi%d : DMA FIFO not empty\n", host->host_no);
 
4062            * Really need to check this code for 710  RGH.
 
4063            * Havn't seen any problems, but maybe we should FLUSH before
 
4064            * clearing sometimes.
 
4066           NCR53c7x0_write8 (CTEST8_REG, CTEST8_10_CLF);
 
4067           while (NCR53c7x0_read8 (CTEST8_REG) & CTEST8_10_CLF)
 
4069           hostdata->dstat |= DSTAT_DFE;
 
4077  * The following implements a cyclic log of instructions executed, if you turn
 
4078  * TRACE on.  It will also print the log for you.  Very useful when debugging
 
4079  * 53c710 support, possibly not really needed any more.
 
4083 u32 insn_log_index = 0;
 
4087         insn_log[insn_log_index++] = i;
 
4088         if (insn_log_index == 4096)
 
4092 void log_insn (u32 *ip)
 
4097         if (((*ip >> 24) & DCMD_TYPE_MASK) == DCMD_TYPE_MMI)
 
4104         int i = insn_log_index;
 
4106         struct Scsi_Host *host = first_host;
 
4108         while (cnt < 4096) {
 
4109                 printk ("%08x (+%6x): ", insn_log[i], (insn_log[i] - (u32)&(((struct NCR53c7x0_hostdata *)host->hostdata[0])->script))/4);
 
4113                 if (((insn_log[i]  >> 24) & DCMD_TYPE_MASK) == DCMD_TYPE_MMI) 
 
4118                         printk ("%08x ", insn_log[i]);
 
4130  * Function : static void NCR53c7x0_intfly (struct Scsi_Host *host)
 
4132  * Purpose : Scan command queue for specified host, looking for completed
 
4135  * Inputs : Scsi_Host pointer.
 
4137  *      This is called from the interrupt handler, when a simulated INTFLY
 
4142 NCR53c7x0_intfly (struct Scsi_Host *host)
 
4144     NCR53c7x0_local_declare();
 
4145     struct NCR53c7x0_hostdata *hostdata;        /* host->hostdata[0] */
 
4146     struct NCR53c7x0_cmd *cmd,                  /* command which halted */
 
4148     unsigned long flags;                                
 
4149     char search_found = 0;                      /* Got at least one ? */
 
4151     hostdata = (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
4152     NCR53c7x0_local_setup(host);
 
4154     if (hostdata->options & OPTION_DEBUG_INTR)
 
4155     printk ("scsi%d : INTFLY\n", host->host_no); 
 
4158     * Traverse our list of running commands, and look
 
4159     * for those with valid (non-0xff ff) status and message
 
4160     * bytes encoded in the result which signify command
 
4164     local_irq_save(flags);
 
4166     for (cmd_prev_ptr = (struct NCR53c7x0_cmd **)&(hostdata->running_list),
 
4167         cmd = (struct NCR53c7x0_cmd *) hostdata->running_list; cmd ;
 
4168         cmd_prev_ptr = (struct NCR53c7x0_cmd **) &(cmd->next), 
 
4169         cmd = (struct NCR53c7x0_cmd *) cmd->next)
 
4174             printk("scsi%d : very weird.\n", host->host_no);
 
4178         if (!(tmp = cmd->cmd)) {
 
4179             printk("scsi%d : weird.  NCR53c7x0_cmd has no Scsi_Cmnd\n",
 
4183         /* Copy the result over now; may not be complete,
 
4184          * but subsequent tests may as well be done on
 
4187         tmp->result = cmd->result;
 
4189         if (((tmp->result & 0xff) == 0xff) ||
 
4190                             ((tmp->result & 0xff00) == 0xff00))
 
4195         if (cmd->bounce.len)
 
4196             memcpy ((void *)cmd->bounce.addr,
 
4197                                 (void *)cmd->bounce.buf, cmd->bounce.len);
 
4199         /* Important - remove from list _before_ done is called */
 
4201             *cmd_prev_ptr = (struct NCR53c7x0_cmd *) cmd->next;
 
4203         --hostdata->busy[tmp->device->id][tmp->device->lun];
 
4204         cmd->next = hostdata->free;
 
4205         hostdata->free = cmd;
 
4207         tmp->host_scribble = NULL;
 
4209         if (hostdata->options & OPTION_DEBUG_INTR) {
 
4210             printk ("scsi%d : command complete : pid %lu, id %d,lun %d result 0x%x ", 
 
4211                   host->host_no, tmp->pid, tmp->device->id, tmp->device->lun, tmp->result);
 
4212             __scsi_print_command (tmp->cmnd);
 
4215         tmp->scsi_done(tmp);
 
4218     local_irq_restore(flags);
 
4220     if (!search_found)  {
 
4221         printk ("scsi%d : WARNING : INTFLY with no completed commands.\n",
 
4224         run_process_issue_queue();
 
4230  * Function : static irqreturn_t NCR53c7x0_intr (int irq, void *dev_id, struct pt_regs * regs)
 
4232  * Purpose : handle NCR53c7x0 interrupts for all NCR devices sharing
 
4233  *      the same IRQ line.  
 
4235  * Inputs : Since we're using the SA_INTERRUPT interrupt handler
 
4236  *      semantics, irq indicates the interrupt which invoked 
 
4239  * On the 710 we simualte an INTFLY with a script interrupt, and the
 
4240  * script interrupt handler will call back to this function.
 
4244 NCR53c7x0_intr (int irq, void *dev_id, struct pt_regs * regs)
 
4246     NCR53c7x0_local_declare();
 
4247     struct Scsi_Host *host;                     /* Host we are looking at */
 
4248     unsigned char istat;                        /* Values of interrupt regs */
 
4249     struct NCR53c7x0_hostdata *hostdata;        /* host->hostdata[0] */
 
4250     struct NCR53c7x0_cmd *cmd;                  /* command which halted */
 
4255     char buf[80];                               /* Debugging sprintf buffer */
 
4256     size_t buflen;                              /* Length of same */
 
4259     host     = (struct Scsi_Host *)dev_id;
 
4260     hostdata = (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
4261     NCR53c7x0_local_setup(host);
 
4264      * Only read istat once per loop, since reading it again will unstack
 
4268     while ((istat = NCR53c7x0_read8(hostdata->istat)) & (ISTAT_SIP|ISTAT_DIP)) {
 
4270         hostdata->dsp_changed = 0;
 
4271         hostdata->dstat_valid = 0;
 
4272         hostdata->state = STATE_HALTED;
 
4274         if (NCR53c7x0_read8 (SSTAT2_REG) & SSTAT2_FF_MASK) 
 
4275             printk ("scsi%d : SCSI FIFO not empty\n", host->host_no);
 
4278          * NCR53c700 and NCR53c700-66 change the current SCSI
 
4279          * process, hostdata->ncrcurrent, in the Linux driver so
 
4280          * cmd = hostdata->ncrcurrent.
 
4282          * With other chips, we must look through the commands
 
4283          * executing and find the command structure which 
 
4284          * corresponds to the DSA register.
 
4287         if (hostdata->options & OPTION_700) {
 
4288             cmd = (struct NCR53c7x0_cmd *) hostdata->ncrcurrent;
 
4290             dsa = bus_to_virt(NCR53c7x0_read32(DSA_REG));
 
4291             for (cmd = (struct NCR53c7x0_cmd *) hostdata->running_list;
 
4292                 cmd && (dsa + (hostdata->dsa_start / sizeof(u32))) != cmd->dsa;
 
4293                     cmd = (struct NCR53c7x0_cmd *)(cmd->next))
 
4296         if (hostdata->options & OPTION_DEBUG_INTR) {
 
4298                 printk("scsi%d : interrupt for pid %lu, id %d, lun %d ", 
 
4299                     host->host_no, cmd->cmd->pid, (int) cmd->cmd->device->id,
 
4300                     (int) cmd->cmd->device->lun);
 
4301                 __scsi_print_command (cmd->cmd->cmnd);
 
4303                 printk("scsi%d : no active command\n", host->host_no);
 
4307         if (istat & ISTAT_SIP) {
 
4308             if (hostdata->options & OPTION_DEBUG_INTR) 
 
4309                 printk ("scsi%d : ISTAT_SIP\n", host->host_no);
 
4310             intr_scsi (host, cmd);
 
4313         if (istat & ISTAT_DIP) {
 
4314             if (hostdata->options & OPTION_DEBUG_INTR) 
 
4315                 printk ("scsi%d : ISTAT_DIP\n", host->host_no);
 
4316             intr_dma (host, cmd);
 
4319         if (!hostdata->dstat_valid) {
 
4320             hostdata->dstat = NCR53c7x0_read8(DSTAT_REG);
 
4321             hostdata->dstat_valid = 1;
 
4324         if (!(hostdata->dstat & DSTAT_DFE)) {
 
4325             printk ("scsi%d : DMA FIFO not empty\n", host->host_no);
 
4326             /* Really need to check this out for 710 RGH */
 
4327             NCR53c7x0_write8 (CTEST8_REG, CTEST8_10_CLF);
 
4328             while (NCR53c7x0_read8 (CTEST8_REG) & CTEST8_10_CLF)
 
4330             hostdata->dstat |= DSTAT_DFE;
 
4333         if (!hostdata->idle && hostdata->state == STATE_HALTED) {
 
4334             if (!hostdata->dsp_changed)
 
4335                 hostdata->dsp = (u32 *)bus_to_virt(NCR53c7x0_read32(DSP_REG));
 
4337             printk("scsi%d : new dsp is 0x%lx (virt 0x%p)\n",
 
4338                 host->host_no,  virt_to_bus(hostdata->dsp), hostdata->dsp);
 
4341             hostdata->state = STATE_RUNNING;
 
4342             NCR53c7x0_write32 (DSP_REG, virt_to_bus(hostdata->dsp));
 
4343             if (hostdata->options & OPTION_DEBUG_TRACE) {
 
4345                 log_insn (hostdata->dsp);
 
4347                 print_insn (host, hostdata->dsp, "t ", 1);
 
4349                 NCR53c7x0_write8 (DCNTL_REG,
 
4350                         hostdata->saved_dcntl | DCNTL_SSM | DCNTL_STD);
 
4359  * Function : static int abort_connected (struct Scsi_Host *host)
 
4361  * Purpose : Assuming that the NCR SCSI processor is currently 
 
4362  *      halted, break the currently established nexus.  Clean
 
4363  *      up of the NCR53c7x0_cmd and Scsi_Cmnd structures should
 
4364  *      be done on receipt of the abort interrupt.
 
4366  * Inputs : host - SCSI host
 
4371 abort_connected (struct Scsi_Host *host) {
 
4373     NCR53c7x0_local_declare();
 
4375     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
4377 /* FIXME : this probably should change for production kernels; at the 
 
4378    least, counter should move to a per-host structure. */
 
4379     static int counter = 5;
 
4381     int sstat, phase, offset;
 
4383     NCR53c7x0_local_setup(host);
 
4386     if (--counter <= 0) {
 
4391     printk ("scsi%d : DANGER : abort_connected() called \n",
 
4397  * New strategy : Rather than using a generic abort routine,
 
4398  * we'll specifically try to source or sink the appropriate
 
4399  * amount of data for the phase we're currently in (taking into 
 
4400  * account the current synchronous offset) 
 
4403     sstat = (NCR53c8x0_read8 (SSTAT2_REG);
 
4404     offset = OFFSET (sstat & SSTAT2_FF_MASK) >> SSTAT2_FF_SHIFT;
 
4405     phase = sstat & SSTAT2_PHASE_MASK;
 
4409  * MOVE source_or_sink, WHEN CURRENT PHASE 
 
4410  * < repeat for each outstanding byte >
 
4411  * JUMP send_abort_message
 
4414     script = hostdata->abort_script = kmalloc (
 
4415         8  /* instruction size */ * (
 
4417             (!offset ? 1 : offset) /* One transfer per outstanding byte */ +
 
4418             1 /* send abort message */),
 
4422 #else /* def NEW_ABORT */
 
4423     hostdata->dsp = hostdata->script + hostdata->E_initiator_abort /
 
4425 #endif /* def NEW_ABORT */
 
4426     hostdata->dsp_changed = 1;
 
4428 /* XXX - need to flag the command as aborted after the abort_connected
 
4435  * Function : static int datapath_residual (Scsi_Host *host)
 
4437  * Purpose : return residual data count of what's in the chip.
 
4439  * Inputs : host - SCSI host
 
4443 datapath_residual (struct Scsi_Host *host) {
 
4444     NCR53c7x0_local_declare();
 
4445     int count, synchronous, sstat;
 
4448     NCR53c7x0_local_setup(host);
 
4449     /* COMPAT : the 700 and 700-66 need to use DFIFO_00_BO_MASK */
 
4450     count = ((NCR53c7x0_read8 (DFIFO_REG) & DFIFO_10_BO_MASK) -
 
4451         (NCR53c7x0_read32 (DBC_REG) & DFIFO_10_BO_MASK)) & DFIFO_10_BO_MASK;
 
4452     synchronous = NCR53c7x0_read8 (SXFER_REG) & SXFER_MO_MASK;
 
4453     /* COMPAT : DDIR is elsewhere on non-'8xx chips. */
 
4454     ddir = NCR53c7x0_read8 (CTEST0_REG_700) & CTEST0_700_DDIR;
 
4459             count += (NCR53c7x0_read8 (SSTAT2_REG) & SSTAT2_FF_MASK) >> SSTAT2_FF_SHIFT;
 
4461             if (NCR53c7x0_read8 (SSTAT1_REG) & SSTAT1_ILF)
 
4465         sstat = NCR53c7x0_read8 (SSTAT1_REG);
 
4466         if (sstat & SSTAT1_OLF)
 
4468         if (synchronous && (sstat & SSTAT1_ORF))
 
4475  * Function : static const char * sbcl_to_phase (int sbcl)_
 
4477  * Purpose : Convert SBCL register to user-parsable phase representation
 
4479  * Inputs : sbcl - value of sbcl register
 
4484 sbcl_to_phase (int sbcl) {
 
4485     switch (sbcl & SBCL_PHASE_MASK) {
 
4486     case SBCL_PHASE_DATAIN:
 
4488     case SBCL_PHASE_DATAOUT:
 
4490     case SBCL_PHASE_MSGIN:
 
4492     case SBCL_PHASE_MSGOUT:
 
4494     case SBCL_PHASE_CMDOUT:
 
4496     case SBCL_PHASE_STATIN:
 
4504  * Function : static const char * sstat2_to_phase (int sstat)_
 
4506  * Purpose : Convert SSTAT2 register to user-parsable phase representation
 
4508  * Inputs : sstat - value of sstat register
 
4513 sstat2_to_phase (int sstat) {
 
4514     switch (sstat & SSTAT2_PHASE_MASK) {
 
4515     case SSTAT2_PHASE_DATAIN:
 
4517     case SSTAT2_PHASE_DATAOUT:
 
4519     case SSTAT2_PHASE_MSGIN:
 
4521     case SSTAT2_PHASE_MSGOUT:
 
4523     case SSTAT2_PHASE_CMDOUT:
 
4525     case SSTAT2_PHASE_STATIN:
 
4533  * Function : static void intr_phase_mismatch (struct Scsi_Host *host, 
 
4534  *      struct NCR53c7x0_cmd *cmd)
 
4536  * Purpose : Handle phase mismatch interrupts
 
4538  * Inputs : host, cmd - host and NCR command causing the interrupt, cmd
 
4541  * Side effects : The abort_connected() routine is called or the NCR chip 
 
4542  *      is restarted, jumping to the command_complete entry point, or 
 
4543  *      patching the address and transfer count of the current instruction 
 
4544  *      and calling the msg_in entry point as appropriate.
 
4548 intr_phase_mismatch (struct Scsi_Host *host, struct NCR53c7x0_cmd *cmd) {
 
4549     NCR53c7x0_local_declare();
 
4550     u32 dbc_dcmd, *dsp, *dsp_next;
 
4551     unsigned char dcmd, sbcl;
 
4552     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
4555     enum {ACTION_ABORT, ACTION_ABORT_PRINT, ACTION_CONTINUE} action = 
 
4557     const char *where = NULL;
 
4559     NCR53c7x0_local_setup(host);
 
4562      * Corrective action is based on where in the SCSI SCRIPT(tm) the error 
 
4563      * occurred, as well as which SCSI phase we are currently in.
 
4565     dsp_next = bus_to_virt(NCR53c7x0_read32(DSP_REG));
 
4568      * Fetch the current instruction, and remove the operands for easier 
 
4571     dbc_dcmd = NCR53c7x0_read32(DBC_REG);
 
4572     dcmd = (dbc_dcmd & 0xff000000) >> 24;
 
4574      * Like other processors, the NCR adjusts the instruction pointer before
 
4575      * instruction decode.  Set the DSP address back to what it should
 
4576      * be for this instruction based on its size (2 or 3 32 bit words).
 
4578     dsp = dsp_next - NCR53c7x0_insn_size(dcmd);
 
4582      * Read new SCSI phase from the SBCL lines.  Since all of our code uses 
 
4583      * a WHEN conditional instead of an IF conditional, we don't need to 
 
4584      * wait for a new REQ.
 
4586     sbcl = NCR53c7x0_read8(SBCL_REG) & SBCL_PHASE_MASK;
 
4589         action = ACTION_ABORT_PRINT;
 
4590         where = "no current command";
 
4592      * The way my SCSI SCRIPTS(tm) are architected, recoverable phase
 
4593      * mismatches should only occur where we're doing a multi-byte  
 
4594      * BMI instruction.  Specifically, this means 
 
4596      *  - select messages (a SCSI-I target may ignore additional messages
 
4597      *          after the IDENTIFY; any target may reject a SDTR or WDTR)
 
4599      *  - command out (targets may send a message to signal an error 
 
4600      *          condition, or go into STATUSIN after they've decided 
 
4601      *          they don't like the command.
 
4603      *  - reply_message (targets may reject a multi-byte message in the 
 
4606      *  - data transfer routines (command completion with buffer space
 
4607      *          left, disconnect message, or error message)
 
4609     } else if (((dsp >= cmd->data_transfer_start && 
 
4610         dsp < cmd->data_transfer_end)) || dsp == (cmd->residual + 2)) {
 
4611         if ((dcmd & (DCMD_TYPE_MASK|DCMD_BMI_OP_MASK|DCMD_BMI_INDIRECT|
 
4612                 DCMD_BMI_MSG|DCMD_BMI_CD)) == (DCMD_TYPE_BMI|
 
4613                 DCMD_BMI_OP_MOVE_I)) {
 
4614             residual = datapath_residual (host);
 
4615             if (hostdata->options & OPTION_DEBUG_DISCONNECT)
 
4616                 printk ("scsi%d : handling residual transfer (+ %d bytes from DMA FIFO)\n", 
 
4617                     host->host_no, residual);
 
4620              * The first instruction is a CALL to the alternate handler for 
 
4621              * this data transfer phase, so we can do calls to 
 
4622              * munge_msg_restart as we would if control were passed 
 
4623              * from normal dynamic code.
 
4625             if (dsp != cmd->residual + 2) {
 
4626                 cmd->residual[0] = ((DCMD_TYPE_TCI | DCMD_TCI_OP_CALL |
 
4627                         ((dcmd & DCMD_BMI_IO) ? DCMD_TCI_IO : 0)) << 24) | 
 
4628                     DBC_TCI_WAIT_FOR_VALID | DBC_TCI_COMPARE_PHASE;
 
4629                 cmd->residual[1] = virt_to_bus(hostdata->script)
 
4630                     + ((dcmd & DCMD_BMI_IO)
 
4631                        ? hostdata->E_other_in : hostdata->E_other_out);
 
4635              * The second instruction is the a data transfer block
 
4636              * move instruction, reflecting the pointer and count at the 
 
4637              * time of the phase mismatch.
 
4639             cmd->residual[2] = dbc_dcmd + residual;
 
4640             cmd->residual[3] = NCR53c7x0_read32(DNAD_REG) - residual;
 
4643              * The third and final instruction is a jump to the instruction
 
4644              * which follows the instruction which had to be 'split'
 
4646             if (dsp != cmd->residual + 2) {
 
4647                 cmd->residual[4] = ((DCMD_TYPE_TCI|DCMD_TCI_OP_JUMP) 
 
4648                     << 24) | DBC_TCI_TRUE;
 
4649                 cmd->residual[5] = virt_to_bus(dsp_next);
 
4653              * For the sake of simplicity, transfer control to the 
 
4654              * conditional CALL at the start of the residual buffer.
 
4656             hostdata->dsp = cmd->residual;
 
4657             hostdata->dsp_changed = 1;
 
4658             action = ACTION_CONTINUE;
 
4660             where = "non-BMI dynamic DSA code";
 
4661             action = ACTION_ABORT_PRINT;
 
4663     } else if (dsp == (hostdata->script + hostdata->E_select_msgout / 4 + 2)) {
 
4664         /* RGH 290697:  Added +2 above, to compensate for the script
 
4665          * instruction which disables the selection timer. */
 
4667         NCR53c7x0_write8 (SOCL_REG, 0);
 
4670      * Some devices (SQ555 come to mind) grab the IDENTIFY message
 
4671      * sent on selection, and decide to go into COMMAND OUT phase
 
4672      * rather than accepting the rest of the messages or rejecting
 
4673      * them.  Handle these devices gracefully.
 
4675         case SBCL_PHASE_CMDOUT:
 
4676             hostdata->dsp = dsp + 2 /* two _words_ */;
 
4677             hostdata->dsp_changed = 1;
 
4678             printk ("scsi%d : target %d ignored SDTR and went into COMMAND OUT\n", 
 
4679                 host->host_no, cmd->cmd->device->id);
 
4680             cmd->flags &= ~CMD_FLAG_SDTR;
 
4681             action = ACTION_CONTINUE;
 
4683         case SBCL_PHASE_MSGIN:
 
4684             hostdata->dsp = hostdata->script + hostdata->E_msg_in / 
 
4686             hostdata->dsp_changed = 1;
 
4687             action = ACTION_CONTINUE;
 
4690             where="select message out";
 
4691             action = ACTION_ABORT_PRINT;
 
4694      * Some SCSI devices will interpret a command as they read the bytes
 
4695      * off the SCSI bus, and may decide that the command is Bogus before 
 
4696      * they've read the entire command off the bus.
 
4698     } else if (dsp == hostdata->script + hostdata->E_cmdout_cmdout / sizeof 
 
4700         hostdata->dsp = hostdata->script + hostdata->E_data_transfer /
 
4702         hostdata->dsp_changed = 1;
 
4703         action = ACTION_CONTINUE;
 
4704     /* FIXME : we need to handle message reject, etc. within msg_respond. */
 
4706     } else if (dsp == hostdata->script + hostdata->E_reply_message) {
 
4708     /* Any other phase mismatches abort the currently executing command.  */
 
4711         where = "unknown location";
 
4712         action = ACTION_ABORT_PRINT;
 
4715     /* Flush DMA FIFO */
 
4716     if (!hostdata->dstat_valid) {
 
4717         hostdata->dstat = NCR53c7x0_read8(DSTAT_REG);
 
4718         hostdata->dstat_valid = 1;
 
4720     if (!(hostdata->dstat & DSTAT_DFE)) {
 
4721       /* Really need to check this out for 710 RGH */
 
4722       NCR53c7x0_write8 (CTEST8_REG, CTEST8_10_CLF);
 
4723       while (NCR53c7x0_read8 (CTEST8_REG) & CTEST8_10_CLF);
 
4724       hostdata->dstat |= DSTAT_DFE;
 
4728     case ACTION_ABORT_PRINT:
 
4729         printk("scsi%d : %s : unexpected phase %s.\n",
 
4730              host->host_no, where ? where : "unknown location", 
 
4731              sbcl_to_phase(sbcl));
 
4733     /* Fall through to ACTION_ABORT */
 
4735         abort_connected (host);
 
4737     case ACTION_CONTINUE:
 
4742     if (hostdata->dsp_changed) {
 
4743         printk("scsi%d: new dsp 0x%p\n", host->host_no, hostdata->dsp);
 
4744         print_insn (host, hostdata->dsp, "", 1);
 
4750  * Function : static void intr_bf (struct Scsi_Host *host, 
 
4751  *      struct NCR53c7x0_cmd *cmd)
 
4753  * Purpose : handle BUS FAULT interrupts 
 
4755  * Inputs : host, cmd - host and NCR command causing the interrupt, cmd
 
4760 intr_bf (struct Scsi_Host *host, struct NCR53c7x0_cmd *cmd) {
 
4761     NCR53c7x0_local_declare();
 
4763         *next_dsp,              /* Current dsp */
 
4765         dbc_dcmd;               /* DCMD (high eight bits) + DBC */
 
4766     char *reason = NULL;
 
4767     /* Default behavior is for a silent error, with a retry until we've
 
4768        exhausted retries. */
 
4769     enum {MAYBE, ALWAYS, NEVER} retry = MAYBE;
 
4771     NCR53c7x0_local_setup(host);
 
4773     dbc_dcmd = NCR53c7x0_read32 (DBC_REG);
 
4774     next_dsp = bus_to_virt (NCR53c7x0_read32(DSP_REG));
 
4775     dsp = next_dsp - NCR53c7x0_insn_size ((dbc_dcmd >> 24) & 0xff);
 
4776 /* FIXME - check chip type  */
 
4777     dsa = bus_to_virt (NCR53c7x0_read32(DSA_REG));
 
4780      * Bus faults can be caused by either a Bad Address or 
 
4781      * Target Abort. We should check the Received Target Abort
 
4782      * bit of the PCI status register and Master Abort Bit.
 
4784      *  - Master Abort bit indicates that no device claimed
 
4785      *          the address with DEVSEL within five clocks
 
4787      *  - Target Abort bit indicates that a target claimed it,
 
4788      *          but changed its mind once it saw the byte enables.
 
4792     /* 53c710, not PCI system */
 
4799     if (report && reason)
 
4801         printk(KERN_ALERT "scsi%d : BUS FAULT reason = %s\n",
 
4802              host->host_no, reason ? reason : "unknown");
 
4811      * TODO : we should attempt to recover from any spurious bus 
 
4812      * faults.  After X retries, we should figure that things are 
 
4813      * sufficiently wedged, and call NCR53c7xx_reset.
 
4815      * This code should only get executed once we've decided that we 
 
4819     if (retry == NEVER) {
 
4820         printk(KERN_ALERT "          mail richard@sleepie.demon.co.uk\n");
 
4826  * Function : static void intr_dma (struct Scsi_Host *host, 
 
4827  *      struct NCR53c7x0_cmd *cmd)
 
4829  * Purpose : handle all DMA interrupts, indicated by the setting 
 
4830  *      of the DIP bit in the ISTAT register.
 
4832  * Inputs : host, cmd - host and NCR command causing the interrupt, cmd
 
4837 intr_dma (struct Scsi_Host *host, struct NCR53c7x0_cmd *cmd) {
 
4838     NCR53c7x0_local_declare();
 
4839     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
4841     unsigned char dstat;        /* DSTAT */     
 
4843         *next_dsp,              /* Current dsp */
 
4845         dbc_dcmd;               /* DCMD (high eight bits) + DBC */
 
4847     unsigned long flags;
 
4848     NCR53c7x0_local_setup(host);
 
4850     if (!hostdata->dstat_valid) {
 
4851         hostdata->dstat = NCR53c7x0_read8(DSTAT_REG);
 
4852         hostdata->dstat_valid = 1;
 
4855     dstat = hostdata->dstat;
 
4857     if (hostdata->options & OPTION_DEBUG_INTR)
 
4858         printk("scsi%d : DSTAT=0x%x\n", host->host_no, (int) dstat);
 
4860     dbc_dcmd = NCR53c7x0_read32 (DBC_REG);
 
4861     next_dsp = bus_to_virt(NCR53c7x0_read32(DSP_REG));
 
4862     dsp = next_dsp - NCR53c7x0_insn_size ((dbc_dcmd >> 24) & 0xff);
 
4863 /* XXX - check chip type */
 
4864     dsa = bus_to_virt(NCR53c7x0_read32(DSA_REG));
 
4867      * DSTAT_ABRT is the aborted interrupt.  This is set whenever the 
 
4868      * SCSI chip is aborted.  
 
4870      * With NCR53c700 and NCR53c700-66 style chips, we should only 
 
4871      * get this when the chip is currently running the accept 
 
4872      * reselect/select code and we have set the abort bit in the 
 
4877     if (dstat & DSTAT_ABRT) {
 
4879         /* XXX - add code here to deal with normal abort */
 
4880         if ((hostdata->options & OPTION_700) && (hostdata->state ==
 
4885             printk(KERN_ALERT "scsi%d : unexpected abort interrupt at\n" 
 
4886                    "         ", host->host_no);
 
4887             print_insn (host, dsp, KERN_ALERT "s ", 1);
 
4893      * DSTAT_SSI is the single step interrupt.  Should be generated 
 
4894      * whenever we have single stepped or are tracing.
 
4897     if (dstat & DSTAT_SSI) {
 
4898         if (hostdata->options & OPTION_DEBUG_TRACE) {
 
4899             /* Don't print instr. until we write DSP at end of intr function */
 
4900         } else if (hostdata->options & OPTION_DEBUG_SINGLE) {
 
4901             print_insn (host, dsp, "s ", 0);
 
4902             local_irq_save(flags);
 
4903 /* XXX - should we do this, or can we get away with writing dsp? */
 
4905             NCR53c7x0_write8 (DCNTL_REG, (NCR53c7x0_read8(DCNTL_REG) & 
 
4906                 ~DCNTL_SSM) | DCNTL_STD);
 
4907             local_irq_restore(flags);
 
4909             printk(KERN_ALERT "scsi%d : unexpected single step interrupt at\n"
 
4910                    "         ", host->host_no);
 
4911             print_insn (host, dsp, KERN_ALERT "", 1);
 
4912             printk(KERN_ALERT "         mail drew@PoohSticks.ORG\n");
 
4918      * DSTAT_IID / DSTAT_OPC (same bit, same meaning, only the name 
 
4919      * is different) is generated whenever an illegal instruction is 
 
4922      * XXX - we may want to emulate INTFLY here, so we can use 
 
4923      *    the same SCSI SCRIPT (tm) for NCR53c710 through NCR53c810  
 
4927     if (dstat & DSTAT_OPC) {
 
4929      * Ascertain if this IID interrupts occurred before or after a STO 
 
4930      * interrupt.  Since the interrupt handling code now leaves 
 
4931      * DSP unmodified until _after_ all stacked interrupts have been
 
4932      * processed, reading the DSP returns the original DSP register.
 
4933      * This means that if dsp lies between the select code, and 
 
4934      * message out following the selection code (where the IID interrupt
 
4935      * would have to have occurred by due to the implicit wait for REQ),
 
4936      * we have an IID interrupt resulting from a STO condition and 
 
4940         if (((dsp >= (hostdata->script + hostdata->E_select / sizeof(u32))) &&
 
4941             (dsp <= (hostdata->script + hostdata->E_select_msgout / 
 
4942             sizeof(u32) + 8))) || (hostdata->test_running == 2)) {
 
4943             if (hostdata->options & OPTION_DEBUG_INTR) 
 
4944                 printk ("scsi%d : ignoring DSTAT_IID for SSTAT_STO\n",
 
4946             if (hostdata->expecting_iid) {
 
4947                 hostdata->expecting_iid = 0;
 
4949                 if (hostdata->test_running == 2) {
 
4950                     hostdata->test_running = 0;
 
4951                     hostdata->test_completed = 3;
 
4953                         abnormal_finished (cmd, DID_BAD_TARGET << 16);
 
4955                 hostdata->expecting_sto = 1;
 
4958      * We can't guarantee we'll be able to execute the WAIT DISCONNECT
 
4959      * instruction within the 3.4us of bus free and arbitration delay
 
4960      * that a target can RESELECT in and assert REQ after we've dropped
 
4961      * ACK.  If this happens, we'll get an illegal instruction interrupt.
 
4962      * Doing away with the WAIT DISCONNECT instructions broke everything,
 
4963      * so instead I'll settle for moving one WAIT DISCONNECT a few 
 
4964      * instructions closer to the CLEAR ACK before it to minimize the
 
4965      * chances of this happening, and handle it if it occurs anyway.
 
4967      * Simply continue with what we were doing, and control should
 
4968      * be transferred to the schedule routine which will ultimately
 
4969      * pass control onto the reselection or selection (not yet)
 
4972         } else if (dbc_dcmd == 0x48000000 && (NCR53c7x0_read8 (SBCL_REG) &
 
4974             if (!(hostdata->options & OPTION_NO_PRINT_RACE))
 
4976                 printk("scsi%d: REQ before WAIT DISCONNECT IID\n", 
 
4978                 hostdata->options |= OPTION_NO_PRINT_RACE;
 
4981             printk(KERN_ALERT "scsi%d : invalid instruction\n", host->host_no);
 
4983             printk(KERN_ALERT "         mail Richard@sleepie.demon.co.uk with ALL\n"
 
4984                               "         boot messages and diagnostic output\n");
 
4990      * DSTAT_BF are bus fault errors.  DSTAT_800_BF is valid for 710 also.
 
4993     if (dstat & DSTAT_800_BF) {
 
4994         intr_bf (host, cmd);
 
4999      * DSTAT_SIR interrupts are generated by the execution of 
 
5000      * the INT instruction.  Since the exact values available 
 
5001      * are determined entirely by the SCSI script running, 
 
5002      * and are local to a particular script, a unique handler
 
5003      * is called for each script.
 
5006     if (dstat & DSTAT_SIR) {
 
5007         if (hostdata->options & OPTION_DEBUG_INTR)
 
5008             printk ("scsi%d : DSTAT_SIR\n", host->host_no);
 
5009         switch ((tmp = hostdata->dstat_sir_intr (host, cmd))) {
 
5010         case SPECIFIC_INT_NOTHING:
 
5011         case SPECIFIC_INT_RESTART:
 
5013         case SPECIFIC_INT_ABORT:
 
5014             abort_connected(host);
 
5016         case SPECIFIC_INT_PANIC:
 
5017             printk(KERN_ALERT "scsi%d : failure at ", host->host_no);
 
5018             print_insn (host, dsp, KERN_ALERT "", 1);
 
5019             printk(KERN_ALERT "          dstat_sir_intr() returned SPECIFIC_INT_PANIC\n");
 
5022         case SPECIFIC_INT_BREAK:
 
5023             intr_break (host, cmd);
 
5026             printk(KERN_ALERT "scsi%d : failure at ", host->host_no);
 
5027             print_insn (host, dsp, KERN_ALERT "", 1);
 
5028             printk(KERN_ALERT"          dstat_sir_intr() returned unknown value %d\n", 
 
5036  * Function : static int print_insn (struct Scsi_Host *host, 
 
5037  *      u32 *insn, int kernel)
 
5039  * Purpose : print numeric representation of the instruction pointed
 
5040  *      to by insn to the debugging or kernel message buffer
 
5043  *      If desired, a user level program can interpret this 
 
5046  * Inputs : host, insn - host, pointer to instruction, prefix - 
 
5047  *      string to prepend, kernel - use printk instead of debugging buffer.
 
5049  * Returns : size, in u32s, of instruction printed.
 
5053  * FIXME: should change kernel parameter so that it takes an ENUM
 
5054  *      specifying severity - either KERN_ALERT or KERN_PANIC so
 
5055  *      all panic messages are output with the same severity.
 
5059 print_insn (struct Scsi_Host *host, const u32 *insn, 
 
5060     const char *prefix, int kernel) {
 
5061     char buf[160],              /* Temporary buffer and pointer.  ICKY 
 
5062                                    arbitrary length.  */
 
5066     unsigned char dcmd;         /* dcmd register for *insn */
 
5070      * Check to see if the instruction pointer is not bogus before 
 
5071      * indirecting through it; avoiding red-zone at start of 
 
5074      * FIXME: icky magic needs to happen here on non-intel boxes which
 
5075      * don't have kernel memory mapped in like this.  Might be reasonable
 
5079     if (virt_to_phys((void *)insn) < PAGE_SIZE || 
 
5080         virt_to_phys((void *)(insn + 8)) > virt_to_phys(high_memory) ||
 
5081         ((((dcmd = (insn[0] >> 24) & 0xff) & DCMD_TYPE_MMI) == DCMD_TYPE_MMI) &&
 
5082         virt_to_phys((void *)(insn + 12)) > virt_to_phys(high_memory))) {
 
5084         sprintf (buf, "%s%p: address out of range\n",
 
5088  * FIXME : (void *) cast in virt_to_bus should be unnecessary, because
 
5089  *      it should take const void * as argument.
 
5091 #if !defined(CONFIG_MVME16x) && !defined(CONFIG_BVME6000)
 
5092         sprintf(buf, "%s0x%lx (virt 0x%p) : 0x%08x 0x%08x (virt 0x%p)", 
 
5093             (prefix ? prefix : ""), virt_to_bus((void *) insn), insn,  
 
5094             insn[0], insn[1], bus_to_virt (insn[1]));
 
5096         /* Remove virtual addresses to reduce output, as they are the same */
 
5097         sprintf(buf, "%s0x%x (+%x) : 0x%08x 0x%08x", 
 
5098             (prefix ? prefix : ""), (u32)insn, ((u32)insn -
 
5099                 (u32)&(((struct NCR53c7x0_hostdata *)host->hostdata[0])->script))/4, 
 
5102         tmp = buf + strlen(buf);
 
5103         if ((dcmd & DCMD_TYPE_MASK) == DCMD_TYPE_MMI)  {
 
5104 #if !defined(CONFIG_MVME16x) && !defined(CONFIG_BVME6000)
 
5105             sprintf (tmp, " 0x%08x (virt 0x%p)\n", insn[2], 
 
5106                 bus_to_virt(insn[2]));
 
5108             /* Remove virtual addr to reduce output, as it is the same */
 
5109             sprintf (tmp, " 0x%08x\n", insn[2]);
 
5113             sprintf (tmp, "\n");
 
5122         size_t len = strlen(buf);
 
5123         debugger_kernel_write(host, buf, len);
 
5130  * Function : int NCR53c7xx_abort (Scsi_Cmnd *cmd)
 
5132  * Purpose : Abort an errant SCSI command, doing all necessary
 
5133  *      cleanup of the issue_queue, running_list, shared Linux/NCR
 
5134  *      dsa issue and reconnect queues.
 
5136  * Inputs : cmd - command to abort, code - entire result field
 
5138  * Returns : 0 on success, -1 on failure.
 
5142 NCR53c7xx_abort (Scsi_Cmnd *cmd) {
 
5143     NCR53c7x0_local_declare();
 
5144     struct Scsi_Host *host = cmd->device->host;
 
5145     struct NCR53c7x0_hostdata *hostdata = host ? (struct NCR53c7x0_hostdata *) 
 
5146         host->hostdata[0] : NULL;
 
5147     unsigned long flags;
 
5148     struct NCR53c7x0_cmd *curr, **prev;
 
5149     Scsi_Cmnd *me, **last;
 
5151     static long cache_pid = -1;
 
5156         printk ("Bogus SCSI command pid %ld; no host structure\n",
 
5158         return SCSI_ABORT_ERROR;
 
5159     } else if (!hostdata) {
 
5160         printk ("Bogus SCSI host %d; no hostdata\n", host->host_no);
 
5161         return SCSI_ABORT_ERROR;
 
5163     NCR53c7x0_local_setup(host);
 
5166  * CHECK : I don't think that reading ISTAT will unstack any interrupts,
 
5167  *      since we need to write the INTF bit to clear it, and SCSI/DMA
 
5168  *      interrupts don't clear until we read SSTAT/SIST and DSTAT registers.
 
5170  *      See that this is the case.  Appears to be correct on the 710, at least.
 
5172  * I suspect that several of our failures may be coming from a new fatal
 
5173  * interrupt (possibly due to a phase mismatch) happening after we've left
 
5174  * the interrupt handler, but before the PIC has had the interrupt condition
 
5178     if (NCR53c7x0_read8(hostdata->istat) & (ISTAT_DIP|ISTAT_SIP)) {
 
5179         printk ("scsi%d : dropped interrupt for command %ld\n", host->host_no,
 
5181         NCR53c7x0_intr (host->irq, NULL, NULL);
 
5182         return SCSI_ABORT_BUSY;
 
5185     local_irq_save(flags);
 
5187     if (cache_pid == cmd->pid) 
 
5188         panic ("scsi%d : bloody fetus %d\n", host->host_no, cmd->pid);
 
5190         cache_pid = cmd->pid;
 
5195  * The command could be hiding in the issue_queue.  This would be very
 
5196  * nice, as commands can't be moved from the high level driver's issue queue 
 
5197  * into the shared queue until an interrupt routine is serviced, and this
 
5200  * If this is the case, we don't have to worry about anything - we simply
 
5201  * pull the command out of the old queue, and call it aborted.
 
5204     for (me = (Scsi_Cmnd *) hostdata->issue_queue, 
 
5205          last = (Scsi_Cmnd **) &(hostdata->issue_queue);
 
5206          me && me != cmd;  last = (Scsi_Cmnd **)&(me->SCp.ptr), 
 
5207          me = (Scsi_Cmnd *)me->SCp.ptr);
 
5210         *last = (Scsi_Cmnd *) me->SCp.ptr;
 
5211         if (me->host_scribble) {
 
5212             ((struct NCR53c7x0_cmd *)me->host_scribble)->next = hostdata->free;
 
5213             hostdata->free = (struct NCR53c7x0_cmd *) me->host_scribble;
 
5214             me->host_scribble = NULL;
 
5216         cmd->result = DID_ABORT << 16;
 
5217         cmd->scsi_done(cmd);
 
5218         printk ("scsi%d : found command %ld in Linux issue queue\n", 
 
5219             host->host_no, me->pid);
 
5220         local_irq_restore(flags);
 
5221         run_process_issue_queue();
 
5222         return SCSI_ABORT_SUCCESS;
 
5226  * That failing, the command could be in our list of already executing 
 
5227  * commands.  If this is the case, drastic measures are called for.  
 
5230     for (curr = (struct NCR53c7x0_cmd *) hostdata->running_list, 
 
5231          prev = (struct NCR53c7x0_cmd **) &(hostdata->running_list);
 
5232          curr && curr->cmd != cmd; prev = (struct NCR53c7x0_cmd **) 
 
5233          &(curr->next), curr = (struct NCR53c7x0_cmd *) curr->next);
 
5236         if ((curr->result & 0xff) != 0xff && (curr->result & 0xff00) != 0xff00) {
 
5237             cmd->result = curr->result;
 
5239                 *prev = (struct NCR53c7x0_cmd *) curr->next;
 
5240             curr->next = (struct NCR53c7x0_cmd *) hostdata->free;
 
5241             cmd->host_scribble = NULL;
 
5242             hostdata->free = curr;
 
5243             cmd->scsi_done(cmd);
 
5244         printk ("scsi%d : found finished command %ld in running list\n", 
 
5245             host->host_no, cmd->pid);
 
5246             local_irq_restore(flags);
 
5247             return SCSI_ABORT_NOT_RUNNING;
 
5249             printk ("scsi%d : DANGER : command running, can not abort.\n",
 
5250                 cmd->device->host->host_no);
 
5251             local_irq_restore(flags);
 
5252             return SCSI_ABORT_BUSY;
 
5257  * And if we couldn't find it in any of our queues, it must have been 
 
5258  * a dropped interrupt.
 
5261     curr = (struct NCR53c7x0_cmd *) cmd->host_scribble;
 
5263         curr->next = hostdata->free;
 
5264         hostdata->free = curr;
 
5265         cmd->host_scribble = NULL;
 
5268     if (curr == NULL || ((curr->result & 0xff00) == 0xff00) ||
 
5269                 ((curr->result & 0xff) == 0xff)) {
 
5270         printk ("scsi%d : did this command ever run?\n", host->host_no);
 
5271             cmd->result = DID_ABORT << 16;
 
5273         printk ("scsi%d : probably lost INTFLY, normal completion\n", 
 
5275         cmd->result = curr->result;
 
5277  * FIXME : We need to add an additional flag which indicates if a 
 
5278  * command was ever counted as BUSY, so if we end up here we can
 
5279  * decrement the busy count if and only if it is necessary.
 
5281         --hostdata->busy[cmd->device->id][cmd->device->lun];
 
5283     local_irq_restore(flags);
 
5284     cmd->scsi_done(cmd);
 
5287  * We need to run process_issue_queue since termination of this command 
 
5288  * may allow another queued command to execute first? 
 
5290     return SCSI_ABORT_NOT_RUNNING;
 
5294  * Function : int NCR53c7xx_reset (Scsi_Cmnd *cmd) 
 
5296  * Purpose : perform a hard reset of the SCSI bus and NCR
 
5299  * Inputs : cmd - command which caused the SCSI RESET
 
5301  * Returns : 0 on success.
 
5305 NCR53c7xx_reset (Scsi_Cmnd *cmd, unsigned int reset_flags) {
 
5306     NCR53c7x0_local_declare();
 
5307     unsigned long flags;
 
5309     struct NCR53c7x0_cmd * c;
 
5312      * When we call scsi_done(), it's going to wake up anything sleeping on the
 
5313      * resources which were in use by the aborted commands, and we'll start to 
 
5316      * We can't let this happen until after we've re-initialized the driver
 
5317      * structures, and can't reinitialize those structures until after we've 
 
5318      * dealt with their contents.
 
5320      * So, we need to find all of the commands which were running, stick
 
5321      * them on a linked list of completed commands (we'll use the host_scribble
 
5322      * pointer), do our reinitialization, and then call the done function for
 
5325     Scsi_Cmnd *nuke_list = NULL;
 
5326     struct Scsi_Host *host = cmd->device->host;
 
5327     struct NCR53c7x0_hostdata *hostdata = 
 
5328         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
5330     NCR53c7x0_local_setup(host);
 
5331     local_irq_save(flags);
 
5334     dump_events (host, 30);
 
5335     ncr_scsi_reset (host);
 
5336     for (tmp = nuke_list = return_outstanding_commands (host, 1 /* free */,
 
5337         0 /* issue */ ); tmp; tmp = (Scsi_Cmnd *) tmp->SCp.buffer)
 
5344      * If we didn't find the command which caused this reset in our running
 
5345      * list, then we've lost it.  See that it terminates normally anyway.
 
5348         c = (struct NCR53c7x0_cmd *) cmd->host_scribble;
 
5350             cmd->host_scribble = NULL;
 
5351             c->next = hostdata->free;
 
5354             printk ("scsi%d: lost command %ld\n", host->host_no, cmd->pid);
 
5355         cmd->SCp.buffer = (struct scatterlist *) nuke_list;
 
5359     NCR53c7x0_driver_init (host);
 
5360     hostdata->soft_reset (host);
 
5361     if (hostdata->resets == 0) 
 
5363     else if (hostdata->resets != -1)
 
5365     local_irq_restore(flags);
 
5366     for (; nuke_list; nuke_list = tmp) {
 
5367         tmp = (Scsi_Cmnd *) nuke_list->SCp.buffer;
 
5368         nuke_list->result = DID_RESET << 16;
 
5369         nuke_list->scsi_done (nuke_list);
 
5371     local_irq_restore(flags);
 
5372     return SCSI_RESET_SUCCESS;
 
5376  * The NCR SDMS bios follows Annex A of the SCSI-CAM draft, and 
 
5377  * therefore shares the scsicam_bios_param function.
 
5381  * Function : int insn_to_offset (Scsi_Cmnd *cmd, u32 *insn)
 
5383  * Purpose : convert instructions stored at NCR pointer into data 
 
5386  * Inputs : cmd - SCSI command; insn - pointer to instruction.  Either current
 
5387  *      DSP, or saved data pointer.
 
5389  * Returns : offset on success, -1 on failure.
 
5394 insn_to_offset (Scsi_Cmnd *cmd, u32 *insn) {
 
5395     struct NCR53c7x0_hostdata *hostdata = 
 
5396         (struct NCR53c7x0_hostdata *) cmd->device->host->hostdata[0];
 
5397     struct NCR53c7x0_cmd *ncmd = 
 
5398         (struct NCR53c7x0_cmd *) cmd->host_scribble;
 
5399     int offset = 0, buffers;
 
5400     struct scatterlist *segment;
 
5405  * With the current code implementation, if the insn is inside dynamically 
 
5406  * generated code, the data pointer will be the instruction preceding 
 
5407  * the next transfer segment.
 
5410     if (!check_address ((unsigned long) ncmd, sizeof (struct NCR53c7x0_cmd)) &&
 
5411         ((insn >= ncmd->data_transfer_start &&  
 
5412             insn < ncmd->data_transfer_end) ||
 
5413         (insn >= ncmd->residual &&
 
5414             insn < (ncmd->residual + 
 
5415                 sizeof(ncmd->residual))))) {
 
5416             ptr = bus_to_virt(insn[3]);
 
5418             if ((buffers = cmd->use_sg)) {
 
5420                         segment = (struct scatterlist *) cmd->buffer;
 
5421                      buffers && !((found = ((ptr >= (char *)page_address(segment->page)+segment->offset) && 
 
5422                             (ptr < ((char *)page_address(segment->page)+segment->offset+segment->length)))));
 
5423                      --buffers, offset += segment->length, ++segment)
 
5425                     printk("scsi%d: comparing 0x%p to 0x%p\n", 
 
5426                         cmd->device->host->host_no, saved, page_address(segment->page+segment->offset);
 
5430                     offset += ptr - ((char *)page_address(segment->page)+segment->offset);
 
5433                 offset = ptr - (char *) (cmd->request_buffer);
 
5435     } else if ((insn >= hostdata->script + 
 
5436                 hostdata->E_data_transfer / sizeof(u32)) &&
 
5437                (insn <= hostdata->script +
 
5438                 hostdata->E_end_data_transfer / sizeof(u32))) {
 
5442     return found ? offset : -1;
 
5448  * Function : void print_progress (Scsi_Cmnd *cmd) 
 
5450  * Purpose : print the current location of the saved data pointer
 
5452  * Inputs : cmd - command we are interested in
 
5457 print_progress (Scsi_Cmnd *cmd) {
 
5458     NCR53c7x0_local_declare();
 
5459     struct NCR53c7x0_cmd *ncmd = 
 
5460         (struct NCR53c7x0_cmd *) cmd->host_scribble;
 
5464     NCR53c7x0_local_setup (cmd->device->host);
 
5466     if (check_address ((unsigned long) ncmd,sizeof (struct NCR53c7x0_cmd)) == 0)
 
5468         printk("\nNCR53c7x0_cmd fields:\n");
 
5469         printk("  bounce.len=0x%x, addr=0x%0x, buf[]=0x%02x %02x %02x %02x\n",
 
5470             ncmd->bounce.len, ncmd->bounce.addr, ncmd->bounce.buf[0],
 
5471             ncmd->bounce.buf[1], ncmd->bounce.buf[2], ncmd->bounce.buf[3]);
 
5472         printk("  result=%04x, cdb[0]=0x%02x\n", ncmd->result, ncmd->cmnd[0]);
 
5475     for (i = 0; i < 2; ++i) {
 
5476         if (check_address ((unsigned long) ncmd, 
 
5477             sizeof (struct NCR53c7x0_cmd)) == -1) 
 
5481             ptr = bus_to_virt(ncmd->saved_data_pointer);
 
5484             ptr = bus_to_virt (NCR53c7x0_read32 (DSP_REG) -
 
5485                 NCR53c7x0_insn_size (NCR53c7x0_read8 (DCMD_REG)) *
 
5488         offset = insn_to_offset (cmd, ptr);
 
5491             printk ("scsi%d : %s data pointer at offset %d\n",
 
5492                 cmd->device->host->host_no, where, offset);
 
5495             printk ("scsi%d : can't determine %s data pointer offset\n",
 
5496                 cmd->device->host->host_no, where);
 
5498                 size = print_insn (cmd->device->host,
 
5499                     bus_to_virt(ncmd->saved_data_pointer), "", 1);
 
5500                 print_insn (cmd->device->host,
 
5501                     bus_to_virt(ncmd->saved_data_pointer) + size * sizeof(u32),
 
5510 print_dsa (struct Scsi_Host *host, u32 *dsa, const char *prefix) {
 
5511     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5517     if (check_address ((unsigned long) dsa, hostdata->dsa_end - 
 
5518         hostdata->dsa_start) == -1) {
 
5519         printk("scsi%d : bad dsa virt 0x%p\n", host->host_no, dsa);
 
5522     printk("%sscsi%d : dsa at phys 0x%lx (virt 0x%p)\n"
 
5523             "        + %d : dsa_msgout length = %u, data = 0x%x (virt 0x%p)\n" ,
 
5524             prefix ? prefix : "",
 
5525             host->host_no,  virt_to_bus (dsa), dsa, hostdata->dsa_msgout,
 
5526             dsa[hostdata->dsa_msgout / sizeof(u32)],
 
5527             dsa[hostdata->dsa_msgout / sizeof(u32) + 1],
 
5528             bus_to_virt (dsa[hostdata->dsa_msgout / sizeof(u32) + 1]));
 
5531      * Only print messages if they're sane in length so we don't
 
5532      * blow the kernel printk buffer on something which won't buy us
 
5536     if (dsa[hostdata->dsa_msgout / sizeof(u32)] < 
 
5537             sizeof (hostdata->free->select)) 
 
5538         for (i = dsa[hostdata->dsa_msgout / sizeof(u32)],
 
5539             ptr = bus_to_virt (dsa[hostdata->dsa_msgout / sizeof(u32) + 1]); 
 
5540             i > 0 && !check_address ((unsigned long) ptr, 1);
 
5541             ptr += len, i -= len) {
 
5543             len = scsi_print_msg (ptr);
 
5549     printk("        + %d : select_indirect = 0x%x\n",
 
5550         hostdata->dsa_select, dsa[hostdata->dsa_select / sizeof(u32)]);
 
5551     cmd = (Scsi_Cmnd *) bus_to_virt(dsa[hostdata->dsa_cmnd / sizeof(u32)]);
 
5552     printk("        + %d : dsa_cmnd = 0x%x ", hostdata->dsa_cmnd,
 
5553            (u32) virt_to_bus(cmd));
 
5554     /* XXX Maybe we should access cmd->host_scribble->result here. RGH */
 
5556         printk("               result = 0x%x, target = %d, lun = %d, cmd = ",
 
5557             cmd->result, cmd->device->id, cmd->device->lun);
 
5558         __scsi_print_command(cmd->cmnd);
 
5561     printk("        + %d : dsa_next = 0x%x\n", hostdata->dsa_next,
 
5562         dsa[hostdata->dsa_next / sizeof(u32)]);
 
5564         printk("scsi%d target %d : sxfer_sanity = 0x%x, scntl3_sanity = 0x%x\n"
 
5566             host->host_no, cmd->device->id,
 
5567             hostdata->sync[cmd->device->id].sxfer_sanity,
 
5568             hostdata->sync[cmd->device->id].scntl3_sanity);
 
5569         for (i = 0; i < (sizeof(hostdata->sync[cmd->device->id].script) / 4); ++i)
 
5570             printk ("0x%x ", hostdata->sync[cmd->device->id].script[i]);
 
5572         print_progress (cmd);
 
5576  * Function : void print_queues (Scsi_Host *host) 
 
5578  * Purpose : print the contents of the NCR issue and reconnect queues
 
5580  * Inputs : host - SCSI host we are interested in
 
5585 print_queues (struct Scsi_Host *host) {
 
5586     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5588     u32 *dsa, *next_dsa;
 
5589     volatile u32 *ncrcurrent;
 
5591     Scsi_Cmnd *cmd, *next_cmd;
 
5592     unsigned long flags;
 
5594     printk ("scsi%d : issue queue\n", host->host_no);
 
5596     for (left = host->can_queue, cmd = (Scsi_Cmnd *) hostdata->issue_queue; 
 
5599         next_cmd = (Scsi_Cmnd *) cmd->SCp.ptr;
 
5600         local_irq_save(flags);
 
5601         if (cmd->host_scribble) {
 
5602             if (check_address ((unsigned long) (cmd->host_scribble), 
 
5603                 sizeof (cmd->host_scribble)) == -1)
 
5604                 printk ("scsi%d: scsi pid %ld bad pointer to NCR53c7x0_cmd\n",
 
5605                     host->host_no, cmd->pid);
 
5606             /* print_dsa does sanity check on address, no need to check */
 
5608                 print_dsa (host, ((struct NCR53c7x0_cmd *) cmd->host_scribble)
 
5611             printk ("scsi%d : scsi pid %ld for target %d lun %d has no NCR53c7x0_cmd\n",
 
5612                 host->host_no, cmd->pid, cmd->device->id, cmd->device->lun);
 
5613         local_irq_restore(flags);
 
5617         printk ("scsi%d : loop detected in issue queue\n",
 
5622      * Traverse the NCR reconnect and start DSA structures, printing out 
 
5623      * each element until we hit the end or detect a loop.  Currently,
 
5624      * the reconnect structure is a linked list; and the start structure
 
5625      * is an array.  Eventually, the reconnect structure will become a 
 
5626      * list as well, since this simplifies the code.
 
5629     printk ("scsi%d : schedule dsa array :\n", host->host_no);
 
5630     for (left = host->can_queue, ncrcurrent = hostdata->schedule;
 
5631             left > 0; ncrcurrent += 2, --left)
 
5632         if (ncrcurrent[0] != hostdata->NOP_insn) 
 
5633 /* FIXME : convert pointer to dsa_begin to pointer to dsa. */
 
5634             print_dsa (host, bus_to_virt (ncrcurrent[1] - 
 
5635                 (hostdata->E_dsa_code_begin - 
 
5636                 hostdata->E_dsa_code_template)), "");
 
5637     printk ("scsi%d : end schedule dsa array\n", host->host_no);
 
5639     printk ("scsi%d : reconnect_dsa_head :\n", host->host_no);
 
5641     for (left = host->can_queue, 
 
5642         dsa = bus_to_virt (hostdata->reconnect_dsa_head);
 
5645         local_irq_save(flags);
 
5646         if (check_address ((unsigned long) dsa, sizeof(dsa)) == -1) {
 
5647             printk ("scsi%d: bad DSA pointer 0x%p", host->host_no,
 
5653             next_dsa = bus_to_virt(dsa[hostdata->dsa_next / sizeof(u32)]);
 
5654             print_dsa (host, dsa, "");
 
5656         local_irq_restore(flags);
 
5658     printk ("scsi%d : end reconnect_dsa_head\n", host->host_no);
 
5660         printk("scsi%d: possible loop in ncr reconnect list\n",
 
5665 print_lots (struct Scsi_Host *host) {
 
5666     NCR53c7x0_local_declare();
 
5667     struct NCR53c7x0_hostdata *hostdata = 
 
5668         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
5669     u32 *dsp_next, *dsp, *dsa, dbc_dcmd;
 
5670     unsigned char dcmd, sbcl;
 
5672     NCR53c7x0_local_setup(host);
 
5674     if ((dsp_next = bus_to_virt(NCR53c7x0_read32 (DSP_REG)))) {
 
5675         dbc_dcmd = NCR53c7x0_read32(DBC_REG);
 
5676         dcmd = (dbc_dcmd & 0xff000000) >> 24;
 
5677         dsp = dsp_next - NCR53c7x0_insn_size(dcmd);
 
5678         dsa = bus_to_virt(NCR53c7x0_read32(DSA_REG));
 
5679         sbcl = NCR53c7x0_read8 (SBCL_REG);
 
5682          * For the 53c710, the following will report value 0 for SCNTL3
 
5683          * and STEST0 - we don't have these registers.
 
5685         printk ("scsi%d : DCMD|DBC=0x%x, DNAD=0x%x (virt 0x%p)\n"
 
5686                 "         DSA=0x%lx (virt 0x%p)\n"
 
5687                 "         DSPS=0x%x, TEMP=0x%x (virt 0x%p), DMODE=0x%x\n"
 
5688                 "         SXFER=0x%x, SCNTL3=0x%x\n"
 
5689                 "         %s%s%sphase=%s, %d bytes in SCSI FIFO\n"
 
5690                 "         SCRATCH=0x%x, saved2_dsa=0x%0lx\n",
 
5691             host->host_no, dbc_dcmd, NCR53c7x0_read32(DNAD_REG),
 
5692                 bus_to_virt(NCR53c7x0_read32(DNAD_REG)),
 
5693             virt_to_bus(dsa), dsa,
 
5694             NCR53c7x0_read32(DSPS_REG), NCR53c7x0_read32(TEMP_REG), 
 
5695             bus_to_virt (NCR53c7x0_read32(TEMP_REG)),
 
5696             (int) NCR53c7x0_read8(hostdata->dmode),
 
5697             (int) NCR53c7x0_read8(SXFER_REG), 
 
5698             ((hostdata->chip / 100) == 8) ?
 
5699                 (int) NCR53c7x0_read8(SCNTL3_REG_800) : 0,
 
5700             (sbcl & SBCL_BSY) ? "BSY " : "",
 
5701             (sbcl & SBCL_SEL) ? "SEL " : "",
 
5702             (sbcl & SBCL_REQ) ? "REQ " : "",
 
5703             sstat2_to_phase(NCR53c7x0_read8 (((hostdata->chip / 100) == 8) ?
 
5704                 SSTAT1_REG : SSTAT2_REG)),
 
5705             (NCR53c7x0_read8 ((hostdata->chip / 100) == 8 ? 
 
5706                 SSTAT1_REG : SSTAT2_REG) & SSTAT2_FF_MASK) >> SSTAT2_FF_SHIFT,
 
5707             ((hostdata->chip / 100) == 8) ? NCR53c7x0_read8 (STEST0_REG_800) :
 
5708                 NCR53c7x0_read32(SCRATCHA_REG_800),
 
5709             hostdata->saved2_dsa);
 
5710         printk ("scsi%d : DSP 0x%lx (virt 0x%p) ->\n", host->host_no, 
 
5711             virt_to_bus(dsp), dsp);
 
5712         for (i = 6; i > 0; --i, dsp += size)
 
5713             size = print_insn (host, dsp, "", 1);
 
5714         if (NCR53c7x0_read8 (SCNTL1_REG) & SCNTL1_CON)  {
 
5715             if ((hostdata->chip / 100) == 8)
 
5716                 printk ("scsi%d : connected (SDID=0x%x, SSID=0x%x)\n",
 
5717                     host->host_no, NCR53c7x0_read8 (SDID_REG_800),
 
5718                     NCR53c7x0_read8 (SSID_REG_800));
 
5720                 printk ("scsi%d : connected (SDID=0x%x)\n",
 
5721                     host->host_no, NCR53c7x0_read8 (SDID_REG_700));
 
5722             print_dsa (host, dsa, "");
 
5726         print_queues (host);
 
5732  * Function : static int shutdown (struct Scsi_Host *host)
 
5734  * Purpose : does a clean (we hope) shutdown of the NCR SCSI 
 
5735  *      chip.  Use prior to dumping core, unloading the NCR driver,
 
5737  * Returns : 0 on success
 
5740 shutdown (struct Scsi_Host *host) {
 
5741     NCR53c7x0_local_declare();
 
5742     unsigned long flags;
 
5743     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5745     NCR53c7x0_local_setup(host);
 
5746     local_irq_save(flags);
 
5747 /* Get in a state where we can reset the SCSI bus */
 
5749     ncr_scsi_reset (host);
 
5750     hostdata->soft_reset(host);
 
5753     local_irq_restore(flags);
 
5758  * Function : void ncr_scsi_reset (struct Scsi_Host *host)
 
5760  * Purpose : reset the SCSI bus.
 
5764 ncr_scsi_reset (struct Scsi_Host *host) {
 
5765     NCR53c7x0_local_declare();
 
5766     unsigned long flags;
 
5767     NCR53c7x0_local_setup(host);
 
5768     local_irq_save(flags);
 
5769     NCR53c7x0_write8(SCNTL1_REG, SCNTL1_RST);
 
5770     udelay(25); /* Minimum amount of time to assert RST */
 
5771     NCR53c7x0_write8(SCNTL1_REG, 0);
 
5772     local_irq_restore(flags);
 
5776  * Function : void hard_reset (struct Scsi_Host *host)
 
5781 hard_reset (struct Scsi_Host *host) {
 
5782     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5784     unsigned long flags;
 
5785     local_irq_save(flags);
 
5786     ncr_scsi_reset(host);
 
5787     NCR53c7x0_driver_init (host);
 
5788     if (hostdata->soft_reset)
 
5789         hostdata->soft_reset (host);
 
5790     local_irq_restore(flags);
 
5795  * Function : Scsi_Cmnd *return_outstanding_commands (struct Scsi_Host *host,
 
5796  *      int free, int issue)
 
5798  * Purpose : return a linked list (using the SCp.buffer field as next,
 
5799  *      so we don't perturb hostdata.  We don't use a field of the 
 
5800  *      NCR53c7x0_cmd structure since we may not have allocated one 
 
5801  *      for the command causing the reset.) of Scsi_Cmnd structures that 
 
5802  *      had propagated below the Linux issue queue level.  If free is set, 
 
5803  *      free the NCR53c7x0_cmd structures which are associated with 
 
5804  *      the Scsi_Cmnd structures, and clean up any internal 
 
5805  *      NCR lists that the commands were on.  If issue is set,
 
5806  *      also return commands in the issue queue.
 
5808  * Returns : linked list of commands
 
5810  * NOTE : the caller should insure that the NCR chip is halted
 
5811  *      if the free flag is set. 
 
5815 return_outstanding_commands (struct Scsi_Host *host, int free, int issue) {
 
5816     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5818     struct NCR53c7x0_cmd *c;
 
5821     Scsi_Cmnd *list = NULL, *tmp;
 
5822     for (c = (struct NCR53c7x0_cmd *) hostdata->running_list; c; 
 
5823         c = (struct NCR53c7x0_cmd *) c->next)  {
 
5824         if (c->cmd->SCp.buffer) {
 
5825             printk ("scsi%d : loop detected in running list!\n", host->host_no);
 
5828             printk ("Duh? Bad things happening in the NCR driver\n");
 
5832         c->cmd->SCp.buffer = (struct scatterlist *) list;
 
5835             c->next = hostdata->free;
 
5841         for (i = 0, ncrcurrent = (u32 *) hostdata->schedule; 
 
5842             i < host->can_queue; ++i, ncrcurrent += 2) {
 
5843             ncrcurrent[0] = hostdata->NOP_insn;
 
5844             ncrcurrent[1] = 0xdeadbeef;
 
5846         hostdata->ncrcurrent = NULL;
 
5850         for (tmp = (Scsi_Cmnd *) hostdata->issue_queue; tmp; tmp = tmp->next) {
 
5851             if (tmp->SCp.buffer) {
 
5852                 printk ("scsi%d : loop detected in issue queue!\n", 
 
5856             tmp->SCp.buffer = (struct scatterlist *) list;
 
5860             hostdata->issue_queue = NULL;
 
5867  * Function : static int disable (struct Scsi_Host *host)
 
5869  * Purpose : disables the given NCR host, causing all commands
 
5870  *      to return a driver error.  Call this so we can unload the
 
5871  *      module during development and try again.  Eventually, 
 
5872  *      we should be able to find clean workarounds for these
 
5875  * Inputs : host - hostadapter to twiddle
 
5877  * Returns : 0 on success.
 
5881 disable (struct Scsi_Host *host) {
 
5882     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5884     unsigned long flags;
 
5885     Scsi_Cmnd *nuke_list, *tmp;
 
5886     local_irq_save(flags);
 
5887     if (hostdata->state != STATE_HALTED)
 
5889     nuke_list = return_outstanding_commands (host, 1 /* free */, 1 /* issue */);
 
5891     hostdata->state = STATE_DISABLED;
 
5892     local_irq_restore(flags);
 
5893     printk ("scsi%d : nuking commands\n", host->host_no);
 
5894     for (; nuke_list; nuke_list = tmp) {
 
5895             tmp = (Scsi_Cmnd *) nuke_list->SCp.buffer;
 
5896             nuke_list->result = DID_ERROR << 16;
 
5897             nuke_list->scsi_done(nuke_list);
 
5899     printk ("scsi%d : done. \n", host->host_no);
 
5900     printk (KERN_ALERT "scsi%d : disabled.  Unload and reload\n",
 
5906  * Function : static int ncr_halt (struct Scsi_Host *host)
 
5908  * Purpose : halts the SCSI SCRIPTS(tm) processor on the NCR chip
 
5910  * Inputs : host - SCSI chip to halt
 
5912  * Returns : 0 on success
 
5916 ncr_halt (struct Scsi_Host *host) {
 
5917     NCR53c7x0_local_declare();
 
5918     unsigned long flags;
 
5919     unsigned char istat, tmp;
 
5920     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
5923     NCR53c7x0_local_setup(host);
 
5925     local_irq_save(flags);
 
5926     /* Stage 0 : eat all interrupts
 
5928        Stage 2 : eat all but abort interrupts
 
5929        Stage 3 : eat all interrupts
 
5933             NCR53c7x0_write8(hostdata->istat, ISTAT_ABRT);
 
5936         istat = NCR53c7x0_read8 (hostdata->istat);
 
5937         if (istat & ISTAT_SIP) {
 
5938             tmp = NCR53c7x0_read8(SSTAT0_REG);
 
5939         } else if (istat & ISTAT_DIP) {
 
5940             tmp = NCR53c7x0_read8(DSTAT_REG);
 
5942                 if (tmp & DSTAT_ABRT) {
 
5943                     NCR53c7x0_write8(hostdata->istat, 0);
 
5946                     printk(KERN_ALERT "scsi%d : could not halt NCR chip\n", 
 
5952         if (!(istat & (ISTAT_SIP|ISTAT_DIP))) {
 
5955             else if (stage == 3)
 
5959     hostdata->state = STATE_HALTED;
 
5960     local_irq_restore(flags);
 
5968  * Function: event_name (int event)
 
5970  * Purpose: map event enum into user-readable strings.
 
5974 event_name (int event) {
 
5976     case EVENT_NONE:            return "none";
 
5977     case EVENT_ISSUE_QUEUE:     return "to issue queue";
 
5978     case EVENT_START_QUEUE:     return "to start queue";
 
5979     case EVENT_SELECT:          return "selected";
 
5980     case EVENT_DISCONNECT:      return "disconnected";
 
5981     case EVENT_RESELECT:        return "reselected";
 
5982     case EVENT_COMPLETE:        return "completed";
 
5983     case EVENT_IDLE:            return "idle";
 
5984     case EVENT_SELECT_FAILED:   return "select failed";
 
5985     case EVENT_BEFORE_SELECT:   return "before select";
 
5986     case EVENT_RESELECT_FAILED: return "reselect failed";
 
5987     default:                    return "unknown";
 
5992  * Function : void dump_events (struct Scsi_Host *host, count)
 
5994  * Purpose : print last count events which have occurred.
 
5997 dump_events (struct Scsi_Host *host, int count) {
 
5998     struct NCR53c7x0_hostdata *hostdata = (struct NCR53c7x0_hostdata *)
 
6000     struct NCR53c7x0_event event;
 
6002     unsigned long flags;
 
6003     if (hostdata->events) {
 
6004         if (count > hostdata->event_size)
 
6005             count = hostdata->event_size;
 
6006         for (i = hostdata->event_index; count > 0; 
 
6007             i = (i ? i - 1 : hostdata->event_size -1), --count) {
 
6009  * By copying the event we're currently examining with interrupts
 
6010  * disabled, we can do multiple printk(), etc. operations and 
 
6011  * still be guaranteed that they're happening on the same 
 
6014             local_irq_save(flags);
 
6016             event = hostdata->events[i];
 
6018             memcpy ((void *) &event, (void *) &(hostdata->events[i]),
 
6022             local_irq_restore(flags);
 
6023             printk ("scsi%d : %s event %d at %ld secs %ld usecs target %d lun %d\n",
 
6024                 host->host_no, event_name (event.event), count,
 
6025                 (long) event.time.tv_sec, (long) event.time.tv_usec,
 
6026                 event.target, event.lun);
 
6028                 printk ("         event for dsa 0x%lx (virt 0x%p)\n", 
 
6029                     virt_to_bus(event.dsa), event.dsa);
 
6030             if (event.pid != -1) {
 
6031                 printk ("         event for pid %ld ", event.pid);
 
6032                 __scsi_print_command (event.cmnd);
 
6039  * Function: check_address
 
6041  * Purpose: Check to see if a possibly corrupt pointer will fault the 
 
6044  * Inputs: addr - address; size - size of area
 
6046  * Returns: 0 if area is OK, -1 on error.
 
6048  * NOTES: should be implemented in terms of vverify on kernels 
 
6053 check_address (unsigned long addr, int size) {
 
6054     return (virt_to_phys((void *)addr) < PAGE_SIZE || virt_to_phys((void *)(addr + size)) > virt_to_phys(high_memory) ?  -1 : 0);
 
6059 NCR53c7x0_release(struct Scsi_Host *host) {
 
6060     struct NCR53c7x0_hostdata *hostdata = 
 
6061         (struct NCR53c7x0_hostdata *) host->hostdata[0];
 
6062     struct NCR53c7x0_cmd *cmd, *tmp;
 
6064     if (host->irq != SCSI_IRQ_NONE)
 
6067             struct Scsi_Host *tmp;
 
6068             for (irq_count = 0, tmp = first_host; tmp; tmp = tmp->next)
 
6069                 if (tmp->hostt == the_template && tmp->irq == host->irq)
 
6072                 free_irq(host->irq, NULL);
 
6074     if (host->dma_channel != DMA_NONE)
 
6075         free_dma(host->dma_channel);
 
6077         release_region(host->io_port, host->n_io_port);
 
6079     for (cmd = (struct NCR53c7x0_cmd *) hostdata->free; cmd; cmd = tmp, 
 
6080         --hostdata->num_cmds) {
 
6081         tmp = (struct NCR53c7x0_cmd *) cmd->next;
 
6083      * If we're going to loop, try to stop it to get a more accurate
 
6084      * count of the leaked commands.
 
6088             cmd->free ((void *) cmd->real, cmd->size);
 
6090     if (hostdata->num_cmds)
 
6091         printk ("scsi%d : leaked %d NCR53c7x0_cmd structures\n",
 
6092             host->host_no, hostdata->num_cmds);
 
6094     vfree(hostdata->events);
 
6096     /* XXX This assumes default cache mode to be IOMAP_FULL_CACHING, which
 
6097      * XXX may be invalid (CONFIG_060_WRITETHROUGH)
 
6099     kernel_set_cachemode((void *)hostdata, 8192, IOMAP_FULL_CACHING);
 
6100     free_pages ((u32)hostdata, 1);
 
6103 #endif /* def MODULE */