310 lines
7.6 KiB
C
310 lines
7.6 KiB
C
/* $NetBSD: scsireg.h,v 1.12 2008/04/09 15:40:30 tsutsui Exp $ */
|
|
|
|
/*
|
|
* Copyright (c) 1992, 1993
|
|
* The Regents of the University of California. All rights reserved.
|
|
*
|
|
* This code is derived from software contributed to Berkeley by
|
|
* Sony Corp. and Kazumasa Utashiro of Software Research Associates, Inc.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. Neither the name of the University nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* from: $Hdr: scsireg.h,v 4.300 91/06/09 06:38:12 root Rel41 $ SONY
|
|
*
|
|
* @(#)scsireg.h 8.1 (Berkeley) 6/11/93
|
|
*/
|
|
|
|
/*
|
|
* scsireg.h
|
|
*/
|
|
|
|
#ifndef __SCSIREG__
|
|
#define __SCSIREG__ 1
|
|
|
|
/*
|
|
* initiator status byte bit image
|
|
*/
|
|
#define INST_EP 0x80 /* End of Process */
|
|
#define INST_WR 0x40 /* Waiting Reselection */
|
|
#define INST_IP 0x20 /* In Process */
|
|
#define INST_WAIT 0x10 /* Waiting Bus free */
|
|
#define INST_LB 0x8 /* Loss of BUSY */
|
|
#define INST_TO 0x4 /* Time Out */
|
|
#define INST_PRE 0x2 /* PaRameter Error */
|
|
#define INST_HE 0x1 /* Hard Error */
|
|
|
|
#define INSTERMASK 0x7
|
|
|
|
|
|
/*
|
|
* target status byte bit image
|
|
*/
|
|
#define VENDOR 0x61
|
|
#define TGSTMASK 0x1e
|
|
#define TGST_RSVCFLCT 0x18
|
|
#define TGST_INTERMED 0x10
|
|
#define TGST_BUSY 0x8
|
|
#define TGST_CC 0x2
|
|
#define TGST_GOOD 0x0
|
|
|
|
#define TS_MAPPED_PIO 0x01 /* program I/O with map */
|
|
#define TS_CONTR_ON 0x02 /* contiguous transfer on */
|
|
#define TS_CONTR_OFF 0x04 /* contiguous transfer off */
|
|
#define TS_BYTE_DMA 0x08 /* DMA transfer(byte access) */
|
|
#define TS_LONG_DMA 0x10 /* DMA transfer(long access) */
|
|
|
|
|
|
/*
|
|
* message byte
|
|
*/
|
|
#define MSG_IDENT 0x80
|
|
#define MSG_RESELEN 0x40
|
|
#define MSG_CCOMP 0
|
|
#define MSG_EXTND 1
|
|
#define MSG_SDP 2
|
|
#define MSG_RDP 3
|
|
#define MSG_DCNT 4
|
|
#define MSG_IDE 5
|
|
/*#define MSG_ABORT 6*/
|
|
#define MSG_MREJ 7
|
|
#define MSG_NOP 8
|
|
#define MSG_PERROR 9
|
|
|
|
|
|
/*
|
|
* message identify byte bit image
|
|
*/
|
|
#define IDT_DISCON 0x40
|
|
#define IDT_DRMASK 0x7
|
|
|
|
|
|
/*
|
|
* scsi command opcodes
|
|
*/
|
|
#define SCOP_TST 0x00
|
|
#define SCOP_REZERO 0x01
|
|
#define SCOP_REWIND 0x01
|
|
#define SCOP_RSENSE 0x03
|
|
#define SCOP_FMT 0x04
|
|
#define SCOP_RBLIM 0x05
|
|
#define SCOP_SPARAM 0x06
|
|
#define SCOP_RASBLK 0x07
|
|
#define SCOP_READ 0x08
|
|
#define SCOP_MOERASE 0x09
|
|
#define SCOP_WRITE 0x0a
|
|
#define SCOP_SEEK 0x0b
|
|
#define SCOP_MERASE 0x0e
|
|
#define SCOP_WFMARK 0x10
|
|
#define SCOP_SPACE 0x11
|
|
#define SCOP_INQUIRY 0x12
|
|
#define SCOP_SVERIFY 0x13
|
|
#define SCOP_RBDATA 0x14
|
|
#define SCOP_MSELECT 0x15
|
|
#define SCOP_ERASE 0x19
|
|
#define SCOP_MSENSE 0x1a
|
|
#define SCOP_STST 0x1b
|
|
#define SCOP_LOAD 0x1b
|
|
#define SCOP_RECDIAG 0x1c
|
|
#define SCOP_SNDDIAG 0x1d
|
|
#define SCOP_MEDRMV 0x1e
|
|
#define SCOP_RCAP 0x25
|
|
#define SCOP_EREAD 0x28
|
|
#define SCOP_EWRITE 0x2a
|
|
#define SCOP_BSSRCH 0x2c
|
|
#define SCOP_WSSRCH 0x2d
|
|
#define SCOP_WRTVRFY 0x2e
|
|
#define SCOP_VERIFY 0x2f
|
|
#define SCOP_RDL 0x37
|
|
#define SCOP_WBUF 0x3b
|
|
#define SCOP_RBUF 0x3c
|
|
#define SCOP_EJECT 0xc0
|
|
#define SCOP_EESENSE 0xc1
|
|
#define SCOP_READTOC 0xc1
|
|
#define SCOP_READID 0xc2
|
|
#define SCOP_ADP 0xc2
|
|
#define SCOP_READQ 0xc2
|
|
#define SCOP_BLANKS 0xc3
|
|
#define SCOP_READHEAD 0xc3
|
|
#define SCOP_PBSTS 0xc4
|
|
#define SCOP_RCVDISK 0xc4
|
|
#define SCOP_PAUSE 0xc5
|
|
#define SCOP_PLAYTRACK 0xc6
|
|
#define SCOP_PLAYMSF 0xc7
|
|
#define SCOP_PLAYAUDIO 0xc8
|
|
#define SCOP_ERASED 0xe7
|
|
#define SCOP_RESET 0xff
|
|
|
|
|
|
#ifdef CPU_DOUBLE
|
|
# ifdef __mips__
|
|
# define ipc_phys(x) (void *)K0_TT0(x)
|
|
# else
|
|
# define ipc_phys(x) (void *)((int)(x) & ~0x80000000)
|
|
# endif
|
|
# ifdef news3800
|
|
# define splsc spl4
|
|
# define splscon spl3
|
|
# endif
|
|
#endif /* CPU_DOUBLE */
|
|
|
|
#ifdef CPU_SINGLE
|
|
# define ipc_phys(x) (void *)(x)
|
|
# ifdef news3400
|
|
# define splsc splbio /* Lite2 used spl3 */
|
|
# define splscon spl2 XXX not used
|
|
# else
|
|
# define splsc spl4
|
|
# define splscon spl3
|
|
# endif
|
|
#endif /* CPU_SINGLE */
|
|
|
|
#define SCSI_INTEN 1
|
|
#define SCSI_INTDIS 0
|
|
|
|
|
|
/*
|
|
* other definition
|
|
*/
|
|
#define ON 1
|
|
#define OFF 0
|
|
|
|
|
|
/*
|
|
* scsi map table format
|
|
*/
|
|
#if defined(news3400)
|
|
#define NSCMAP 120
|
|
#endif
|
|
|
|
#if defined(news3800)
|
|
#define NSCMAP 129
|
|
#endif
|
|
|
|
struct sc_map {
|
|
volatile uint32_t mp_offset;
|
|
volatile uint32_t mp_pages;
|
|
volatile uint32_t mp_addr[NSCMAP]; /* page number */
|
|
};
|
|
|
|
struct sc_chan_stat {
|
|
struct sc_chan_stat *wb_next; /* wait bus channel queue */
|
|
struct sc_scb *scb; /* scsi struct address */
|
|
u_int stcnt; /* save transfer count */
|
|
uint8_t *spoint; /* save transfer point */
|
|
u_int stag; /* save tag register */
|
|
u_int soffset; /* save offset register */
|
|
int chan_num; /* channel NO. */
|
|
uint8_t comflg; /* flag for save comand pointer */
|
|
uint8_t intr_flg; /* interrupt flag. SCSI_INTEN/INTDIS */
|
|
};
|
|
|
|
struct sc_scb {
|
|
TAILQ_ENTRY(sc_scb) chain;
|
|
struct scsipi_xfer *xs;
|
|
int flags;
|
|
|
|
struct sc_softc *scb_softc;
|
|
struct sc_map *sc_map;
|
|
uint8_t *sc_cpoint; /* pointer to buffer address */
|
|
u_int sc_ctrnscnt; /* transfer count */
|
|
u_int sc_ctag;
|
|
u_int sc_coffset;
|
|
|
|
uint8_t istatus;
|
|
uint8_t tstatus;
|
|
uint8_t identify;
|
|
uint8_t message;
|
|
uint8_t msgbuf[20];
|
|
};
|
|
|
|
#define NTARGET 8
|
|
|
|
struct sc_softc {
|
|
device_t sc_dev;
|
|
struct scsipi_channel sc_channel;
|
|
struct scsipi_adapter sc_adapter;
|
|
|
|
TAILQ_HEAD(scb_list, sc_scb) ready_list, free_list;
|
|
struct sc_scb sc_scb[3 * NTARGET];
|
|
|
|
int inuse[NTARGET];
|
|
struct sc_map sc_map[NTARGET];
|
|
struct sc_chan_stat chan_stat[NTARGET]; /* SCSI channel status */
|
|
int sel_stat[NTARGET]; /* target select status */
|
|
|
|
int scsi_1185AQ;
|
|
int pad_start;
|
|
|
|
int wbc; /* # of channel that is waiting for scsi bus free */
|
|
int wrc; /* # of channel that is waiting for reselection */
|
|
struct sc_chan_stat *ip;
|
|
/* In progress channel. Same as ISTAT.IP */
|
|
int ipc; /* number of in progress channel. */
|
|
int dma_stat; /* OFF = DMAC is not used */
|
|
#define SC_DMAC_RD 1
|
|
#define SC_DMAC_WR 2
|
|
|
|
struct sc_chan_stat *wbq_actf; /* forword active pointer */
|
|
struct sc_chan_stat *wbq_actl; /* last active pointer */
|
|
|
|
uint8_t *act_cmd_pointer;
|
|
uint8_t *min_point[NTARGET];
|
|
int pad_cnt[NTARGET];
|
|
int8_t min_cnt[NTARGET];
|
|
uint8_t sync_tr[NTARGET]; /* sync/async flag */
|
|
uint8_t mout_flag[NTARGET];
|
|
uint8_t perr_flag[NTARGET];
|
|
uint8_t int_stat1;
|
|
uint8_t int_stat2;
|
|
int min_flag;
|
|
int lastcmd;
|
|
};
|
|
|
|
/*
|
|
* sel_stat values
|
|
*/
|
|
#define SEL_WAIT 0
|
|
#define SEL_START 1
|
|
#define SEL_TIMEOUT 2
|
|
#define SEL_ARBF 3
|
|
#define SEL_SUCCESS 4
|
|
#define SEL_RSLD 5
|
|
#define SEL_RSL_WAIT 6
|
|
|
|
/*
|
|
* mout_flag values
|
|
*/
|
|
#define MOUT_IDENTIFY 1
|
|
#define MOUT_SYNC_TR 2
|
|
|
|
|
|
struct scintsw {
|
|
/*00*/ int (*sci_inthandler)(int); /* pointer to interrupt handler */
|
|
/*04*/ int sci_ctlr; /* controller number */
|
|
/*08*/
|
|
};
|
|
|
|
#endif /* !__SCSIREG__ */
|