mirror of
https://github.com/torvalds/linux.git
synced 2024-12-31 23:31:29 +00:00
f281233d3e
Move the mid-layer's ->queuecommand() invocation from being locked with the host lock to being unlocked to facilitate speeding up the critical path for drivers who don't need this lock taken anyway. The patch below presents a simple SCSI host lock push-down as an equivalent transformation. No locking or other behavior should change with this patch. All existing bugs and locking orders are preserved. Additionally, add one parameter to queuecommand, struct Scsi_Host * and remove one parameter from queuecommand, void (*done)(struct scsi_cmnd *) Scsi_Host* is a convenient pointer that most host drivers need anyway, and 'done' is redundant to struct scsi_cmnd->scsi_done. Minimal code disturbance was attempted with this change. Most drivers needed only two one-line modifications for their host lock push-down. Signed-off-by: Jeff Garzik <jgarzik@redhat.com> Acked-by: James Bottomley <James.Bottomley@suse.de> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
100 lines
2.6 KiB
C
100 lines
2.6 KiB
C
/*
|
|
* DTC controller, taken from T128 driver by...
|
|
* Copyright 1993, Drew Eckhardt
|
|
* Visionary Computing
|
|
* (Unix and Linux consulting and custom programming)
|
|
* drew@colorado.edu
|
|
* +1 (303) 440-4894
|
|
*
|
|
* DISTRIBUTION RELEASE 2.
|
|
*
|
|
* For more information, please consult
|
|
*
|
|
*
|
|
*
|
|
* and
|
|
*
|
|
* NCR 5380 Family
|
|
* SCSI Protocol Controller
|
|
* Databook
|
|
*
|
|
* NCR Microelectronics
|
|
* 1635 Aeroplaza Drive
|
|
* Colorado Springs, CO 80916
|
|
* 1+ (719) 578-3400
|
|
* 1+ (800) 334-5454
|
|
*/
|
|
|
|
#ifndef DTC3280_H
|
|
#define DTC3280_H
|
|
|
|
#define DTCDEBUG 0
|
|
#define DTCDEBUG_INIT 0x1
|
|
#define DTCDEBUG_TRANSFER 0x2
|
|
|
|
static int dtc_abort(Scsi_Cmnd *);
|
|
static int dtc_biosparam(struct scsi_device *, struct block_device *,
|
|
sector_t, int*);
|
|
static int dtc_detect(struct scsi_host_template *);
|
|
static int dtc_queue_command(struct Scsi_Host *, struct scsi_cmnd *);
|
|
static int dtc_bus_reset(Scsi_Cmnd *);
|
|
|
|
#ifndef CMD_PER_LUN
|
|
#define CMD_PER_LUN 2
|
|
#endif
|
|
|
|
#ifndef CAN_QUEUE
|
|
#define CAN_QUEUE 32
|
|
#endif
|
|
|
|
#define NCR5380_implementation_fields \
|
|
void __iomem *base
|
|
|
|
#define NCR5380_local_declare() \
|
|
void __iomem *base
|
|
|
|
#define NCR5380_setup(instance) \
|
|
base = ((struct NCR5380_hostdata *)(instance)->hostdata)->base
|
|
|
|
#define DTC_address(reg) (base + DTC_5380_OFFSET + reg)
|
|
|
|
#define dbNCR5380_read(reg) \
|
|
(rval=readb(DTC_address(reg)), \
|
|
(((unsigned char) printk("DTC : read register %d at addr %p is: %02x\n"\
|
|
, (reg), DTC_address(reg), rval)), rval ) )
|
|
|
|
#define dbNCR5380_write(reg, value) do { \
|
|
printk("DTC : write %02x to register %d at address %p\n", \
|
|
(value), (reg), DTC_address(reg)); \
|
|
writeb(value, DTC_address(reg));} while(0)
|
|
|
|
|
|
#if !(DTCDEBUG & DTCDEBUG_TRANSFER)
|
|
#define NCR5380_read(reg) (readb(DTC_address(reg)))
|
|
#define NCR5380_write(reg, value) (writeb(value, DTC_address(reg)))
|
|
#else
|
|
#define NCR5380_read(reg) (readb(DTC_address(reg)))
|
|
#define xNCR5380_read(reg) \
|
|
(((unsigned char) printk("DTC : read register %d at address %p\n"\
|
|
, (reg), DTC_address(reg))), readb(DTC_address(reg)))
|
|
|
|
#define NCR5380_write(reg, value) do { \
|
|
printk("DTC : write %02x to register %d at address %p\n", \
|
|
(value), (reg), DTC_address(reg)); \
|
|
writeb(value, DTC_address(reg));} while(0)
|
|
#endif
|
|
|
|
#define NCR5380_intr dtc_intr
|
|
#define NCR5380_queue_command dtc_queue_command
|
|
#define NCR5380_abort dtc_abort
|
|
#define NCR5380_bus_reset dtc_bus_reset
|
|
#define NCR5380_proc_info dtc_proc_info
|
|
|
|
/* 15 12 11 10
|
|
1001 1100 0000 0000 */
|
|
|
|
#define DTC_IRQS 0x9c00
|
|
|
|
|
|
#endif /* DTC3280_H */
|