2005-04-17 02:20:36 +04:00
/*
* Generic Generic NCR5380 driver defines
*
* Copyright 1993 , Drew Eckhardt
* Visionary Computing
* ( Unix and Linux consulting and custom programming )
* drew @ colorado . edu
* + 1 ( 303 ) 440 - 4894
*
* NCR53C400 extensions ( c ) 1994 , 1995 , 1996 , Kevin Lentin
* K . Lentin @ cs . monash . edu . au
*/
# ifndef GENERIC_NCR5380_H
# define GENERIC_NCR5380_H
# ifdef NCR53C400
# define BIOSPARAM
# define NCR5380_BIOSPARAM generic_NCR5380_biosparam
# else
# define NCR5380_BIOSPARAM NULL
# endif
# ifndef CMD_PER_LUN
# define CMD_PER_LUN 2
# endif
# ifndef CAN_QUEUE
# define CAN_QUEUE 16
# endif
# define __STRVAL(x) #x
# define STRVAL(x) __STRVAL(x)
2010-08-11 05:01:16 +04:00
# ifndef SCSI_G_NCR5380_MEM
2005-04-17 02:20:36 +04:00
# define NCR5380_map_type int
# define NCR5380_map_name port
# define NCR53C400_register_offset 0
# define NCR53C400_address_adjust 8
# ifdef NCR53C400
# define NCR5380_region_size 16
# else
# define NCR5380_region_size 8
# endif
2016-01-03 08:05:06 +03:00
# define NCR5380_read(reg) \
inb ( instance - > io_port + ( reg ) )
# define NCR5380_write(reg, value) \
outb ( value , instance - > io_port + ( reg ) )
2005-04-17 02:20:36 +04:00
2016-01-03 08:05:06 +03:00
# define NCR5380_implementation_fields /* none */
2006-03-24 14:15:37 +03:00
2005-04-17 02:20:36 +04:00
# else
2010-08-11 05:01:16 +04:00
/* therefore SCSI_G_NCR5380_MEM */
2005-04-17 02:20:36 +04:00
# define NCR5380_map_type unsigned long
# define NCR5380_map_name base
# define NCR53C400_register_offset 0x108
# define NCR53C400_address_adjust 0
# define NCR53C400_mem_base 0x3880
# define NCR53C400_host_buffer 0x3900
# define NCR5380_region_size 0x3a00
2016-01-03 08:05:06 +03:00
# define NCR5380_read(reg) \
readb ( ( ( struct NCR5380_hostdata * ) shost_priv ( instance ) ) - > iomem + \
NCR53C400_mem_base + ( reg ) )
# define NCR5380_write(reg, value) \
writeb ( value , ( ( struct NCR5380_hostdata * ) shost_priv ( instance ) ) - > iomem + \
NCR53C400_mem_base + ( reg ) )
2005-04-17 02:20:36 +04:00
# define NCR5380_implementation_fields \
2006-03-24 14:15:37 +03:00
void __iomem * iomem ;
2005-04-17 02:20:36 +04:00
2006-03-24 14:15:37 +03:00
# endif
2005-04-17 02:20:36 +04:00
# define NCR5380_intr generic_NCR5380_intr
# define NCR5380_queue_command generic_NCR5380_queue_command
# define NCR5380_abort generic_NCR5380_abort
# define NCR5380_bus_reset generic_NCR5380_bus_reset
# define NCR5380_pread generic_NCR5380_pread
# define NCR5380_pwrite generic_NCR5380_pwrite
2014-11-12 08:11:58 +03:00
# define NCR5380_info generic_NCR5380_info
# define NCR5380_show_info generic_NCR5380_show_info
2005-04-17 02:20:36 +04:00
# define BOARD_NCR5380 0
# define BOARD_NCR53C400 1
# define BOARD_NCR53C400A 2
# define BOARD_DTC3181E 3
# endif /* GENERIC_NCR5380_H */