/*
|
/*
|
* Cumana Generic NCR5380 driver defines
|
* Cumana Generic NCR5380 driver defines
|
*
|
*
|
* Copyright 1993, Drew Eckhardt
|
* Copyright 1993, Drew Eckhardt
|
* Visionary Computing
|
* Visionary Computing
|
* (Unix and Linux consulting and custom programming)
|
* (Unix and Linux consulting and custom programming)
|
* drew@colorado.edu
|
* drew@colorado.edu
|
* +1 (303) 440-4894
|
* +1 (303) 440-4894
|
*
|
*
|
* ALPHA RELEASE 1.
|
* ALPHA RELEASE 1.
|
*
|
*
|
* For more information, please consult
|
* For more information, please consult
|
*
|
*
|
* NCR 5380 Family
|
* NCR 5380 Family
|
* SCSI Protocol Controller
|
* SCSI Protocol Controller
|
* Databook
|
* Databook
|
*
|
*
|
* NCR Microelectronics
|
* NCR Microelectronics
|
* 1635 Aeroplaza Drive
|
* 1635 Aeroplaza Drive
|
* Colorado Springs, CO 80916
|
* Colorado Springs, CO 80916
|
* 1+ (719) 578-3400
|
* 1+ (719) 578-3400
|
* 1+ (800) 334-5454
|
* 1+ (800) 334-5454
|
*/
|
*/
|
|
|
/*
|
/*
|
* $Log: not supported by cvs2svn $
|
* $Log: not supported by cvs2svn $
|
* Revision 1.1.1.1 2001/09/10 07:43:54 simons
|
* Revision 1.1.1.1 2001/09/10 07:43:54 simons
|
* Initial import
|
* Initial import
|
*
|
*
|
* Revision 1.1.1.1 2001/07/02 17:58:40 simons
|
* Revision 1.1.1.1 2001/07/02 17:58:40 simons
|
* Initial revision
|
* Initial revision
|
*
|
*
|
* Revision 1.1.1.1 1999/11/15 13:42:32 vadim
|
* Revision 1.1.1.1 1999/11/15 13:42:32 vadim
|
* Initial import
|
* Initial import
|
*
|
*
|
*/
|
*/
|
|
|
#ifndef OAK_NCR5380_H
|
#ifndef OAK_NCR5380_H
|
#define OAK_NCR5380_H
|
#define OAK_NCR5380_H
|
|
|
#define OAKSCSI_PUBLIC_RELEASE 1
|
#define OAKSCSI_PUBLIC_RELEASE 1
|
|
|
|
|
#ifndef ASM
|
#ifndef ASM
|
int oakscsi_abort(Scsi_Cmnd *);
|
int oakscsi_abort(Scsi_Cmnd *);
|
int oakscsi_detect(Scsi_Host_Template *);
|
int oakscsi_detect(Scsi_Host_Template *);
|
int oakscsi_release(struct Scsi_Host *);
|
int oakscsi_release(struct Scsi_Host *);
|
const char *oakscsi_info(struct Scsi_Host *);
|
const char *oakscsi_info(struct Scsi_Host *);
|
int oakscsi_reset(Scsi_Cmnd *, unsigned int);
|
int oakscsi_reset(Scsi_Cmnd *, unsigned int);
|
int oakscsi_queue_command(Scsi_Cmnd *, void (*done)(Scsi_Cmnd *));
|
int oakscsi_queue_command(Scsi_Cmnd *, void (*done)(Scsi_Cmnd *));
|
int oakscsi_proc_info (char *buffer, char **start, off_t off,
|
int oakscsi_proc_info (char *buffer, char **start, off_t off,
|
int length, int hostno, int inout);
|
int length, int hostno, int inout);
|
|
|
#ifndef NULL
|
#ifndef NULL
|
#define NULL 0
|
#define NULL 0
|
#endif
|
#endif
|
|
|
#ifndef CMD_PER_LUN
|
#ifndef CMD_PER_LUN
|
#define CMD_PER_LUN 2
|
#define CMD_PER_LUN 2
|
#endif
|
#endif
|
|
|
#ifndef CAN_QUEUE
|
#ifndef CAN_QUEUE
|
#define CAN_QUEUE 16
|
#define CAN_QUEUE 16
|
#endif
|
#endif
|
|
|
#define OAK_NCR5380 { \
|
#define OAK_NCR5380 { \
|
NULL, /* ptr for modules */ \
|
NULL, /* ptr for modules */ \
|
NULL, /* usage count for modules */ \
|
NULL, /* usage count for modules */ \
|
NULL, \
|
NULL, \
|
oakscsi_proc_info, \
|
oakscsi_proc_info, \
|
"Oak 16-bit SCSI", \
|
"Oak 16-bit SCSI", \
|
oakscsi_detect, \
|
oakscsi_detect, \
|
oakscsi_release, /* Release */ \
|
oakscsi_release, /* Release */ \
|
oakscsi_info, \
|
oakscsi_info, \
|
NULL, \
|
NULL, \
|
oakscsi_queue_command, \
|
oakscsi_queue_command, \
|
oakscsi_abort, \
|
oakscsi_abort, \
|
oakscsi_reset, \
|
oakscsi_reset, \
|
NULL, \
|
NULL, \
|
NULL, /* Biosparam */ \
|
NULL, /* Biosparam */ \
|
CAN_QUEUE, /* can queue */ \
|
CAN_QUEUE, /* can queue */ \
|
7, /* id */ \
|
7, /* id */ \
|
SG_ALL, /* sg_tablesize */ \
|
SG_ALL, /* sg_tablesize */ \
|
CMD_PER_LUN, /* cmd per lun */ \
|
CMD_PER_LUN, /* cmd per lun */ \
|
0, /* number of boards */ \
|
0, /* number of boards */ \
|
0, /* unchecked isa dma */ \
|
0, /* unchecked isa dma */ \
|
DISABLE_CLUSTERING \
|
DISABLE_CLUSTERING \
|
}
|
}
|
|
|
#ifndef HOSTS_C
|
#ifndef HOSTS_C
|
#define NCR5380_implementation_fields \
|
#define NCR5380_implementation_fields \
|
int port, ctrl
|
int port, ctrl
|
|
|
#define NCR5380_local_declare() \
|
#define NCR5380_local_declare() \
|
struct Scsi_Host *_instance
|
struct Scsi_Host *_instance
|
|
|
#define NCR5380_setup(instance) \
|
#define NCR5380_setup(instance) \
|
_instance = instance
|
_instance = instance
|
|
|
#define NCR5380_read(reg) oakscsi_read(_instance, reg)
|
#define NCR5380_read(reg) oakscsi_read(_instance, reg)
|
#define NCR5380_write(reg, value) oakscsi_write(_instance, reg, value)
|
#define NCR5380_write(reg, value) oakscsi_write(_instance, reg, value)
|
#define NCR5380_intr oakscsi_intr
|
#define NCR5380_intr oakscsi_intr
|
#define NCR5380_queue_command oakscsi_queue_command
|
#define NCR5380_queue_command oakscsi_queue_command
|
#define NCR5380_abort oakscsi_abort
|
#define NCR5380_abort oakscsi_abort
|
#define NCR5380_reset oakscsi_reset
|
#define NCR5380_reset oakscsi_reset
|
#define NCR5380_proc_info oakscsi_proc_info
|
#define NCR5380_proc_info oakscsi_proc_info
|
|
|
#define BOARD_NORMAL 0
|
#define BOARD_NORMAL 0
|
#define BOARD_NCR53C400 1
|
#define BOARD_NCR53C400 1
|
|
|
#endif /* else def HOSTS_C */
|
#endif /* else def HOSTS_C */
|
#endif /* ndef ASM */
|
#endif /* ndef ASM */
|
#endif /* OAK_NCR5380_H */
|
#endif /* OAK_NCR5380_H */
|
|
|
|
|