Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ffd7858d authored by Russell King's avatar Russell King Committed by Russell King
Browse files

[ARM] rpc: acornscsi: convert hardware accessors to take 'AS_Host *'

parent 324b9337
Loading
Loading
Loading
Loading
+120 −123
Original line number Original line Diff line number Diff line
@@ -203,44 +203,41 @@ static void acornscsi_abortcmd(AS_Host *host, unsigned char tag);
 * Miscellaneous
 * Miscellaneous
 */
 */


static inline void
static inline void sbic_arm_write(AS_Host *host, unsigned int reg, unsigned int value)
sbic_arm_write(unsigned int io_port, int reg, int value)
{
{
    __raw_writeb(reg, io_port);
    __raw_writeb(reg, host->scsi.io_port);
    __raw_writeb(value, io_port + 4);
    __raw_writeb(value, host->scsi.io_port + 4);
}
}


#define sbic_arm_writenext(io,val) \
#define sbic_arm_writenext(host,val) \
	__raw_writeb((val), (io) + 4)
	__raw_writeb((val), (host)->scsi.io_port + 4)


static inline
static inline int sbic_arm_read(AS_Host *host, unsigned int reg)
int sbic_arm_read(unsigned int io_port, int reg)
{
{
    if(reg == SBIC_ASR)
    if(reg == SBIC_ASR)
	   return __raw_readl(io_port) & 255;
	   return __raw_readl(host->scsi.io_port) & 255;
    __raw_writeb(reg, io_port);
    __raw_writeb(reg, host->scsi.io_port);
    return __raw_readl(io_port + 4) & 255;
    return __raw_readl(host->scsi.io_port + 4) & 255;
}
}


#define sbic_arm_readnext(io) \
#define sbic_arm_readnext(host) \
	__raw_readb((io) + 4)
	__raw_readb((host)->scsi.io_port + 4)


#ifdef USE_DMAC
#ifdef USE_DMAC
#define dmac_read(io_port,reg) \
#define dmac_read(host,reg) \
	inb((io_port) + (reg))
	inb((host)->dma.io_port + (reg))


#define dmac_write(io_port,reg,value) \
#define dmac_write(host,reg,value) \
	({ outb((value), (io_port) + (reg)); })
	({ outb((value), (host)->dma.io_port + (reg)); })


#define dmac_clearintr(io_port) \
#define dmac_clearintr(host) \
	({ outb(0, (io_port)); })
	({ outb(0, (host)->dma.io_intr_clear); })


static inline
static inline unsigned int dmac_address(AS_Host *host)
unsigned int dmac_address(unsigned int io_port)
{
{
    return dmac_read(io_port, DMAC_TXADRHI) << 16 |
    return dmac_read(host, DMAC_TXADRHI) << 16 |
	   dmac_read(io_port, DMAC_TXADRMD) << 8 |
	   dmac_read(host, DMAC_TXADRMD) << 8 |
	   dmac_read(io_port, DMAC_TXADRLO);
	   dmac_read(host, DMAC_TXADRLO);
}
}


