Commit 6c4b88ca authored by Finn Thain's avatar Finn Thain Committed by Martin K. Petersen

ncr5380: Use DMA hooks for PDMA

Those wrapper drivers which use DMA define the REAL_DMA macro and
those which use pseudo DMA define PSEUDO_DMA. These macros need to be
removed for a number of reasons, not least of which is to have drivers
share more code.

Redefine the PDMA send and receive hooks as DMA setup hooks, so that the
DMA code can be shared by all 5380 wrapper drivers. This will help to
reunify the forked core driver.
Signed-off-by: default avatarFinn Thain <fthain@telegraphics.com.au>
Reviewed-by: default avatarHannes Reinecke <hare@suse.com>
Tested-by: default avatarMichael Schmitz <schmitzmic@gmail.com>
Tested-by: default avatarOndrej Zary <linux@rainbow-software.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent e5d55d1a
...@@ -127,17 +127,11 @@ ...@@ -127,17 +127,11 @@
* specific implementation of the NCR5380 * specific implementation of the NCR5380
* *
* Either real DMA *or* pseudo DMA may be implemented * Either real DMA *or* pseudo DMA may be implemented
* Note that the DMA setup functions should return the number of bytes
* that they were able to program the controller for.
* *
* NCR5380_dma_write_setup(instance, src, count) - initialize * NCR5380_dma_write_setup(instance, src, count) - initialize
* NCR5380_dma_read_setup(instance, dst, count) - initialize * NCR5380_dma_read_setup(instance, dst, count) - initialize
* NCR5380_dma_residual(instance); - residual count * NCR5380_dma_residual(instance); - residual count
* *
* PSEUDO functions :
* NCR5380_pwrite(instance, src, count)
* NCR5380_pread(instance, dst, count);
*
* The generic driver is initialized by calling NCR5380_init(instance), * The generic driver is initialized by calling NCR5380_init(instance),
* after setting the appropriate host specific fields and ID. If the * after setting the appropriate host specific fields and ID. If the
* driver wishes to autoprobe for an IRQ line, the NCR5380_probe_irq(instance, * driver wishes to autoprobe for an IRQ line, the NCR5380_probe_irq(instance,
...@@ -1511,7 +1505,7 @@ static int NCR5380_transfer_dma(struct Scsi_Host *instance, ...@@ -1511,7 +1505,7 @@ static int NCR5380_transfer_dma(struct Scsi_Host *instance,
*/ */
if (p & SR_IO) { if (p & SR_IO) {
foo = NCR5380_pread(instance, d, foo = NCR5380_dma_recv_setup(instance, d,
hostdata->flags & FLAG_DMA_FIXUP ? c - 1 : c); hostdata->flags & FLAG_DMA_FIXUP ? c - 1 : c);
if (!foo && (hostdata->flags & FLAG_DMA_FIXUP)) { if (!foo && (hostdata->flags & FLAG_DMA_FIXUP)) {
/* /*
...@@ -1542,7 +1536,7 @@ static int NCR5380_transfer_dma(struct Scsi_Host *instance, ...@@ -1542,7 +1536,7 @@ static int NCR5380_transfer_dma(struct Scsi_Host *instance,
d[c - 1] = NCR5380_read(INPUT_DATA_REG); d[c - 1] = NCR5380_read(INPUT_DATA_REG);
} }
} else { } else {
foo = NCR5380_pwrite(instance, d, c); foo = NCR5380_dma_send_setup(instance, d, c);
if (!foo && (hostdata->flags & FLAG_DMA_FIXUP)) { if (!foo && (hostdata->flags & FLAG_DMA_FIXUP)) {
/* /*
* Wait for the last byte to be sent. If REQ is being asserted for * Wait for the last byte to be sent. If REQ is being asserted for
......
...@@ -18,6 +18,8 @@ ...@@ -18,6 +18,8 @@
#define NCR5380_write(reg, value) cumanascsi_write(instance, reg, value) #define NCR5380_write(reg, value) cumanascsi_write(instance, reg, value)
#define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize) #define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize)
#define NCR5380_dma_recv_setup cumanascsi_pread
#define NCR5380_dma_send_setup cumanascsi_pwrite
#define NCR5380_intr cumanascsi_intr #define NCR5380_intr cumanascsi_intr
#define NCR5380_queue_command cumanascsi_queue_command #define NCR5380_queue_command cumanascsi_queue_command
...@@ -39,8 +41,8 @@ void cumanascsi_setup(char *str, int *ints) ...@@ -39,8 +41,8 @@ void cumanascsi_setup(char *str, int *ints)
#define L(v) (((v)<<16)|((v) & 0x0000ffff)) #define L(v) (((v)<<16)|((v) & 0x0000ffff))
#define H(v) (((v)>>16)|((v) & 0xffff0000)) #define H(v) (((v)>>16)|((v) & 0xffff0000))
static inline int static inline int cumanascsi_pwrite(struct Scsi_Host *host,
NCR5380_pwrite(struct Scsi_Host *host, unsigned char *addr, int len) unsigned char *addr, int len)
{ {
unsigned long *laddr; unsigned long *laddr;
void __iomem *dma = priv(host)->dma + 0x2000; void __iomem *dma = priv(host)->dma + 0x2000;
...@@ -102,8 +104,8 @@ NCR5380_pwrite(struct Scsi_Host *host, unsigned char *addr, int len) ...@@ -102,8 +104,8 @@ NCR5380_pwrite(struct Scsi_Host *host, unsigned char *addr, int len)
return len; return len;
} }
static inline int static inline int cumanascsi_pread(struct Scsi_Host *host,
NCR5380_pread(struct Scsi_Host *host, unsigned char *addr, int len) unsigned char *addr, int len)
{ {
unsigned long *laddr; unsigned long *laddr;
void __iomem *dma = priv(host)->dma + 0x2000; void __iomem *dma = priv(host)->dma + 0x2000;
......
...@@ -24,6 +24,8 @@ ...@@ -24,6 +24,8 @@
writeb(value, priv(instance)->base + ((reg) << 2)) writeb(value, priv(instance)->base + ((reg) << 2))
#define NCR5380_dma_xfer_len(instance, cmd, phase) (0) #define NCR5380_dma_xfer_len(instance, cmd, phase) (0)
#define NCR5380_dma_recv_setup oakscsi_pread
#define NCR5380_dma_send_setup oakscsi_pwrite
#define NCR5380_queue_command oakscsi_queue_command #define NCR5380_queue_command oakscsi_queue_command
#define NCR5380_info oakscsi_info #define NCR5380_info oakscsi_info
...@@ -39,8 +41,8 @@ ...@@ -39,8 +41,8 @@
#define STAT ((128 + 16) << 2) #define STAT ((128 + 16) << 2)
#define DATA ((128 + 8) << 2) #define DATA ((128 + 8) << 2)
static inline int NCR5380_pwrite(struct Scsi_Host *instance, unsigned char *addr, static inline int oakscsi_pwrite(struct Scsi_Host *instance,
int len) unsigned char *addr, int len)
{ {
void __iomem *base = priv(instance)->base; void __iomem *base = priv(instance)->base;
...@@ -54,8 +56,8 @@ printk("writing %p len %d\n",addr, len); ...@@ -54,8 +56,8 @@ printk("writing %p len %d\n",addr, len);
} }
} }
static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *addr, static inline int oakscsi_pread(struct Scsi_Host *instance,
int len) unsigned char *addr, int len)
{ {
void __iomem *base = priv(instance)->base; void __iomem *base = priv(instance)->base;
printk("reading %p len %d\n", addr, len); printk("reading %p len %d\n", addr, len);
......
...@@ -40,8 +40,8 @@ ...@@ -40,8 +40,8 @@
#define NCR5380_write(reg, value) outb(value, instance->io_port + reg) #define NCR5380_write(reg, value) outb(value, instance->io_port + reg)
#define NCR5380_dma_xfer_len(instance, cmd, phase) (0) #define NCR5380_dma_xfer_len(instance, cmd, phase) (0)
#define NCR5380_pread(instance, dst, len) (0) #define NCR5380_dma_recv_setup(instance, dst, len) (0)
#define NCR5380_pwrite(instance, src, len) (0) #define NCR5380_dma_send_setup(instance, src, len) (0)
#define NCR5380_implementation_fields /* none */ #define NCR5380_implementation_fields /* none */
......
...@@ -322,7 +322,8 @@ static int dtc_biosparam(struct scsi_device *sdev, struct block_device *dev, ...@@ -322,7 +322,8 @@ static int dtc_biosparam(struct scsi_device *sdev, struct block_device *dev,
* timeout. * timeout.
*/ */
static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len) static inline int dtc_pread(struct Scsi_Host *instance,
unsigned char *dst, int len)
{ {
unsigned char *d = dst; unsigned char *d = dst;
int i; /* For counting time spent in the poll-loop */ int i; /* For counting time spent in the poll-loop */
...@@ -367,7 +368,8 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, ...@@ -367,7 +368,8 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst,
* timeout. * timeout.
*/ */
static inline int NCR5380_pwrite(struct Scsi_Host *instance, unsigned char *src, int len) static inline int dtc_pwrite(struct Scsi_Host *instance,
unsigned char *src, int len)
{ {
int i; int i;
struct NCR5380_hostdata *hostdata = shost_priv(instance); struct NCR5380_hostdata *hostdata = shost_priv(instance);
......
...@@ -21,6 +21,8 @@ ...@@ -21,6 +21,8 @@
#define NCR5380_dma_xfer_len(instance, cmd, phase) \ #define NCR5380_dma_xfer_len(instance, cmd, phase) \
dtc_dma_xfer_len(cmd) dtc_dma_xfer_len(cmd)
#define NCR5380_dma_recv_setup dtc_pread
#define NCR5380_dma_send_setup dtc_pwrite
#define NCR5380_intr dtc_intr #define NCR5380_intr dtc_intr
#define NCR5380_queue_command dtc_queue_command #define NCR5380_queue_command dtc_queue_command
......
...@@ -551,7 +551,7 @@ static int generic_NCR5380_release_resources(struct Scsi_Host *instance) ...@@ -551,7 +551,7 @@ static int generic_NCR5380_release_resources(struct Scsi_Host *instance)
} }
/** /**
* NCR5380_pread - pseudo DMA read * generic_NCR5380_pread - pseudo DMA read
* @instance: adapter to read from * @instance: adapter to read from
* @dst: buffer to read into * @dst: buffer to read into
* @len: buffer length * @len: buffer length
...@@ -560,7 +560,8 @@ static int generic_NCR5380_release_resources(struct Scsi_Host *instance) ...@@ -560,7 +560,8 @@ static int generic_NCR5380_release_resources(struct Scsi_Host *instance)
* controller * controller
*/ */
static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len) static inline int generic_NCR5380_pread(struct Scsi_Host *instance,
unsigned char *dst, int len)
{ {
struct NCR5380_hostdata *hostdata = shost_priv(instance); struct NCR5380_hostdata *hostdata = shost_priv(instance);
int blocks = len / 128; int blocks = len / 128;
...@@ -628,7 +629,7 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, ...@@ -628,7 +629,7 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst,
} }
/** /**
* NCR5380_write - pseudo DMA write * generic_NCR5380_pwrite - pseudo DMA write
* @instance: adapter to read from * @instance: adapter to read from
* @dst: buffer to read into * @dst: buffer to read into
* @len: buffer length * @len: buffer length
...@@ -637,7 +638,8 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, ...@@ -637,7 +638,8 @@ static inline int NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst,
* controller * controller
*/ */
static inline int NCR5380_pwrite(struct Scsi_Host *instance, unsigned char *src, int len) static inline int generic_NCR5380_pwrite(struct Scsi_Host *instance,
unsigned char *src, int len)
{ {
struct NCR5380_hostdata *hostdata = shost_priv(instance); struct NCR5380_hostdata *hostdata = shost_priv(instance);
int blocks = len / 128; int blocks = len / 128;
......
...@@ -62,13 +62,13 @@ ...@@ -62,13 +62,13 @@
#define NCR5380_dma_xfer_len(instance, cmd, phase) \ #define NCR5380_dma_xfer_len(instance, cmd, phase) \
generic_NCR5380_dma_xfer_len(instance, cmd) generic_NCR5380_dma_xfer_len(instance, cmd)
#define NCR5380_dma_recv_setup generic_NCR5380_pread
#define NCR5380_dma_send_setup generic_NCR5380_pwrite
#define NCR5380_intr generic_NCR5380_intr #define NCR5380_intr generic_NCR5380_intr
#define NCR5380_queue_command generic_NCR5380_queue_command #define NCR5380_queue_command generic_NCR5380_queue_command
#define NCR5380_abort generic_NCR5380_abort #define NCR5380_abort generic_NCR5380_abort
#define NCR5380_bus_reset generic_NCR5380_bus_reset #define NCR5380_bus_reset generic_NCR5380_bus_reset
#define NCR5380_pread generic_NCR5380_pread
#define NCR5380_pwrite generic_NCR5380_pwrite
#define NCR5380_info generic_NCR5380_info #define NCR5380_info generic_NCR5380_info
#define NCR5380_io_delay(x) udelay(x) #define NCR5380_io_delay(x) udelay(x)
......
...@@ -33,11 +33,10 @@ ...@@ -33,11 +33,10 @@
#define NCR5380_read(reg) macscsi_read(instance, reg) #define NCR5380_read(reg) macscsi_read(instance, reg)
#define NCR5380_write(reg, value) macscsi_write(instance, reg, value) #define NCR5380_write(reg, value) macscsi_write(instance, reg, value)
#define NCR5380_pread macscsi_pread
#define NCR5380_pwrite macscsi_pwrite
#define NCR5380_dma_xfer_len(instance, cmd, phase) \ #define NCR5380_dma_xfer_len(instance, cmd, phase) \
macscsi_dma_xfer_len(instance, cmd) macscsi_dma_xfer_len(instance, cmd)
#define NCR5380_dma_recv_setup macscsi_pread
#define NCR5380_dma_send_setup macscsi_pwrite
#define NCR5380_intr macscsi_intr #define NCR5380_intr macscsi_intr
#define NCR5380_queue_command macscsi_queue_command #define NCR5380_queue_command macscsi_queue_command
......
...@@ -458,7 +458,7 @@ static int pas16_biosparam(struct scsi_device *sdev, struct block_device *dev, ...@@ -458,7 +458,7 @@ static int pas16_biosparam(struct scsi_device *sdev, struct block_device *dev,
} }
/* /*
* Function : int NCR5380_pread (struct Scsi_Host *instance, * Function : int pas16_pread (struct Scsi_Host *instance,
* unsigned char *dst, int len) * unsigned char *dst, int len)
* *
* Purpose : Fast 5380 pseudo-dma read function, transfers len bytes to * Purpose : Fast 5380 pseudo-dma read function, transfers len bytes to
...@@ -470,8 +470,9 @@ static int pas16_biosparam(struct scsi_device *sdev, struct block_device *dev, ...@@ -470,8 +470,9 @@ static int pas16_biosparam(struct scsi_device *sdev, struct block_device *dev,
* timeout. * timeout.
*/ */
static inline int NCR5380_pread (struct Scsi_Host *instance, unsigned char *dst, static inline int pas16_pread(struct Scsi_Host *instance,
int len) { unsigned char *dst, int len)
{
register unsigned char *d = dst; register unsigned char *d = dst;
register unsigned short reg = (unsigned short) (instance->io_port + register unsigned short reg = (unsigned short) (instance->io_port +
P_DATA_REG_OFFSET); P_DATA_REG_OFFSET);
...@@ -493,7 +494,7 @@ static inline int NCR5380_pread (struct Scsi_Host *instance, unsigned char *dst, ...@@ -493,7 +494,7 @@ static inline int NCR5380_pread (struct Scsi_Host *instance, unsigned char *dst,
} }
/* /*
* Function : int NCR5380_pwrite (struct Scsi_Host *instance, * Function : int pas16_pwrite (struct Scsi_Host *instance,
* unsigned char *src, int len) * unsigned char *src, int len)
* *
* Purpose : Fast 5380 pseudo-dma write function, transfers len bytes from * Purpose : Fast 5380 pseudo-dma write function, transfers len bytes from
...@@ -505,8 +506,9 @@ static inline int NCR5380_pread (struct Scsi_Host *instance, unsigned char *dst, ...@@ -505,8 +506,9 @@ static inline int NCR5380_pread (struct Scsi_Host *instance, unsigned char *dst,
* timeout. * timeout.
*/ */
static inline int NCR5380_pwrite (struct Scsi_Host *instance, unsigned char *src, static inline int pas16_pwrite(struct Scsi_Host *instance,
int len) { unsigned char *src, int len)
{
register unsigned char *s = src; register unsigned char *s = src;
register unsigned short reg = (instance->io_port + P_DATA_REG_OFFSET); register unsigned short reg = (instance->io_port + P_DATA_REG_OFFSET);
register int i = len; register int i = len;
......
...@@ -103,6 +103,8 @@ ...@@ -103,6 +103,8 @@
#define NCR5380_write(reg, value) ( outb((value),PAS16_io_port(reg)) ) #define NCR5380_write(reg, value) ( outb((value),PAS16_io_port(reg)) )
#define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize) #define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize)
#define NCR5380_dma_recv_setup pas16_pread
#define NCR5380_dma_send_setup pas16_pwrite
#define NCR5380_intr pas16_intr #define NCR5380_intr pas16_intr
#define NCR5380_queue_command pas16_queue_command #define NCR5380_queue_command pas16_queue_command
......
...@@ -292,7 +292,7 @@ static int t128_biosparam(struct scsi_device *sdev, struct block_device *bdev, ...@@ -292,7 +292,7 @@ static int t128_biosparam(struct scsi_device *sdev, struct block_device *bdev,
} }
/* /*
* Function : int NCR5380_pread (struct Scsi_Host *instance, * Function : int t128_pread (struct Scsi_Host *instance,
* unsigned char *dst, int len) * unsigned char *dst, int len)
* *
* Purpose : Fast 5380 pseudo-dma read function, transfers len bytes to * Purpose : Fast 5380 pseudo-dma read function, transfers len bytes to
...@@ -304,8 +304,8 @@ static int t128_biosparam(struct scsi_device *sdev, struct block_device *bdev, ...@@ -304,8 +304,8 @@ static int t128_biosparam(struct scsi_device *sdev, struct block_device *bdev,
* timeout. * timeout.
*/ */
static inline int static inline int t128_pread(struct Scsi_Host *instance,
NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len) unsigned char *dst, int len)
{ {
struct NCR5380_hostdata *hostdata = shost_priv(instance); struct NCR5380_hostdata *hostdata = shost_priv(instance);
void __iomem *reg, *base = hostdata->base; void __iomem *reg, *base = hostdata->base;
...@@ -338,7 +338,7 @@ NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len) ...@@ -338,7 +338,7 @@ NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len)
} }
/* /*
* Function : int NCR5380_pwrite (struct Scsi_Host *instance, * Function : int t128_pwrite (struct Scsi_Host *instance,
* unsigned char *src, int len) * unsigned char *src, int len)
* *
* Purpose : Fast 5380 pseudo-dma write function, transfers len bytes from * Purpose : Fast 5380 pseudo-dma write function, transfers len bytes from
...@@ -350,8 +350,8 @@ NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len) ...@@ -350,8 +350,8 @@ NCR5380_pread(struct Scsi_Host *instance, unsigned char *dst, int len)
* timeout. * timeout.
*/ */
static inline int static inline int t128_pwrite(struct Scsi_Host *instance,
NCR5380_pwrite(struct Scsi_Host *instance, unsigned char *src, int len) unsigned char *src, int len)
{ {
struct NCR5380_hostdata *hostdata = shost_priv(instance); struct NCR5380_hostdata *hostdata = shost_priv(instance);
void __iomem *reg, *base = hostdata->base; void __iomem *reg, *base = hostdata->base;
......
...@@ -77,6 +77,8 @@ ...@@ -77,6 +77,8 @@
#define NCR5380_write(reg, value) writeb((value),(T128_address(reg))) #define NCR5380_write(reg, value) writeb((value),(T128_address(reg)))
#define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize) #define NCR5380_dma_xfer_len(instance, cmd, phase) (cmd->transfersize)
#define NCR5380_dma_recv_setup t128_pread
#define NCR5380_dma_send_setup t128_pwrite
#define NCR5380_intr t128_intr #define NCR5380_intr t128_intr
#define NCR5380_queue_command t128_queue_command #define NCR5380_queue_command t128_queue_command
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment