xref: /rk3399_rockchip-uboot/include/scsi.h (revision 19d1d41e844ea8525f527fd5301aba9eb3006241)
1e85390dcSwdenk /*
2e85390dcSwdenk  * (C) Copyright 2001
3e85390dcSwdenk  * Denis Peter, MPL AG Switzerland
4e85390dcSwdenk  *
5e85390dcSwdenk  * See file CREDITS for list of people who contributed to this
6e85390dcSwdenk  * project.
7e85390dcSwdenk  *
8e85390dcSwdenk  * This program is free software; you can redistribute it and/or
9e85390dcSwdenk  * modify it under the terms of the GNU General Public License as
10e85390dcSwdenk  * published by the Free Software Foundation; either version 2 of
11e85390dcSwdenk  * the License, or (at your option) any later version.
12e85390dcSwdenk  *
13e85390dcSwdenk  * This program is distributed in the hope that it will be useful,
14e85390dcSwdenk  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15e85390dcSwdenk  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16e85390dcSwdenk  * GNU General Public License for more details.
17e85390dcSwdenk  *
18e85390dcSwdenk  * You should have received a copy of the GNU General Public License
19e85390dcSwdenk  * along with this program; if not, write to the Free Software
20e85390dcSwdenk  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21e85390dcSwdenk  * MA 02111-1307 USA
22e85390dcSwdenk  *
23e85390dcSwdenk  */
24e85390dcSwdenk  #ifndef _SCSI_H
25e85390dcSwdenk  #define _SCSI_H
26e85390dcSwdenk 
27e85390dcSwdenk typedef struct SCSI_cmd_block{
28e85390dcSwdenk 	unsigned char		cmd[16];					/* command				   */
29f5766139SPuneet Saxena 	/* for request sense */
30f5766139SPuneet Saxena 	unsigned char		sense_buf[64]
31f5766139SPuneet Saxena 		__attribute__((aligned(ARCH_DMA_MINALIGN)));
32e85390dcSwdenk 	unsigned char		status;						/* SCSI Status			 */
33e85390dcSwdenk 	unsigned char		target;						/* Target ID				 */
34e85390dcSwdenk 	unsigned char		lun;							/* Target LUN        */
35e85390dcSwdenk 	unsigned char		cmdlen;						/* command len				*/
36e85390dcSwdenk 	unsigned long		datalen;					/* Total data length	*/
37e85390dcSwdenk 	unsigned char	*	pdata;						/* pointer to data		*/
38e85390dcSwdenk 	unsigned char		msgout[12];				/* Messge out buffer (NOT USED) */
39e85390dcSwdenk 	unsigned char		msgin[12];				/* Message in buffer	*/
40e85390dcSwdenk 	unsigned char		sensecmdlen;			/* Sense command len	*/
41e85390dcSwdenk 	unsigned long		sensedatalen;			/* Sense data len			*/
42e85390dcSwdenk 	unsigned char		sensecmd[6];			/* Sense command			*/
43e85390dcSwdenk 	unsigned long		contr_stat;				/* Controller Status	*/
44e85390dcSwdenk 	unsigned long		trans_bytes;			/* tranfered bytes		*/
45e85390dcSwdenk 
46e85390dcSwdenk 	unsigned int		priv;
47e85390dcSwdenk }ccb;
48e85390dcSwdenk 
49e85390dcSwdenk /*-----------------------------------------------------------
50e85390dcSwdenk **
51e85390dcSwdenk **	SCSI  constants.
52e85390dcSwdenk **
53e85390dcSwdenk **-----------------------------------------------------------
54e85390dcSwdenk */
55e85390dcSwdenk 
56e85390dcSwdenk /*
57e85390dcSwdenk **	Messages
58e85390dcSwdenk */
59e85390dcSwdenk 
60e85390dcSwdenk #define	M_COMPLETE	(0x00)
61e85390dcSwdenk #define	M_EXTENDED	(0x01)
62e85390dcSwdenk #define	M_SAVE_DP	(0x02)
63e85390dcSwdenk #define	M_RESTORE_DP	(0x03)
64e85390dcSwdenk #define	M_DISCONNECT	(0x04)
65e85390dcSwdenk #define	M_ID_ERROR	(0x05)
66e85390dcSwdenk #define	M_ABORT		(0x06)
67e85390dcSwdenk #define	M_REJECT	(0x07)
68e85390dcSwdenk #define	M_NOOP		(0x08)
69e85390dcSwdenk #define	M_PARITY	(0x09)
70e85390dcSwdenk #define	M_LCOMPLETE	(0x0a)
71e85390dcSwdenk #define	M_FCOMPLETE	(0x0b)
72e85390dcSwdenk #define	M_RESET		(0x0c)
73e85390dcSwdenk #define	M_ABORT_TAG	(0x0d)
74e85390dcSwdenk #define	M_CLEAR_QUEUE	(0x0e)
75e85390dcSwdenk #define	M_INIT_REC	(0x0f)
76e85390dcSwdenk #define	M_REL_REC	(0x10)
77e85390dcSwdenk #define	M_TERMINATE	(0x11)
78e85390dcSwdenk #define	M_SIMPLE_TAG	(0x20)
79e85390dcSwdenk #define	M_HEAD_TAG	(0x21)
80e85390dcSwdenk #define	M_ORDERED_TAG	(0x22)
81e85390dcSwdenk #define	M_IGN_RESIDUE	(0x23)
82e85390dcSwdenk #define	M_IDENTIFY	(0x80)
83e85390dcSwdenk 
84e85390dcSwdenk #define	M_X_MODIFY_DP	(0x00)
85e85390dcSwdenk #define	M_X_SYNC_REQ	(0x01)
86e85390dcSwdenk #define	M_X_WIDE_REQ	(0x03)
87e85390dcSwdenk #define	M_X_PPR_REQ	(0x04)
88e85390dcSwdenk 
89e85390dcSwdenk 
90e85390dcSwdenk /*
91e85390dcSwdenk **	Status
92e85390dcSwdenk */
93e85390dcSwdenk 
94e85390dcSwdenk #define	S_GOOD		(0x00)
95e85390dcSwdenk #define	S_CHECK_COND	(0x02)
96e85390dcSwdenk #define	S_COND_MET	(0x04)
97e85390dcSwdenk #define	S_BUSY		(0x08)
98e85390dcSwdenk #define	S_INT		(0x10)
99e85390dcSwdenk #define	S_INT_COND_MET	(0x14)
100e85390dcSwdenk #define	S_CONFLICT	(0x18)
101e85390dcSwdenk #define	S_TERMINATED	(0x20)
102e85390dcSwdenk #define	S_QUEUE_FULL	(0x28)
103e85390dcSwdenk #define	S_ILLEGAL	(0xff)
104e85390dcSwdenk #define	S_SENSE		(0x80)
105e85390dcSwdenk 
106e85390dcSwdenk /*
107e85390dcSwdenk  * Sense_keys
108e85390dcSwdenk  */
109e85390dcSwdenk 
110e85390dcSwdenk #define SENSE_NO_SENSE				0x0
111e85390dcSwdenk #define SENSE_RECOVERED_ERROR	0x1
112e85390dcSwdenk #define SENSE_NOT_READY				0x2
113e85390dcSwdenk #define SENSE_MEDIUM_ERROR		0x3
114e85390dcSwdenk #define SENSE_HARDWARE_ERROR	0x4
115e85390dcSwdenk #define SENSE_ILLEGAL_REQUEST	0x5
116e85390dcSwdenk #define SENSE_UNIT_ATTENTION	0x6
117e85390dcSwdenk #define SENSE_DATA_PROTECT		0x7
118e85390dcSwdenk #define SENSE_BLANK_CHECK			0x8
119e85390dcSwdenk #define SENSE_VENDOR_SPECIFIC	0x9
120e85390dcSwdenk #define SENSE_COPY_ABORTED		0xA
121e85390dcSwdenk #define SENSE_ABORTED_COMMAND	0xB
122e85390dcSwdenk #define SENSE_VOLUME_OVERFLOW	0xD
123e85390dcSwdenk #define SENSE_MISCOMPARE			0xE
124e85390dcSwdenk 
125e85390dcSwdenk 
126e85390dcSwdenk #define SCSI_CHANGE_DEF	0x40		/* Change Definition (Optional) */
127e85390dcSwdenk #define SCSI_COMPARE		0x39		/* Compare (O) */
128e85390dcSwdenk #define SCSI_COPY			0x18		/* Copy (O) */
129e85390dcSwdenk #define SCSI_COP_VERIFY	0x3A		/* Copy and Verify (O) */
130e85390dcSwdenk #define SCSI_INQUIRY		0x12		/* Inquiry (MANDATORY) */
131e85390dcSwdenk #define SCSI_LOG_SELECT	0x4C		/* Log Select (O) */
132e85390dcSwdenk #define SCSI_LOG_SENSE	0x4D		/* Log Sense (O) */
133e85390dcSwdenk #define SCSI_MODE_SEL6	0x15		/* Mode Select 6-byte (Device Specific) */
134e85390dcSwdenk #define SCSI_MODE_SEL10	0x55		/* Mode Select 10-byte (Device Specific) */
135e85390dcSwdenk #define SCSI_MODE_SEN6	0x1A		/* Mode Sense 6-byte (Device Specific) */
136e85390dcSwdenk #define SCSI_MODE_SEN10	0x5A		/* Mode Sense 10-byte (Device Specific) */
137e85390dcSwdenk #define SCSI_READ_BUFF	0x3C		/* Read Buffer (O) */
138e85390dcSwdenk #define SCSI_REQ_SENSE	0x03		/* Request Sense (MANDATORY) */
139e85390dcSwdenk #define SCSI_SEND_DIAG	0x1D		/* Send Diagnostic (O) */
140e85390dcSwdenk #define SCSI_TST_U_RDY	0x00		/* Test Unit Ready (MANDATORY) */
141e85390dcSwdenk #define SCSI_WRITE_BUFF	0x3B		/* Write Buffer (O) */
142e85390dcSwdenk /***************************************************************************
143e85390dcSwdenk  *			  %%% Commands Unique to Direct Access Devices %%%
144e85390dcSwdenk  ***************************************************************************/
145e85390dcSwdenk #define SCSI_COMPARE		0x39		/* Compare (O) */
146e85390dcSwdenk #define SCSI_FORMAT		0x04		/* Format Unit (MANDATORY) */
147e85390dcSwdenk #define SCSI_LCK_UN_CAC	0x36		/* Lock Unlock Cache (O) */
148e85390dcSwdenk #define SCSI_PREFETCH	0x34		/* Prefetch (O) */
149e85390dcSwdenk #define SCSI_MED_REMOVL	0x1E		/* Prevent/Allow medium Removal (O) */
150e85390dcSwdenk #define SCSI_READ6		0x08		/* Read 6-byte (MANDATORY) */
151e85390dcSwdenk #define SCSI_READ10		0x28		/* Read 10-byte (MANDATORY) */
152e85390dcSwdenk #define SCSI_RD_CAPAC	0x25		/* Read Capacity (MANDATORY) */
153*19d1d41eSGabe Black #define SCSI_RD_CAPAC10	SCSI_RD_CAPAC	/* Read Capacity (10) */
154*19d1d41eSGabe Black #define SCSI_RD_CAPAC16	0x9e		/* Read Capacity (16) */
155e85390dcSwdenk #define SCSI_RD_DEFECT	0x37		/* Read Defect Data (O) */
156e85390dcSwdenk #define SCSI_READ_LONG	0x3E		/* Read Long (O) */
157e85390dcSwdenk #define SCSI_REASS_BLK	0x07		/* Reassign Blocks (O) */
158e85390dcSwdenk #define SCSI_RCV_DIAG	0x1C		/* Receive Diagnostic Results (O) */
159e85390dcSwdenk #define SCSI_RELEASE	0x17		/* Release Unit (MANDATORY) */
160e85390dcSwdenk #define SCSI_REZERO		0x01		/* Rezero Unit (O) */
161e85390dcSwdenk #define SCSI_SRCH_DAT_E	0x31		/* Search Data Equal (O) */
162e85390dcSwdenk #define SCSI_SRCH_DAT_H	0x30		/* Search Data High (O) */
163e85390dcSwdenk #define SCSI_SRCH_DAT_L	0x32		/* Search Data Low (O) */
164e85390dcSwdenk #define SCSI_SEEK6		0x0B		/* Seek 6-Byte (O) */
165e85390dcSwdenk #define SCSI_SEEK10		0x2B		/* Seek 10-Byte (O) */
166e85390dcSwdenk #define SCSI_SEND_DIAG	0x1D		/* Send Diagnostics (MANDATORY) */
167e85390dcSwdenk #define SCSI_SET_LIMIT	0x33		/* Set Limits (O) */
168e85390dcSwdenk #define SCSI_START_STP	0x1B		/* Start/Stop Unit (O) */
169e85390dcSwdenk #define SCSI_SYNC_CACHE	0x35		/* Synchronize Cache (O) */
170e85390dcSwdenk #define SCSI_VERIFY		0x2F		/* Verify (O) */
171e85390dcSwdenk #define SCSI_WRITE6		0x0A		/* Write 6-Byte (MANDATORY) */
172e85390dcSwdenk #define SCSI_WRITE10	0x2A		/* Write 10-Byte (MANDATORY) */
173e85390dcSwdenk #define SCSI_WRT_VERIFY	0x2E		/* Write and Verify (O) */
174e85390dcSwdenk #define SCSI_WRITE_LONG	0x3F		/* Write Long (O) */
175e85390dcSwdenk #define SCSI_WRITE_SAME	0x41		/* Write Same (O) */
176e85390dcSwdenk 
177e85390dcSwdenk 
178e85390dcSwdenk /****************************************************************************
179e85390dcSwdenk  * decleration of functions which have to reside in the LowLevel Part Driver
180e85390dcSwdenk  */
181e85390dcSwdenk 
182e85390dcSwdenk void scsi_print_error(ccb *pccb);
183e85390dcSwdenk int scsi_exec(ccb *pccb);
184e85390dcSwdenk void scsi_bus_reset(void);
185e85390dcSwdenk void scsi_low_level_init(int busdevfunc);
186e85390dcSwdenk 
187e85390dcSwdenk 
188e85390dcSwdenk /***************************************************************************
189e85390dcSwdenk  * functions residing inside cmd_scsi.c
190e85390dcSwdenk  */
191e85390dcSwdenk void scsi_init(void);
192942e3143SRob Herring void scsi_scan(int mode);
193e85390dcSwdenk 
194447c031bSStefan Reinauer /** @return the number of scsi disks */
195447c031bSStefan Reinauer int scsi_get_disk_count(void);
196e85390dcSwdenk 
197e85390dcSwdenk #define SCSI_IDENTIFY					0xC0  /* not used */
198e85390dcSwdenk 
199e85390dcSwdenk /* Hardware errors  */
200e85390dcSwdenk #define SCSI_SEL_TIME_OUT			 0x00000101	 /* Selection time out */
201e85390dcSwdenk #define SCSI_HNS_TIME_OUT			 0x00000102  /* Handshake */
202e85390dcSwdenk #define SCSI_MA_TIME_OUT			 0x00000103  /* Phase error */
203e85390dcSwdenk #define SCSI_UNEXP_DIS				 0x00000104  /* unexpected disconnect */
204e85390dcSwdenk 
205e85390dcSwdenk #define SCSI_INT_STATE				 0x00010000  /* unknown Interrupt number is stored in 16 LSB */
206e85390dcSwdenk 
207e85390dcSwdenk 
208e85390dcSwdenk #ifndef TRUE
209e85390dcSwdenk #define TRUE 1
210e85390dcSwdenk #endif
211e85390dcSwdenk #ifndef FALSE
212e85390dcSwdenk #define FALSE 0
213e85390dcSwdenk #endif
214e85390dcSwdenk 
215e85390dcSwdenk #endif /* _SCSI_H */
216