static
static
@@ -248,15 +245,15 @@ void acornscsi_dumpdma(AS_Host *host, char *where)
{
{
	unsigned int mode, addr, len;
	unsigned int mode, addr, len;


	mode = dmac_read(host->dma.io_port, DMAC_MODECON);
	mode = dmac_read(host, DMAC_MODECON);
	addr = dmac_address(host->dma.io_port);
	addr = dmac_address(host);
	len  = dmac_read(host->dma.io_port, DMAC_TXCNTHI) << 8 |
	len  = dmac_read(host, DMAC_TXCNTHI) << 8 |
	       dmac_read(host->dma.io_port, DMAC_TXCNTLO);
	       dmac_read(host, DMAC_TXCNTLO);


	printk("scsi%d: %s: DMAC %02x @%06x+%04x msk %02x, ",
	printk("scsi%d: %s: DMAC %02x @%06x+%04x msk %02x, ",
		host->host->host_no, where,
		host->host->host_no, where,
		mode, addr, (len + 1) & 0xffff,
		mode, addr, (len + 1) & 0xffff,
		dmac_read(host->dma.io_port, DMAC_MASKREG));
		dmac_read(host, DMAC_MASKREG));


	printk("DMA @%06x, ", host->dma.start_addr);
	printk("DMA @%06x, ", host->dma.start_addr);
	printk("BH @%p +%04x, ", host->scsi.SCp.ptr,
	printk("BH @%p +%04x, ", host->scsi.SCp.ptr,
@@ -272,9 +269,9 @@ unsigned long acornscsi_sbic_xfcount(AS_Host *host)
{
{
    unsigned long length;
    unsigned long length;


    length = sbic_arm_read(host->scsi.io_port, SBIC_TRANSCNTH) << 16;
    length = sbic_arm_read(host, SBIC_TRANSCNTH) << 16;
    length |= sbic_arm_readnext(host->scsi.io_port) << 8;
    length |= sbic_arm_readnext(host) << 8;
    length |= sbic_arm_readnext(host->scsi.io_port);
    length |= sbic_arm_readnext(host);


    return length;
    return length;
}
}
@@ -285,7 +282,7 @@ acornscsi_sbic_wait(AS_Host *host, int stat_mask, int stat, int timeout, char *m
	int asr;
	int asr;


	do {
	do {
		asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
		asr = sbic_arm_read(host, SBIC_ASR);


		if ((asr & stat_mask) == stat)
		if ((asr & stat_mask) == stat)
			return 0;
			return 0;
@@ -304,7 +301,7 @@ int acornscsi_sbic_issuecmd(AS_Host *host, int command)
    if (acornscsi_sbic_wait(host, ASR_CIP, 0, 1000, "issuing command"))
    if (acornscsi_sbic_wait(host, ASR_CIP, 0, 1000, "issuing command"))
	return -1;
	return -1;


    sbic_arm_write(host->scsi.io_port, SBIC_CMND, command);
    sbic_arm_write(host, SBIC_CMND, command);


    return 0;
    return 0;
}
}
@@ -353,12 +350,12 @@ void acornscsi_resetcard(AS_Host *host)
	printk("scsi%d: timeout while resetting card\n",
	printk("scsi%d: timeout while resetting card\n",
		host->host->host_no);
		host->host->host_no);


    sbic_arm_read(host->scsi.io_port, SBIC_ASR);
    sbic_arm_read(host, SBIC_ASR);
    sbic_arm_read(host->scsi.io_port, SBIC_SSR);
    sbic_arm_read(host, SBIC_SSR);


    /* setup sbic - WD33C93A */
    /* setup sbic - WD33C93A */
    sbic_arm_write(host->scsi.io_port, SBIC_OWNID, OWNID_EAF | host->host->this_id);
    sbic_arm_write(host, SBIC_OWNID, OWNID_EAF | host->host->this_id);
    sbic_arm_write(host->scsi.io_port, SBIC_CMND, CMND_RESET);
    sbic_arm_write(host, SBIC_CMND, CMND_RESET);


    /*
    /*
     * Command should cause a reset interrupt
     * Command should cause a reset interrupt
@@ -374,26 +371,26 @@ void acornscsi_resetcard(AS_Host *host)
	printk("scsi%d: timeout while resetting card\n",
	printk("scsi%d: timeout while resetting card\n",
		host->host->host_no);
		host->host->host_no);


    sbic_arm_read(host->scsi.io_port, SBIC_ASR);
    sbic_arm_read(host, SBIC_ASR);
    if (sbic_arm_read(host->scsi.io_port, SBIC_SSR) != 0x01)
    if (sbic_arm_read(host, SBIC_SSR) != 0x01)
	printk(KERN_CRIT "scsi%d: WD33C93A didn't give enhanced reset interrupt\n",
	printk(KERN_CRIT "scsi%d: WD33C93A didn't give enhanced reset interrupt\n",
		host->host->host_no);
		host->host->host_no);


    sbic_arm_write(host->scsi.io_port, SBIC_CTRL, INIT_SBICDMA | CTRL_IDI);
    sbic_arm_write(host, SBIC_CTRL, INIT_SBICDMA | CTRL_IDI);
    sbic_arm_write(host->scsi.io_port, SBIC_TIMEOUT, TIMEOUT_TIME);
    sbic_arm_write(host, SBIC_TIMEOUT, TIMEOUT_TIME);
    sbic_arm_write(host->scsi.io_port, SBIC_SYNCHTRANSFER, SYNCHTRANSFER_2DBA);
    sbic_arm_write(host, SBIC_SYNCHTRANSFER, SYNCHTRANSFER_2DBA);
    sbic_arm_write(host->scsi.io_port, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);
    sbic_arm_write(host, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);


    host->card.page_reg = 0x40;
    host->card.page_reg = 0x40;
    outb(host->card.page_reg, host->card.io_page);
    outb(host->card.page_reg, host->card.io_page);


    /* setup dmac - uPC71071 */
    /* setup dmac - uPC71071 */
    dmac_write(host->dma.io_port, DMAC_INIT, 0);
    dmac_write(host, DMAC_INIT, 0);
#ifdef USE_DMAC
#ifdef USE_DMAC
    dmac_write(host->dma.io_port, DMAC_INIT, INIT_8BIT);
    dmac_write(host, DMAC_INIT, INIT_8BIT);
    dmac_write(host->dma.io_port, DMAC_CHANNEL, CHANNEL_0);
    dmac_write(host, DMAC_CHANNEL, CHANNEL_0);
    dmac_write(host->dma.io_port, DMAC_DEVCON0, INIT_DEVCON0);
    dmac_write(host, DMAC_DEVCON0, INIT_DEVCON0);
    dmac_write(host->dma.io_port, DMAC_DEVCON1, INIT_DEVCON1);
    dmac_write(host, DMAC_DEVCON1, INIT_DEVCON1);
#endif
#endif


    host->SCpnt = NULL;
    host->SCpnt = NULL;
@@ -741,9 +738,9 @@ intr_ret_t acornscsi_kick(AS_Host *host)
     * If we have an interrupt pending, then we may have been reselected.
     * If we have an interrupt pending, then we may have been reselected.
     * In this case, we don't want to write to the registers
     * In this case, we don't want to write to the registers
     */
     */
    if (!(sbic_arm_read(host->scsi.io_port, SBIC_ASR) & (ASR_INT|ASR_BSY|ASR_CIP))) {
    if (!(sbic_arm_read(host, SBIC_ASR) & (ASR_INT|ASR_BSY|ASR_CIP))) {
	sbic_arm_write(host->scsi.io_port, SBIC_DESTID, SCpnt->device->id);
	sbic_arm_write(host, SBIC_DESTID, SCpnt->device->id);
	sbic_arm_write(host->scsi.io_port, SBIC_CMND, CMND_SELWITHATN);
	sbic_arm_write(host, SBIC_CMND, CMND_SELWITHATN);
    }
    }


    /*
    /*
@@ -807,7 +804,7 @@ static void acornscsi_done(AS_Host *host, struct scsi_cmnd **SCpntp,
	struct scsi_cmnd *SCpnt = *SCpntp;
	struct scsi_cmnd *SCpnt = *SCpntp;


    /* clean up */
    /* clean up */
    sbic_arm_write(host->scsi.io_port, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);
    sbic_arm_write(host, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);


    host->stats.fins += 1;
    host->stats.fins += 1;


@@ -1008,8 +1005,8 @@ void acornscsi_data_write(AS_Host *host, char *ptr,
static inline
static inline
void acornscsi_dma_stop(AS_Host *host)
void acornscsi_dma_stop(AS_Host *host)
{
{
    dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_ON);
    dmac_write(host, DMAC_MASKREG, MASK_ON);
    dmac_clearintr(host->dma.io_intr_clear);
    dmac_clearintr(host);


#if (DEBUG & DEBUG_DMA)
#if (DEBUG & DEBUG_DMA)
    DBG(host->SCpnt, acornscsi_dumpdma(host, "stop"));
    DBG(host->SCpnt, acornscsi_dumpdma(host, "stop"));
@@ -1031,7 +1028,7 @@ void acornscsi_dma_setup(AS_Host *host, dmadir_t direction)


    host->dma.direction = direction;
    host->dma.direction = direction;


    dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_ON);
    dmac_write(host, DMAC_MASKREG, MASK_ON);


    if (direction == DMA_OUT) {
    if (direction == DMA_OUT) {
#if (DEBUG & DEBUG_NO_WRITE)
#if (DEBUG & DEBUG_NO_WRITE)
@@ -1062,13 +1059,13 @@ void acornscsi_dma_setup(AS_Host *host, dmadir_t direction)
				length);
				length);


	length -= 1;
	length -= 1;
	dmac_write(host->dma.io_port, DMAC_TXCNTLO, length);
	dmac_write(host, DMAC_TXCNTLO, length);
	dmac_write(host->dma.io_port, DMAC_TXCNTHI, length >> 8);
	dmac_write(host, DMAC_TXCNTHI, length >> 8);
	dmac_write(host->dma.io_port, DMAC_TXADRLO, address);
	dmac_write(host, DMAC_TXADRLO, address);
	dmac_write(host->dma.io_port, DMAC_TXADRMD, address >> 8);
	dmac_write(host, DMAC_TXADRMD, address >> 8);
	dmac_write(host->dma.io_port, DMAC_TXADRHI, 0);
	dmac_write(host, DMAC_TXADRHI, 0);
	dmac_write(host->dma.io_port, DMAC_MODECON, mode);
	dmac_write(host, DMAC_MODECON, mode);
	dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_OFF);
	dmac_write(host, DMAC_MASKREG, MASK_OFF);


#if (DEBUG & DEBUG_DMA)
#if (DEBUG & DEBUG_DMA)
	DBG(host->SCpnt, acornscsi_dumpdma(host, "strt"));
	DBG(host->SCpnt, acornscsi_dumpdma(host, "strt"));
@@ -1088,8 +1085,8 @@ void acornscsi_dma_setup(AS_Host *host, dmadir_t direction)
static
static
void acornscsi_dma_cleanup(AS_Host *host)
void acornscsi_dma_cleanup(AS_Host *host)
{
{
    dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_ON);
    dmac_write(host, DMAC_MASKREG, MASK_ON);
    dmac_clearintr(host->dma.io_intr_clear);
    dmac_clearintr(host);


    /*
    /*
     * Check for a pending transfer
     * Check for a pending transfer
@@ -1116,7 +1113,7 @@ void acornscsi_dma_cleanup(AS_Host *host)
	/*
	/*
	 * Calculate number of bytes transferred from DMA.
	 * Calculate number of bytes transferred from DMA.
	 */
	 */
	transferred = dmac_address(host->dma.io_port) - host->dma.start_addr;
	transferred = dmac_address(host) - host->dma.start_addr;
	host->dma.transferred += transferred;
	host->dma.transferred += transferred;


	if (host->dma.direction == DMA_IN)
	if (host->dma.direction == DMA_IN)
@@ -1152,13 +1149,13 @@ void acornscsi_dma_intr(AS_Host *host)
    DBG(host->SCpnt, acornscsi_dumpdma(host, "inti"));
    DBG(host->SCpnt, acornscsi_dumpdma(host, "inti"));
#endif
#endif


    dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_ON);
    dmac_write(host, DMAC_MASKREG, MASK_ON);
    dmac_clearintr(host->dma.io_intr_clear);
    dmac_clearintr(host);


    /*
    /*
     * Calculate amount transferred via DMA
     * Calculate amount transferred via DMA
     */
     */
    transferred = dmac_address(host->dma.io_port) - host->dma.start_addr;
    transferred = dmac_address(host) - host->dma.start_addr;
    host->dma.transferred += transferred;
    host->dma.transferred += transferred;


    /*
    /*
@@ -1190,12 +1187,12 @@ void acornscsi_dma_intr(AS_Host *host)
				length);
				length);


	length -= 1;
	length -= 1;
	dmac_write(host->dma.io_port, DMAC_TXCNTLO, length);
	dmac_write(host, DMAC_TXCNTLO, length);
	dmac_write(host->dma.io_port, DMAC_TXCNTHI, length >> 8);
	dmac_write(host, DMAC_TXCNTHI, length >> 8);
	dmac_write(host->dma.io_port, DMAC_TXADRLO, address);
	dmac_write(host, DMAC_TXADRLO, address);
	dmac_write(host->dma.io_port, DMAC_TXADRMD, address >> 8);
	dmac_write(host, DMAC_TXADRMD, address >> 8);
	dmac_write(host->dma.io_port, DMAC_TXADRHI, 0);
	dmac_write(host, DMAC_TXADRHI, 0);
	dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_OFF);
	dmac_write(host, DMAC_MASKREG, MASK_OFF);


#if (DEBUG & DEBUG_DMA)
#if (DEBUG & DEBUG_DMA)
	DBG(host->SCpnt, acornscsi_dumpdma(host, "into"));
	DBG(host->SCpnt, acornscsi_dumpdma(host, "into"));
@@ -1209,15 +1206,15 @@ void acornscsi_dma_intr(AS_Host *host)
	 * attention condition.  We continue giving one byte until
	 * attention condition.  We continue giving one byte until
	 * the device recognises the attention.
	 * the device recognises the attention.
	 */
	 */
	if (dmac_read(host->dma.io_port, DMAC_STATUS) & STATUS_RQ0) {
	if (dmac_read(host, DMAC_STATUS) & STATUS_RQ0) {
	    acornscsi_abortcmd(host, host->SCpnt->tag);
	    acornscsi_abortcmd(host, host->SCpnt->tag);


	    dmac_write(host->dma.io_port, DMAC_TXCNTLO, 0);
	    dmac_write(host, DMAC_TXCNTLO, 0);
	    dmac_write(host->dma.io_port, DMAC_TXCNTHI, 0);
	    dmac_write(host, DMAC_TXCNTHI, 0);
	    dmac_write(host->dma.io_port, DMAC_TXADRLO, 0);
	    dmac_write(host, DMAC_TXADRLO, 0);
	    dmac_write(host->dma.io_port, DMAC_TXADRMD, 0);
	    dmac_write(host, DMAC_TXADRMD, 0);
	    dmac_write(host->dma.io_port, DMAC_TXADRHI, 0);
	    dmac_write(host, DMAC_TXADRHI, 0);
	    dmac_write(host->dma.io_port, DMAC_MASKREG, MASK_OFF);
	    dmac_write(host, DMAC_MASKREG, MASK_OFF);
	}
	}
#endif
#endif
    }
    }
@@ -1271,9 +1268,9 @@ void acornscsi_dma_adjust(AS_Host *host)
	    host->dma.xfer_setup = 0;
	    host->dma.xfer_setup = 0;
	else {
	else {
	    transferred += host->dma.start_addr;
	    transferred += host->dma.start_addr;
	    dmac_write(host->dma.io_port, DMAC_TXADRLO, transferred);
	    dmac_write(host, DMAC_TXADRLO, transferred);
	    dmac_write(host->dma.io_port, DMAC_TXADRMD, transferred >> 8);
	    dmac_write(host, DMAC_TXADRMD, transferred >> 8);
	    dmac_write(host->dma.io_port, DMAC_TXADRHI, transferred >> 16);
	    dmac_write(host, DMAC_TXADRHI, transferred >> 16);
#if (DEBUG & (DEBUG_DMA|DEBUG_WRITE))
#if (DEBUG & (DEBUG_DMA|DEBUG_WRITE))
	    DBG(host->SCpnt, acornscsi_dumpdma(host, "adjo"));
	    DBG(host->SCpnt, acornscsi_dumpdma(host, "adjo"));
#endif
#endif
@@ -1292,12 +1289,12 @@ acornscsi_write_pio(AS_Host *host, char *bytes, int *ptr, int len, unsigned int
	int my_ptr = *ptr;
	int my_ptr = *ptr;


	while (my_ptr < len) {
	while (my_ptr < len) {
		asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
		asr = sbic_arm_read(host, SBIC_ASR);


		if (asr & ASR_DBR) {
		if (asr & ASR_DBR) {
			timeout = max_timeout;
			timeout = max_timeout;


			sbic_arm_write(host->scsi.io_port, SBIC_DATA, bytes[my_ptr++]);
			sbic_arm_write(host, SBIC_DATA, bytes[my_ptr++]);
		} else if (asr & ASR_INT)
		} else if (asr & ASR_INT)
			break;
			break;
		else if (--timeout == 0)
		else if (--timeout == 0)
@@ -1320,9 +1317,9 @@ acornscsi_sendcommand(AS_Host *host)
{
{
	struct scsi_cmnd *SCpnt = host->SCpnt;
	struct scsi_cmnd *SCpnt = host->SCpnt;


    sbic_arm_write(host->scsi.io_port, SBIC_TRANSCNTH, 0);
    sbic_arm_write(host, SBIC_TRANSCNTH, 0);
    sbic_arm_writenext(host->scsi.io_port, 0);
    sbic_arm_writenext(host, 0);
    sbic_arm_writenext(host->scsi.io_port, SCpnt->cmd_len - host->scsi.SCp.sent_command);
    sbic_arm_writenext(host, SCpnt->cmd_len - host->scsi.SCp.sent_command);


    acornscsi_sbic_issuecmd(host, CMND_XFERINFO);
    acornscsi_sbic_issuecmd(host, CMND_XFERINFO);


@@ -1351,7 +1348,7 @@ void acornscsi_sendmessage(AS_Host *host)


	acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "sending message 1");
	acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "sending message 1");


	sbic_arm_write(host->scsi.io_port, SBIC_DATA, NOP);
	sbic_arm_write(host, SBIC_DATA, NOP);


	host->scsi.last_message = NOP;
	host->scsi.last_message = NOP;
#if (DEBUG & DEBUG_MESSAGES)
#if (DEBUG & DEBUG_MESSAGES)
@@ -1365,7 +1362,7 @@ void acornscsi_sendmessage(AS_Host *host)


	acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "sending message 2");
	acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "sending message 2");


	sbic_arm_write(host->scsi.io_port, SBIC_DATA, msg->msg[0]);
	sbic_arm_write(host, SBIC_DATA, msg->msg[0]);


	host->scsi.last_message = msg->msg[0];
	host->scsi.last_message = msg->msg[0];
#if (DEBUG & DEBUG_MESSAGES)
#if (DEBUG & DEBUG_MESSAGES)
@@ -1382,9 +1379,9 @@ void acornscsi_sendmessage(AS_Host *host)
	 *  initiator.  This provides an interlock so that the
	 *  initiator.  This provides an interlock so that the
	 *  initiator can determine which message byte is rejected.
	 *  initiator can determine which message byte is rejected.
	 */
	 */
	sbic_arm_write(host->scsi.io_port, SBIC_TRANSCNTH, 0);
	sbic_arm_write(host, SBIC_TRANSCNTH, 0);
	sbic_arm_writenext(host->scsi.io_port, 0);
	sbic_arm_writenext(host, 0);
	sbic_arm_writenext(host->scsi.io_port, message_length);
	sbic_arm_writenext(host, message_length);
	acornscsi_sbic_issuecmd(host, CMND_XFERINFO);
	acornscsi_sbic_issuecmd(host, CMND_XFERINFO);


	msgnr = 0;
	msgnr = 0;
@@ -1421,7 +1418,7 @@ void acornscsi_readstatusbyte(AS_Host *host)
{
{
    acornscsi_sbic_issuecmd(host, CMND_XFERINFO|CMND_SBT);
    acornscsi_sbic_issuecmd(host, CMND_XFERINFO|CMND_SBT);
    acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "reading status byte");
    acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "reading status byte");
    host->scsi.SCp.Status = sbic_arm_read(host->scsi.io_port, SBIC_DATA);
    host->scsi.SCp.Status = sbic_arm_read(host, SBIC_DATA);
}
}


/*
/*
@@ -1438,12 +1435,12 @@ unsigned char acornscsi_readmessagebyte(AS_Host *host)


    acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "for message byte");
    acornscsi_sbic_wait(host, ASR_DBR, ASR_DBR, 1000, "for message byte");


    message = sbic_arm_read(host->scsi.io_port, SBIC_DATA);
    message = sbic_arm_read(host, SBIC_DATA);


    /* wait for MSGIN-XFER-PAUSED */
    /* wait for MSGIN-XFER-PAUSED */
    acornscsi_sbic_wait(host, ASR_INT, ASR_INT, 1000, "for interrupt after message byte");
    acornscsi_sbic_wait(host, ASR_INT, ASR_INT, 1000, "for interrupt after message byte");


    sbic_arm_read(host->scsi.io_port, SBIC_SSR);
    sbic_arm_read(host, SBIC_SSR);


    return message;
    return message;
}
}
@@ -1480,7 +1477,7 @@ void acornscsi_message(AS_Host *host)


	    /* wait for next msg-in */
	    /* wait for next msg-in */
	    acornscsi_sbic_wait(host, ASR_INT, ASR_INT, 1000, "for interrupt after negate ack");
	    acornscsi_sbic_wait(host, ASR_INT, ASR_INT, 1000, "for interrupt after negate ack");
	    sbic_arm_read(host->scsi.io_port, SBIC_SSR);
	    sbic_arm_read(host, SBIC_SSR);
	}
	}
    } while (msgidx < msglen);
    } while (msgidx < msglen);


