import of upstream 2.4.34.4 from kernel.org
[linux-2.4.git] / drivers / scsi / AM53C974.h
1 /* AM53/79C974 (PCscsi) driver release 0.5
2
3  * The architecture and much of the code of this device
4  * driver was originally developed by Drew Eckhardt for
5  * the NCR5380. The following copyrights apply:
6  *  For the architecture and all parts similar to the NCR5380:
7  *    Copyright 1993, Drew Eckhardt
8  *      Visionary Computing 
9  *      (Unix and Linux consulting and custom programming)
10  *      drew@colorado.edu
11  *      +1 (303) 666-5836
12  *
13  *  The AM53C974_nobios_detect code was originally developed by
14  *   Robin Cutshaw (robin@xfree86.org) and is used here in a 
15  *   modified form.
16  *
17  *  For the other parts:
18  *    Copyright 1994, D. Frieauff
19  *    EMail: fri@rsx42sun0.dofn.de
20  *    Phone: x49-7545-8-2256 , x49-7541-42305
21  */
22
23 /*
24  * $Log: AM53C974.h,v $
25  */
26
27 #ifndef AM53C974_H
28 #define AM53C974_H
29
30 #include <scsi/scsicam.h>
31
32 struct AM53C974_hostdata {
33         volatile unsigned in_reset:1;   /* flag, says bus reset pending */
34         volatile unsigned aborted:1;    /* flag, says aborted */
35         volatile unsigned selecting:1;  /* selection started, but not yet finished */
36         volatile unsigned disconnecting: 1;     /* disconnection started, but not yet finished */
37         volatile unsigned dma_busy:1;   /* dma busy when service request for info transfer received */
38         volatile unsigned char msgout[10];      /* message to output in MSGOUT_PHASE */
39         volatile unsigned char last_message[10];        /* last message OUT */
40         volatile Scsi_Cmnd *issue_queue;        /* waiting to be issued */
41         volatile Scsi_Cmnd *disconnected_queue;         /* waiting for reconnect */
42         volatile Scsi_Cmnd *sel_cmd;    /* command for selection */
43         volatile Scsi_Cmnd *connected;  /* currently connected command */
44         volatile unsigned char busy[8];         /* index = target, bit = lun */
45         unsigned char sync_per[8];      /* synchronous transfer period (in effect) */
46         unsigned char sync_off[8];      /* synchronous offset (in effect) */
47         unsigned char sync_neg[8];      /* sync. negotiation performed (in effect) */
48         unsigned char sync_en[8];       /* sync. negotiation performed (in effect) */
49         unsigned char max_rate[8];      /* max. transfer rate (setup) */
50         unsigned char max_offset[8];    /* max. sync. offset (setup), only valid if corresponding sync_en is nonzero */
51 };
52
53 #define AM53C974 {                                \
54     proc_name:      "am53c974",                   \
55     name:           "AM53C974",                   \
56     detect:         AM53C974_pci_detect,          \
57     release:        AM53C974_release,             \
58     info:           AM53C974_info,                \
59     command:        AM53C974_command,             \
60     queuecommand:   AM53C974_queue_command,       \
61     abort:          AM53C974_abort,               \
62     reset:          AM53C974_reset,               \
63     bios_param:     scsicam_bios_param,           \
64     can_queue:      12,                           \
65     this_id:        -1,                           \
66     sg_tablesize:   SG_ALL,                       \
67     cmd_per_lun:    1,                            \
68     use_clustering: DISABLE_CLUSTERING            \
69     }
70
71 static int AM53C974_pci_detect(Scsi_Host_Template * tpnt);
72 static int AM53C974_release(struct Scsi_Host *shp);
73 static const char *AM53C974_info(struct Scsi_Host *);
74 static int AM53C974_command(Scsi_Cmnd * SCpnt);
75 static int AM53C974_queue_command(Scsi_Cmnd * cmd, void (*done) (Scsi_Cmnd *));
76 static int AM53C974_abort(Scsi_Cmnd * cmd);
77 static int AM53C974_reset(Scsi_Cmnd * cmd, unsigned int);
78
79 #endif                          /* AM53C974_H */