@@ -1602,7 +1599,7 @@ void acornscsi_message(AS_Host *host)
		    host->host->host_no, acornscsi_target(host));
		    host->host->host_no, acornscsi_target(host));
	    host->device[host->SCpnt->device->id].sync_xfer = SYNCHTRANSFER_2DBA;
	    host->device[host->SCpnt->device->id].sync_xfer = SYNCHTRANSFER_2DBA;
	    host->device[host->SCpnt->device->id].sync_state = SYNC_ASYNCHRONOUS;
	    host->device[host->SCpnt->device->id].sync_state = SYNC_ASYNCHRONOUS;
	    sbic_arm_write(host->scsi.io_port, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
	    sbic_arm_write(host, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
	    break;
	    break;


	default:
	default:
@@ -1652,7 +1649,7 @@ void acornscsi_message(AS_Host *host)
		host->device[host->SCpnt->device->id].sync_xfer =
		host->device[host->SCpnt->device->id].sync_xfer =
			calc_sync_xfer(period * 4, length);
			calc_sync_xfer(period * 4, length);
	    }
	    }
	    sbic_arm_write(host->scsi.io_port, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
	    sbic_arm_write(host, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
	    break;
	    break;
#else
#else
	    /* We do not accept synchronous transfers.  Respond with a
	    /* We do not accept synchronous transfers.  Respond with a
@@ -1792,10 +1789,10 @@ int acornscsi_starttransfer(AS_Host *host)


    residual = scsi_bufflen(host->SCpnt) - host->scsi.SCp.scsi_xferred;
    residual = scsi_bufflen(host->SCpnt) - host->scsi.SCp.scsi_xferred;


    sbic_arm_write(host->scsi.io_port, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
    sbic_arm_write(host, SBIC_SYNCHTRANSFER, host->device[host->SCpnt->device->id].sync_xfer);
    sbic_arm_writenext(host->scsi.io_port, residual >> 16);
    sbic_arm_writenext(host, residual >> 16);
    sbic_arm_writenext(host->scsi.io_port, residual >> 8);
    sbic_arm_writenext(host, residual >> 8);
    sbic_arm_writenext(host->scsi.io_port, residual);
    sbic_arm_writenext(host, residual);
    acornscsi_sbic_issuecmd(host, CMND_XFERINFO);
    acornscsi_sbic_issuecmd(host, CMND_XFERINFO);
    return 1;
    return 1;
}
}
@@ -1816,7 +1813,7 @@ int acornscsi_reconnect(AS_Host *host)
{
{
    unsigned int target, lun, ok = 0;
    unsigned int target, lun, ok = 0;


    target = sbic_arm_read(host->scsi.io_port, SBIC_SOURCEID);
    target = sbic_arm_read(host, SBIC_SOURCEID);


    if (!(target & 8))
    if (!(target & 8))
	printk(KERN_ERR "scsi%d: invalid source id after reselection "
	printk(KERN_ERR "scsi%d: invalid source id after reselection "
@@ -1832,7 +1829,7 @@ int acornscsi_reconnect(AS_Host *host)
	host->SCpnt = NULL;
	host->SCpnt = NULL;
    }
    }


    lun = sbic_arm_read(host->scsi.io_port, SBIC_DATA) & 7;
    lun = sbic_arm_read(host, SBIC_DATA) & 7;


    host->scsi.reconnected.target = target;
    host->scsi.reconnected.target = target;
    host->scsi.reconnected.lun = lun;
    host->scsi.reconnected.lun = lun;
@@ -1952,7 +1949,7 @@ static
void acornscsi_abortcmd(AS_Host *host, unsigned char tag)
void acornscsi_abortcmd(AS_Host *host, unsigned char tag)
{
{
    host->scsi.phase = PHASE_ABORTED;
    host->scsi.phase = PHASE_ABORTED;
    sbic_arm_write(host->scsi.io_port, SBIC_CMND, CMND_ASSERTATN);
    sbic_arm_write(host, SBIC_CMND, CMND_ASSERTATN);


    msgqueue_flush(&host->scsi.msgs);
    msgqueue_flush(&host->scsi.msgs);
#ifdef CONFIG_SCSI_ACORNSCSI_TAGGED_QUEUE
#ifdef CONFIG_SCSI_ACORNSCSI_TAGGED_QUEUE
@@ -1979,11 +1976,11 @@ intr_ret_t acornscsi_sbicintr(AS_Host *host, int in_irq)
{
{
    unsigned int asr, ssr;
    unsigned int asr, ssr;


    asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
    asr = sbic_arm_read(host, SBIC_ASR);
    if (!(asr & ASR_INT))
    if (!(asr & ASR_INT))
	return INTR_IDLE;
	return INTR_IDLE;


    ssr = sbic_arm_read(host->scsi.io_port, SBIC_SSR);
    ssr = sbic_arm_read(host, SBIC_SSR);


#if (DEBUG & DEBUG_PHASES)
#if (DEBUG & DEBUG_PHASES)
    print_sbic_status(asr, ssr, host->scsi.phase);
    print_sbic_status(asr, ssr, host->scsi.phase);
@@ -1999,15 +1996,15 @@ intr_ret_t acornscsi_sbicintr(AS_Host *host, int in_irq)
	printk(KERN_ERR "scsi%d: reset in standard mode but wanted advanced mode.\n",
	printk(KERN_ERR "scsi%d: reset in standard mode but wanted advanced mode.\n",
		host->host->host_no);
		host->host->host_no);
	/* setup sbic - WD33C93A */
	/* setup sbic - WD33C93A */
	sbic_arm_write(host->scsi.io_port, SBIC_OWNID, OWNID_EAF | host->host->this_id);
	sbic_arm_write(host, SBIC_OWNID, OWNID_EAF | host->host->this_id);
	sbic_arm_write(host->scsi.io_port, SBIC_CMND, CMND_RESET);
	sbic_arm_write(host, SBIC_CMND, CMND_RESET);
	return INTR_IDLE;
	return INTR_IDLE;


    case 0x01:				/* reset state - advanced			*/
    case 0x01:				/* reset state - advanced			*/
	sbic_arm_write(host->scsi.io_port, SBIC_CTRL, INIT_SBICDMA | CTRL_IDI);
	sbic_arm_write(host, SBIC_CTRL, INIT_SBICDMA | CTRL_IDI);
	sbic_arm_write(host->scsi.io_port, SBIC_TIMEOUT, TIMEOUT_TIME);
	sbic_arm_write(host, SBIC_TIMEOUT, TIMEOUT_TIME);
	sbic_arm_write(host->scsi.io_port, SBIC_SYNCHTRANSFER, SYNCHTRANSFER_2DBA);
	sbic_arm_write(host, SBIC_SYNCHTRANSFER, SYNCHTRANSFER_2DBA);
	sbic_arm_write(host->scsi.io_port, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);
	sbic_arm_write(host, SBIC_SOURCEID, SOURCEID_ER | SOURCEID_DSP);
	msgqueue_flush(&host->scsi.msgs);
	msgqueue_flush(&host->scsi.msgs);
	return INTR_IDLE;
	return INTR_IDLE;


@@ -2025,10 +2022,10 @@ intr_ret_t acornscsi_sbicintr(AS_Host *host, int in_irq)
	    msgqueue_flush(&host->scsi.msgs);
	    msgqueue_flush(&host->scsi.msgs);
	    host->dma.transferred = host->scsi.SCp.scsi_xferred;
	    host->dma.transferred = host->scsi.SCp.scsi_xferred;
	    /* 33C93 gives next interrupt indicating bus phase */
	    /* 33C93 gives next interrupt indicating bus phase */
	    asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
	    asr = sbic_arm_read(host, SBIC_ASR);
	    if (!(asr & ASR_INT))
	    if (!(asr & ASR_INT))
		break;
		break;
	    ssr = sbic_arm_read(host->scsi.io_port, SBIC_SSR);
	    ssr = sbic_arm_read(host, SBIC_SSR);
	    ADD_STATUS(8, ssr, host->scsi.phase, 1);
	    ADD_STATUS(8, ssr, host->scsi.phase, 1);
	    ADD_STATUS(host->SCpnt->device->id, ssr, host->scsi.phase, 1);
	    ADD_STATUS(host->SCpnt->device->id, ssr, host->scsi.phase, 1);
	    goto connected;
	    goto connected;
@@ -2655,7 +2652,7 @@ static enum res_abort acornscsi_do_abort(AS_Host *host, struct scsi_cmnd *SCpnt)
		 * busylun bit.
		 * busylun bit.
		 */
		 */
		case PHASE_CONNECTED:
		case PHASE_CONNECTED:
			sbic_arm_write(host->scsi.io_port, SBIC_CMND, CMND_DISCONNECT);
			sbic_arm_write(host, SBIC_CMND, CMND_DISCONNECT);
			host->SCpnt = NULL;
			host->SCpnt = NULL;
			res = res_success_clear;
			res = res_success_clear;
			break;
			break;
@@ -2699,8 +2696,8 @@ int acornscsi_abort(struct scsi_cmnd *SCpnt)
#if (DEBUG & DEBUG_ABORT)
#if (DEBUG & DEBUG_ABORT)
	{
	{
		int asr, ssr;
		int asr, ssr;
		asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
		asr = sbic_arm_read(host, SBIC_ASR);
		ssr = sbic_arm_read(host->scsi.io_port, SBIC_SSR);
		ssr = sbic_arm_read(host, SBIC_SSR);


		printk(KERN_WARNING "acornscsi_abort: ");
		printk(KERN_WARNING "acornscsi_abort: ");
		print_sbic_status(asr, ssr, host->scsi.phase);
		print_sbic_status(asr, ssr, host->scsi.phase);
@@ -2780,8 +2777,8 @@ int acornscsi_bus_reset(struct scsi_cmnd *SCpnt)
    {
    {
	int asr, ssr;
	int asr, ssr;


	asr = sbic_arm_read(host->scsi.io_port, SBIC_ASR);
	asr = sbic_arm_read(host, SBIC_ASR);
	ssr = sbic_arm_read(host->scsi.io_port, SBIC_SSR);
	ssr = sbic_arm_read(host, SBIC_SSR);


	printk(KERN_WARNING "acornscsi_reset: ");
	printk(KERN_WARNING "acornscsi_reset: ");
	print_sbic_status(asr, ssr, host->scsi.phase);
	print_sbic_status(asr, ssr, host->scsi.phase);