xref: /dflybsd-src/sys/dev/raid/twa/tw_cl_fwif.h (revision 1e0dd9dd32a69a1d3bbe6a9e41c3a63aae59fb4d)
1df54c2f9SSascha Wildner /*
2df54c2f9SSascha Wildner  * Copyright (c) 2004-07 Applied Micro Circuits Corporation.
3df54c2f9SSascha Wildner  * Copyright (c) 2004-05 Vinod Kashyap
4df54c2f9SSascha Wildner  * All rights reserved.
5df54c2f9SSascha Wildner  *
6df54c2f9SSascha Wildner  * Redistribution and use in source and binary forms, with or without
7df54c2f9SSascha Wildner  * modification, are permitted provided that the following conditions
8df54c2f9SSascha Wildner  * are met:
9df54c2f9SSascha Wildner  * 1. Redistributions of source code must retain the above copyright
10df54c2f9SSascha Wildner  *    notice, this list of conditions and the following disclaimer.
11df54c2f9SSascha Wildner  * 2. Redistributions in binary form must reproduce the above copyright
12df54c2f9SSascha Wildner  *    notice, this list of conditions and the following disclaimer in the
13df54c2f9SSascha Wildner  *    documentation and/or other materials provided with the distribution.
14df54c2f9SSascha Wildner  *
15df54c2f9SSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16df54c2f9SSascha Wildner  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17df54c2f9SSascha Wildner  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18df54c2f9SSascha Wildner  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19df54c2f9SSascha Wildner  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20df54c2f9SSascha Wildner  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21df54c2f9SSascha Wildner  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22df54c2f9SSascha Wildner  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23df54c2f9SSascha Wildner  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24df54c2f9SSascha Wildner  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25df54c2f9SSascha Wildner  * SUCH DAMAGE.
26df54c2f9SSascha Wildner  *
27*1e0dd9ddSSascha Wildner  *	$FreeBSD: head/sys/dev/twa/tw_cl_fwif.h 212008 2010-08-30 19:15:04Z delphij $
28df54c2f9SSascha Wildner  */
29df54c2f9SSascha Wildner 
30df54c2f9SSascha Wildner /*
31df54c2f9SSascha Wildner  * AMCC'S 3ware driver for 9000 series storage controllers.
32df54c2f9SSascha Wildner  *
33df54c2f9SSascha Wildner  * Author: Vinod Kashyap
34df54c2f9SSascha Wildner  * Modifications by: Adam Radford
35df54c2f9SSascha Wildner  */
36df54c2f9SSascha Wildner 
37df54c2f9SSascha Wildner 
38df54c2f9SSascha Wildner 
39df54c2f9SSascha Wildner #ifndef TW_CL_FWIF_H
40df54c2f9SSascha Wildner 
41df54c2f9SSascha Wildner #define TW_CL_FWIF_H
42df54c2f9SSascha Wildner 
43df54c2f9SSascha Wildner 
44df54c2f9SSascha Wildner /*
45df54c2f9SSascha Wildner  * Macros and data structures for interfacing with the firmware.
46df54c2f9SSascha Wildner  */
47df54c2f9SSascha Wildner 
48df54c2f9SSascha Wildner 
49df54c2f9SSascha Wildner /* Register offsets from base address. */
50df54c2f9SSascha Wildner #define	TWA_CONTROL_REGISTER_OFFSET		0x0
51df54c2f9SSascha Wildner #define	TWA_STATUS_REGISTER_OFFSET		0x4
52df54c2f9SSascha Wildner #define	TWA_COMMAND_QUEUE_OFFSET		0x8
53df54c2f9SSascha Wildner #define	TWA_RESPONSE_QUEUE_OFFSET		0xC
54df54c2f9SSascha Wildner #define	TWA_COMMAND_QUEUE_OFFSET_LOW		0x20
55df54c2f9SSascha Wildner #define	TWA_COMMAND_QUEUE_OFFSET_HIGH		0x24
56df54c2f9SSascha Wildner #define	TWA_LARGE_RESPONSE_QUEUE_OFFSET		0x30
57df54c2f9SSascha Wildner 
58df54c2f9SSascha Wildner 
59df54c2f9SSascha Wildner /* Control register bit definitions. */
60df54c2f9SSascha Wildner #define TWA_CONTROL_ISSUE_HOST_INTERRUPT	0x00000020
61df54c2f9SSascha Wildner #define TWA_CONTROL_DISABLE_INTERRUPTS		0x00000040
62df54c2f9SSascha Wildner #define TWA_CONTROL_ENABLE_INTERRUPTS		0x00000080
63df54c2f9SSascha Wildner #define TWA_CONTROL_ISSUE_SOFT_RESET		0x00000100
64df54c2f9SSascha Wildner #define TWA_CONTROL_UNMASK_RESPONSE_INTERRUPT	0x00004000
65df54c2f9SSascha Wildner #define TWA_CONTROL_UNMASK_COMMAND_INTERRUPT	0x00008000
66df54c2f9SSascha Wildner #define TWA_CONTROL_MASK_RESPONSE_INTERRUPT	0x00010000
67df54c2f9SSascha Wildner #define TWA_CONTROL_MASK_COMMAND_INTERRUPT	0x00020000
68df54c2f9SSascha Wildner #define TWA_CONTROL_CLEAR_ATTENTION_INTERRUPT	0x00040000
69df54c2f9SSascha Wildner #define TWA_CONTROL_CLEAR_HOST_INTERRUPT	0x00080000
70df54c2f9SSascha Wildner #define TWA_CONTROL_CLEAR_PCI_ABORT		0x00100000
71df54c2f9SSascha Wildner #define TWA_CONTROL_CLEAR_QUEUE_ERROR		0x00400000
72df54c2f9SSascha Wildner #define TWA_CONTROL_CLEAR_PARITY_ERROR		0x00800000
73df54c2f9SSascha Wildner 
74df54c2f9SSascha Wildner 
75df54c2f9SSascha Wildner /* Status register bit definitions. */
76df54c2f9SSascha Wildner #define TWA_STATUS_ROM_BIOS_IN_SBUF		0x00000002
77df54c2f9SSascha Wildner #define TWA_STATUS_COMMAND_QUEUE_EMPTY		0x00001000
78df54c2f9SSascha Wildner #define TWA_STATUS_MICROCONTROLLER_READY	0x00002000
79df54c2f9SSascha Wildner #define TWA_STATUS_RESPONSE_QUEUE_EMPTY		0x00004000
80df54c2f9SSascha Wildner #define TWA_STATUS_COMMAND_QUEUE_FULL		0x00008000
81df54c2f9SSascha Wildner #define TWA_STATUS_RESPONSE_INTERRUPT		0x00010000
82df54c2f9SSascha Wildner #define TWA_STATUS_COMMAND_INTERRUPT		0x00020000
83df54c2f9SSascha Wildner #define TWA_STATUS_ATTENTION_INTERRUPT		0x00040000
84df54c2f9SSascha Wildner #define TWA_STATUS_HOST_INTERRUPT		0x00080000
85df54c2f9SSascha Wildner #define TWA_STATUS_PCI_ABORT_INTERRUPT		0x00100000
86df54c2f9SSascha Wildner #define TWA_STATUS_MICROCONTROLLER_ERROR	0x00200000
87df54c2f9SSascha Wildner #define TWA_STATUS_QUEUE_ERROR_INTERRUPT	0x00400000
88df54c2f9SSascha Wildner #define TWA_STATUS_PCI_PARITY_ERROR_INTERRUPT	0x00800000
89df54c2f9SSascha Wildner #define TWA_STATUS_MINOR_VERSION_MASK		0x0F000000
90df54c2f9SSascha Wildner #define TWA_STATUS_MAJOR_VERSION_MASK		0xF0000000
91df54c2f9SSascha Wildner 
924fbf05f9SSascha Wildner #define TWA_STATUS_UNEXPECTED_BITS		0x00D00000
93df54c2f9SSascha Wildner 
94df54c2f9SSascha Wildner 
95df54c2f9SSascha Wildner /* PCI related defines. */
96df54c2f9SSascha Wildner #define TWA_IO_CONFIG_REG			0x10
97df54c2f9SSascha Wildner 
98df54c2f9SSascha Wildner #define TWA_PCI_CONFIG_CLEAR_PARITY_ERROR	0xc100
99df54c2f9SSascha Wildner #define TWA_PCI_CONFIG_CLEAR_PCI_ABORT		0x2000
100df54c2f9SSascha Wildner 
101df54c2f9SSascha Wildner #define TWA_RESET_PHASE1_NOTIFICATION_RESPONSE	0xFFFF
102df54c2f9SSascha Wildner #define TWA_RESET_PHASE1_WAIT_TIME_MS		500
103df54c2f9SSascha Wildner 
104df54c2f9SSascha Wildner 
105df54c2f9SSascha Wildner /* Command packet opcodes. */
106df54c2f9SSascha Wildner #define TWA_FW_CMD_NOP				0x00
107df54c2f9SSascha Wildner #define TWA_FW_CMD_INIT_CONNECTION		0x01
108df54c2f9SSascha Wildner #define TWA_FW_CMD_READ				0x02
109df54c2f9SSascha Wildner #define TWA_FW_CMD_WRITE			0x03
110df54c2f9SSascha Wildner #define TWA_FW_CMD_READVERIFY			0x04
111df54c2f9SSascha Wildner #define TWA_FW_CMD_VERIFY			0x05
112df54c2f9SSascha Wildner #define TWA_FW_CMD_ZEROUNIT			0x08
113df54c2f9SSascha Wildner #define TWA_FW_CMD_REPLACEUNIT			0x09
114df54c2f9SSascha Wildner #define TWA_FW_CMD_HOTSWAP			0x0A
115df54c2f9SSascha Wildner #define TWA_FW_CMD_SELFTESTS			0x0B
116df54c2f9SSascha Wildner #define TWA_FW_CMD_SYNC_PARAM			0x0C
117df54c2f9SSascha Wildner #define TWA_FW_CMD_REORDER_UNITS		0x0D
118df54c2f9SSascha Wildner 
119df54c2f9SSascha Wildner #define TWA_FW_CMD_EXECUTE_SCSI			0x10
120df54c2f9SSascha Wildner #define TWA_FW_CMD_ATA_PASSTHROUGH		0x11
121df54c2f9SSascha Wildner #define TWA_FW_CMD_GET_PARAM			0x12
122df54c2f9SSascha Wildner #define TWA_FW_CMD_SET_PARAM			0x13
123df54c2f9SSascha Wildner #define TWA_FW_CMD_CREATEUNIT			0x14
124df54c2f9SSascha Wildner #define TWA_FW_CMD_DELETEUNIT			0x15
125df54c2f9SSascha Wildner #define TWA_FW_CMD_DOWNLOAD_FIRMWARE		0x16
126df54c2f9SSascha Wildner #define TWA_FW_CMD_REBUILDUNIT			0x17
127df54c2f9SSascha Wildner #define TWA_FW_CMD_POWER_MANAGEMENT		0x18
128df54c2f9SSascha Wildner 
129df54c2f9SSascha Wildner #define TWA_FW_CMD_REMOTE_PRINT			0x1B
130df54c2f9SSascha Wildner #define TWA_FW_CMD_HARD_RESET_FIRMWARE		0x1C
131df54c2f9SSascha Wildner #define TWA_FW_CMD_DEBUG			0x1D
132df54c2f9SSascha Wildner 
133df54c2f9SSascha Wildner #define TWA_FW_CMD_DIAGNOSTICS			0x1F
134df54c2f9SSascha Wildner 
135df54c2f9SSascha Wildner 
136df54c2f9SSascha Wildner /* Misc defines. */
137df54c2f9SSascha Wildner #define TWA_SHUTDOWN_MESSAGE_CREDITS	0x001
138df54c2f9SSascha Wildner #define TWA_64BIT_SG_ADDRESSES		0x00000001
139df54c2f9SSascha Wildner #define TWA_EXTENDED_INIT_CONNECT	0x00000002
140df54c2f9SSascha Wildner #define TWA_BASE_MODE			1
141df54c2f9SSascha Wildner #define TWA_BASE_FW_SRL			24
142df54c2f9SSascha Wildner #define TWA_BASE_FW_BRANCH		0
143df54c2f9SSascha Wildner #define TWA_BASE_FW_BUILD		1
144df54c2f9SSascha Wildner #define TWA_CURRENT_FW_SRL		41
145df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BRANCH_9K	4
146df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BUILD_9K		8
147df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BRANCH_9K_X	8
148df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BUILD_9K_X	4
149df54c2f9SSascha Wildner #define TWA_MULTI_LUN_FW_SRL		28
150df54c2f9SSascha Wildner #define TWA_ARCH_ID_9K			0x5	/* 9000 PCI controllers */
151df54c2f9SSascha Wildner #define TWA_ARCH_ID_9K_X		0x6	/* 9000 PCI-X controllers */
152df54c2f9SSascha Wildner #define TWA_CTLR_FW_SAME_OR_NEWER	0x00000001
153df54c2f9SSascha Wildner #define TWA_CTLR_FW_COMPATIBLE		0x00000002
154df54c2f9SSascha Wildner #define TWA_SENSE_DATA_LENGTH		18
155df54c2f9SSascha Wildner 
156df54c2f9SSascha Wildner 
157df54c2f9SSascha Wildner #define TWA_ARCH_ID(device_id)						\
158df54c2f9SSascha Wildner 	(((device_id) == TW_CL_DEVICE_ID_9K) ? TWA_ARCH_ID_9K :		\
159df54c2f9SSascha Wildner 	TWA_ARCH_ID_9K_X)
160df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BRANCH(arch_id)					\
161df54c2f9SSascha Wildner 	(((arch_id) == TWA_ARCH_ID_9K) ? TWA_CURRENT_FW_BRANCH_9K :	\
162df54c2f9SSascha Wildner 	TWA_CURRENT_FW_BRANCH_9K_X)
163df54c2f9SSascha Wildner #define TWA_CURRENT_FW_BUILD(arch_id)					\
164df54c2f9SSascha Wildner 	(((arch_id) == TWA_ARCH_ID_9K) ? TWA_CURRENT_FW_BUILD_9K :	\
165df54c2f9SSascha Wildner 	TWA_CURRENT_FW_BUILD_9K_X)
166df54c2f9SSascha Wildner 
167df54c2f9SSascha Wildner /*
168df54c2f9SSascha Wildner  * All SG addresses and DMA'able memory allocated by the OSL should be
169df54c2f9SSascha Wildner  * TWA_ALIGNMENT bytes aligned, and have a size that is a multiple of
170df54c2f9SSascha Wildner  * TWA_SG_ELEMENT_SIZE_FACTOR.
171df54c2f9SSascha Wildner  */
172df54c2f9SSascha Wildner #define TWA_ALIGNMENT(device_id)			0x4
173df54c2f9SSascha Wildner #define TWA_SG_ELEMENT_SIZE_FACTOR(device_id)		\
174df54c2f9SSascha Wildner 	(((device_id) == TW_CL_DEVICE_ID_9K) ? 512 : 4)
175df54c2f9SSascha Wildner 
176df54c2f9SSascha Wildner 
177df54c2f9SSascha Wildner /*
178df54c2f9SSascha Wildner  * Some errors of interest (in cmd_hdr->status_block.error) when a command
179df54c2f9SSascha Wildner  * is completed by the firmware with a bad status.
180df54c2f9SSascha Wildner  */
181df54c2f9SSascha Wildner #define TWA_ERROR_LOGICAL_UNIT_NOT_SUPPORTED	0x010a
182df54c2f9SSascha Wildner #define TWA_ERROR_UNIT_OFFLINE			0x0128
183df54c2f9SSascha Wildner #define TWA_ERROR_MORE_DATA			0x0231
184df54c2f9SSascha Wildner 
185df54c2f9SSascha Wildner 
186df54c2f9SSascha Wildner /* AEN codes of interest. */
187df54c2f9SSascha Wildner #define TWA_AEN_QUEUE_EMPTY		0x00
188df54c2f9SSascha Wildner #define TWA_AEN_SOFT_RESET		0x01
189df54c2f9SSascha Wildner #define TWA_AEN_SYNC_TIME_WITH_HOST	0x31
190df54c2f9SSascha Wildner 
191df54c2f9SSascha Wildner 
192df54c2f9SSascha Wildner /* Table #'s and id's of parameters of interest in firmware's param table. */
193df54c2f9SSascha Wildner #define TWA_PARAM_VERSION_TABLE		0x0402
194df54c2f9SSascha Wildner #define TWA_PARAM_VERSION_FW		3	/* firmware version [16] */
195df54c2f9SSascha Wildner #define TWA_PARAM_VERSION_BIOS		4	/* BIOSs version [16] */
196df54c2f9SSascha Wildner #define TWA_PARAM_CTLR_MODEL		8	/* Controller model [16] */
197df54c2f9SSascha Wildner 
198df54c2f9SSascha Wildner #define TWA_PARAM_CONTROLLER_TABLE	0x0403
199df54c2f9SSascha Wildner #define TWA_PARAM_CONTROLLER_PORT_COUNT	3	/* number of ports [1] */
200df54c2f9SSascha Wildner 
201df54c2f9SSascha Wildner #define TWA_PARAM_TIME_TABLE		0x40A
202df54c2f9SSascha Wildner #define TWA_PARAM_TIME_SCHED_TIME	0x3
203df54c2f9SSascha Wildner 
204df54c2f9SSascha Wildner #define TWA_9K_PARAM_DESCRIPTOR		0x8000
205df54c2f9SSascha Wildner 
206df54c2f9SSascha Wildner 
207df54c2f9SSascha Wildner #pragma pack(1)
208df54c2f9SSascha Wildner /* 7000 structures. */
209df54c2f9SSascha Wildner struct tw_cl_command_init_connect {
210df54c2f9SSascha Wildner 	TW_UINT8	res1__opcode;	/* 3:5 */
211df54c2f9SSascha Wildner 	TW_UINT8	size;
212df54c2f9SSascha Wildner 	TW_UINT8	request_id;
213df54c2f9SSascha Wildner 	TW_UINT8	res2;
214df54c2f9SSascha Wildner 	TW_UINT8	status;
215df54c2f9SSascha Wildner 	TW_UINT8	flags;
216df54c2f9SSascha Wildner 	TW_UINT16	message_credits;
217df54c2f9SSascha Wildner 	TW_UINT32	features;
218df54c2f9SSascha Wildner 	TW_UINT16	fw_srl;
219df54c2f9SSascha Wildner 	TW_UINT16	fw_arch_id;
220df54c2f9SSascha Wildner 	TW_UINT16	fw_branch;
221df54c2f9SSascha Wildner 	TW_UINT16	fw_build;
222df54c2f9SSascha Wildner 	TW_UINT32	result;
223df54c2f9SSascha Wildner };
224df54c2f9SSascha Wildner 
225df54c2f9SSascha Wildner 
226df54c2f9SSascha Wildner /* Structure for downloading firmware onto the controller. */
227df54c2f9SSascha Wildner struct tw_cl_command_download_firmware {
228df54c2f9SSascha Wildner 	TW_UINT8	sgl_off__opcode;/* 3:5 */
229df54c2f9SSascha Wildner 	TW_UINT8	size;
230df54c2f9SSascha Wildner 	TW_UINT8	request_id;
231df54c2f9SSascha Wildner 	TW_UINT8	unit;
232df54c2f9SSascha Wildner 	TW_UINT8	status;
233df54c2f9SSascha Wildner 	TW_UINT8	flags;
234df54c2f9SSascha Wildner 	TW_UINT16	param;
235df54c2f9SSascha Wildner 	TW_UINT8	sgl[1];
236df54c2f9SSascha Wildner };
237df54c2f9SSascha Wildner 
238df54c2f9SSascha Wildner 
239df54c2f9SSascha Wildner /* Structure for hard resetting the controller. */
240df54c2f9SSascha Wildner struct tw_cl_command_reset_firmware {
241df54c2f9SSascha Wildner 	TW_UINT8	res1__opcode;	/* 3:5 */
242df54c2f9SSascha Wildner 	TW_UINT8	size;
243df54c2f9SSascha Wildner 	TW_UINT8	request_id;
244df54c2f9SSascha Wildner 	TW_UINT8	unit;
245df54c2f9SSascha Wildner 	TW_UINT8	status;
246df54c2f9SSascha Wildner 	TW_UINT8	flags;
247df54c2f9SSascha Wildner 	TW_UINT8	res2;
248df54c2f9SSascha Wildner 	TW_UINT8	param;
249df54c2f9SSascha Wildner };
250df54c2f9SSascha Wildner 
251df54c2f9SSascha Wildner 
252df54c2f9SSascha Wildner /* Structure for sending get/set param commands. */
253df54c2f9SSascha Wildner struct tw_cl_command_param {
254df54c2f9SSascha Wildner 	TW_UINT8	sgl_off__opcode;/* 3:5 */
255df54c2f9SSascha Wildner 	TW_UINT8	size;
256df54c2f9SSascha Wildner 	TW_UINT8	request_id;
257df54c2f9SSascha Wildner 	TW_UINT8	host_id__unit;	/* 4:4 */
258df54c2f9SSascha Wildner 	TW_UINT8	status;
259df54c2f9SSascha Wildner 	TW_UINT8	flags;
260df54c2f9SSascha Wildner 	TW_UINT16	param_count;
261df54c2f9SSascha Wildner 	TW_UINT8	sgl[1];
262df54c2f9SSascha Wildner };
263df54c2f9SSascha Wildner 
264df54c2f9SSascha Wildner 
265df54c2f9SSascha Wildner /* Generic command packet. */
266df54c2f9SSascha Wildner struct tw_cl_command_generic {
267df54c2f9SSascha Wildner 	TW_UINT8	sgl_off__opcode;/* 3:5 */
268df54c2f9SSascha Wildner 	TW_UINT8	size;
269df54c2f9SSascha Wildner 	TW_UINT8	request_id;
270df54c2f9SSascha Wildner 	TW_UINT8	host_id__unit;	/* 4:4 */
271df54c2f9SSascha Wildner 	TW_UINT8	status;
272df54c2f9SSascha Wildner 	TW_UINT8	flags;
273df54c2f9SSascha Wildner 	TW_UINT16	count;	/* block cnt, parameter cnt, message credits */
274df54c2f9SSascha Wildner };
275df54c2f9SSascha Wildner 
276df54c2f9SSascha Wildner 
277df54c2f9SSascha Wildner /* Command packet header. */
278df54c2f9SSascha Wildner struct tw_cl_command_header {
279df54c2f9SSascha Wildner 	TW_UINT8	sense_data[TWA_SENSE_DATA_LENGTH];
280df54c2f9SSascha Wildner 	struct {
281df54c2f9SSascha Wildner 		TW_INT8		reserved[4];
282df54c2f9SSascha Wildner 		TW_UINT16	error;
283df54c2f9SSascha Wildner 		TW_UINT8	padding;
284df54c2f9SSascha Wildner 		TW_UINT8	res__severity;	/* 5:3 */
285df54c2f9SSascha Wildner 	} status_block;
286df54c2f9SSascha Wildner 	TW_UINT8	err_specific_desc[98];
287df54c2f9SSascha Wildner 	struct {
288df54c2f9SSascha Wildner 		TW_UINT8	size_header;
289df54c2f9SSascha Wildner 		TW_UINT16	reserved;
290df54c2f9SSascha Wildner 		TW_UINT8	size_sense;
291df54c2f9SSascha Wildner 	} header_desc;
292df54c2f9SSascha Wildner };
293df54c2f9SSascha Wildner 
294df54c2f9SSascha Wildner 
295df54c2f9SSascha Wildner /* 7000 Command packet. */
296df54c2f9SSascha Wildner union tw_cl_command_7k {
297df54c2f9SSascha Wildner 	struct tw_cl_command_init_connect	init_connect;
298df54c2f9SSascha Wildner 	struct tw_cl_command_download_firmware	download_fw;
299df54c2f9SSascha Wildner 	struct tw_cl_command_reset_firmware	reset_fw;
300df54c2f9SSascha Wildner 	struct tw_cl_command_param		param;
301df54c2f9SSascha Wildner 	struct tw_cl_command_generic		generic;
302df54c2f9SSascha Wildner 	TW_UINT8	padding[1024 - sizeof(struct tw_cl_command_header)];
303df54c2f9SSascha Wildner };
304df54c2f9SSascha Wildner 
305df54c2f9SSascha Wildner 
306df54c2f9SSascha Wildner /* 9000 Command Packet. */
307df54c2f9SSascha Wildner struct tw_cl_command_9k {
308df54c2f9SSascha Wildner 	TW_UINT8	res__opcode;	/* 3:5 */
309df54c2f9SSascha Wildner 	TW_UINT8	unit;
310df54c2f9SSascha Wildner 	TW_UINT16	lun_l4__req_id;	/* 4:12 */
311df54c2f9SSascha Wildner 	TW_UINT8	status;
312df54c2f9SSascha Wildner 	TW_UINT8	sgl_offset; /* offset (in bytes) to sg_list, from the
313df54c2f9SSascha Wildner 					end of sgl_entries */
314df54c2f9SSascha Wildner 	TW_UINT16	lun_h4__sgl_entries;
315df54c2f9SSascha Wildner 	TW_UINT8	cdb[16];
316df54c2f9SSascha Wildner 	TW_UINT8	sg_list[872];/* total struct size =
317df54c2f9SSascha Wildner 					1024-sizeof(cmd_hdr) */
318df54c2f9SSascha Wildner };
319df54c2f9SSascha Wildner 
320df54c2f9SSascha Wildner 
321df54c2f9SSascha Wildner /* Full command packet. */
322df54c2f9SSascha Wildner struct tw_cl_command_packet {
323df54c2f9SSascha Wildner 	struct tw_cl_command_header	cmd_hdr;
324df54c2f9SSascha Wildner 	union {
325df54c2f9SSascha Wildner 		union tw_cl_command_7k	cmd_pkt_7k;
326df54c2f9SSascha Wildner 		struct tw_cl_command_9k cmd_pkt_9k;
327df54c2f9SSascha Wildner 	} command;
328df54c2f9SSascha Wildner };
329df54c2f9SSascha Wildner 
330df54c2f9SSascha Wildner 
331df54c2f9SSascha Wildner /* Structure describing payload for get/set param commands. */
332df54c2f9SSascha Wildner struct tw_cl_param_9k {
333df54c2f9SSascha Wildner 	TW_UINT16	table_id;
334df54c2f9SSascha Wildner 	TW_UINT8	parameter_id;
335df54c2f9SSascha Wildner 	TW_UINT8	reserved;
336df54c2f9SSascha Wildner 	TW_UINT16	parameter_size_bytes;
337df54c2f9SSascha Wildner 	TW_UINT16	parameter_actual_size_bytes;
338df54c2f9SSascha Wildner 	TW_UINT8	data[1];
339df54c2f9SSascha Wildner };
340df54c2f9SSascha Wildner #pragma pack()
341df54c2f9SSascha Wildner 
342df54c2f9SSascha Wildner 
343df54c2f9SSascha Wildner /* Functions to read from, and write to registers */
344df54c2f9SSascha Wildner #define TW_CLI_WRITE_CONTROL_REGISTER(ctlr_handle, value)		\
345df54c2f9SSascha Wildner 	tw_osl_write_reg(ctlr_handle, TWA_CONTROL_REGISTER_OFFSET, value, 4)
346df54c2f9SSascha Wildner 
347df54c2f9SSascha Wildner 
348df54c2f9SSascha Wildner #define TW_CLI_READ_STATUS_REGISTER(ctlr_handle)			\
349df54c2f9SSascha Wildner 	tw_osl_read_reg(ctlr_handle, TWA_STATUS_REGISTER_OFFSET, 4)
350df54c2f9SSascha Wildner 
351df54c2f9SSascha Wildner 
352df54c2f9SSascha Wildner #define TW_CLI_WRITE_COMMAND_QUEUE(ctlr_handle, value)	do {		\
353df54c2f9SSascha Wildner 	if (ctlr->flags & TW_CL_64BIT_ADDRESSES) {			\
354df54c2f9SSascha Wildner 		/* First write the low 4 bytes, then the high 4. */	\
355df54c2f9SSascha Wildner 		tw_osl_write_reg(ctlr_handle, TWA_COMMAND_QUEUE_OFFSET_LOW, \
356df54c2f9SSascha Wildner 			(TW_UINT32)(value), 4);				\
357df54c2f9SSascha Wildner 		tw_osl_write_reg(ctlr_handle, TWA_COMMAND_QUEUE_OFFSET_HIGH,\
358df54c2f9SSascha Wildner 			(TW_UINT32)(((TW_UINT64)value)>>32), 4);	\
359df54c2f9SSascha Wildner 	} else								\
360df54c2f9SSascha Wildner 		tw_osl_write_reg(ctlr_handle, TWA_COMMAND_QUEUE_OFFSET,	\
361df54c2f9SSascha Wildner 					(TW_UINT32)(value), 4);		\
362df54c2f9SSascha Wildner } while (0)
363df54c2f9SSascha Wildner 
364df54c2f9SSascha Wildner 
365df54c2f9SSascha Wildner #define TW_CLI_READ_RESPONSE_QUEUE(ctlr_handle)				\
366df54c2f9SSascha Wildner 	tw_osl_read_reg(ctlr_handle, TWA_RESPONSE_QUEUE_OFFSET, 4)
367df54c2f9SSascha Wildner 
368df54c2f9SSascha Wildner 
369df54c2f9SSascha Wildner #define TW_CLI_READ_LARGE_RESPONSE_QUEUE(ctlr_handle)			\
370df54c2f9SSascha Wildner 	tw_osl_read_reg(ctlr_handle, TWA_LARGE_RESPONSE_QUEUE_OFFSET, 4)
371df54c2f9SSascha Wildner 
372df54c2f9SSascha Wildner 
373df54c2f9SSascha Wildner #define TW_CLI_SOFT_RESET(ctlr)					\
374df54c2f9SSascha Wildner 	TW_CLI_WRITE_CONTROL_REGISTER(ctlr,			\
375df54c2f9SSascha Wildner 		TWA_CONTROL_ISSUE_SOFT_RESET |			\
376df54c2f9SSascha Wildner 		TWA_CONTROL_CLEAR_HOST_INTERRUPT |		\
377df54c2f9SSascha Wildner 		TWA_CONTROL_CLEAR_ATTENTION_INTERRUPT |		\
378df54c2f9SSascha Wildner 		TWA_CONTROL_MASK_COMMAND_INTERRUPT |		\
379df54c2f9SSascha Wildner 		TWA_CONTROL_MASK_RESPONSE_INTERRUPT |		\
380df54c2f9SSascha Wildner 		TWA_CONTROL_DISABLE_INTERRUPTS)
381df54c2f9SSascha Wildner 
382df54c2f9SSascha Wildner /* Detect inconsistencies in the status register. */
383df54c2f9SSascha Wildner #define TW_CLI_STATUS_ERRORS(x)					\
384df54c2f9SSascha Wildner 	((x & TWA_STATUS_UNEXPECTED_BITS) &&			\
385df54c2f9SSascha Wildner 	 (x & TWA_STATUS_MICROCONTROLLER_READY))
386df54c2f9SSascha Wildner 
387df54c2f9SSascha Wildner 
388df54c2f9SSascha Wildner /*
389df54c2f9SSascha Wildner  * Functions for making transparent, the bit fields in firmware
390df54c2f9SSascha Wildner  * interface structures.
391df54c2f9SSascha Wildner  */
392df54c2f9SSascha Wildner #define BUILD_SGL_OFF__OPCODE(sgl_off, opcode)	\
393df54c2f9SSascha Wildner 	((sgl_off << 5) & 0xE0) | (opcode & 0x1F)	/* 3:5 */
394df54c2f9SSascha Wildner 
395df54c2f9SSascha Wildner #define BUILD_RES__OPCODE(res, opcode)		\
396df54c2f9SSascha Wildner 	((res << 5) & 0xE0) | (opcode & 0x1F)		/* 3:5 */
397df54c2f9SSascha Wildner 
398df54c2f9SSascha Wildner #define BUILD_HOST_ID__UNIT(host_id, unit)	\
399df54c2f9SSascha Wildner 	((host_id << 4) & 0xF0) | (unit & 0xF)		/* 4:4 */
400df54c2f9SSascha Wildner 
401df54c2f9SSascha Wildner #define BUILD_RES__SEVERITY(res, severity)	\
402df54c2f9SSascha Wildner 	((res << 3) & 0xF8) | (severity & 0x7)		/* 5:3 */
403df54c2f9SSascha Wildner 
404df54c2f9SSascha Wildner #define BUILD_LUN_L4__REQ_ID(lun, req_id)	\
405df54c2f9SSascha Wildner 	(((lun << 12) & 0xF000) | (req_id & 0xFFF))	/* 4:12 */
406df54c2f9SSascha Wildner 
407df54c2f9SSascha Wildner #define BUILD_LUN_H4__SGL_ENTRIES(lun, sgl_entries)	\
408df54c2f9SSascha Wildner 	(((lun << 8) & 0xF000) | (sgl_entries & 0xFFF))	/* 4:12 */
409df54c2f9SSascha Wildner 
410df54c2f9SSascha Wildner 
411df54c2f9SSascha Wildner #define GET_OPCODE(sgl_off__opcode)	\
412df54c2f9SSascha Wildner 	(sgl_off__opcode & 0x1F)		/* 3:5 */
413df54c2f9SSascha Wildner 
414df54c2f9SSascha Wildner #define GET_SGL_OFF(sgl_off__opcode)	\
415df54c2f9SSascha Wildner 	((sgl_off__opcode >> 5) & 0x7)		/* 3:5 */
416df54c2f9SSascha Wildner 
417df54c2f9SSascha Wildner #define GET_UNIT(host_id__unit)		\
418df54c2f9SSascha Wildner 	(host_id__unit & 0xF)			/* 4:4 */
419df54c2f9SSascha Wildner 
420df54c2f9SSascha Wildner #define GET_HOST_ID(host_id__unit)	\
421df54c2f9SSascha Wildner 	((host_id__unit >> 4) & 0xF)		/* 4:4 */
422df54c2f9SSascha Wildner 
423df54c2f9SSascha Wildner #define GET_SEVERITY(res__severity)	\
424df54c2f9SSascha Wildner 	(res__severity & 0x7)			/* 5:3 */
425df54c2f9SSascha Wildner 
426df54c2f9SSascha Wildner #define GET_RESP_ID(undef2__resp_id__undef1)	\
427df54c2f9SSascha Wildner 	((undef2__resp_id__undef1 >> 4) & 0xFF)	/* 20:8:4 */
428df54c2f9SSascha Wildner 
429df54c2f9SSascha Wildner #define GET_RESP_ID_9K_X(undef2__resp_id)	\
430df54c2f9SSascha Wildner 	((undef2__resp_id) & 0xFFF)		/* 20:12 */
431df54c2f9SSascha Wildner 
432df54c2f9SSascha Wildner #define GET_LARGE_RESP_ID(misc__large_resp_id)	\
433df54c2f9SSascha Wildner 	((misc__large_resp_id) & 0xFFFF)	/* 16:16 */
434df54c2f9SSascha Wildner 
435df54c2f9SSascha Wildner #define GET_REQ_ID(lun_l4__req_id)	\
436df54c2f9SSascha Wildner 	(lun_l4__req_id & 0xFFF)		/* 4:12 */
437df54c2f9SSascha Wildner 
438df54c2f9SSascha Wildner #define GET_LUN_L4(lun_l4__req_id)	\
439df54c2f9SSascha Wildner 	((lun_l4__req_id >> 12) & 0xF)		/* 4:12 */
440df54c2f9SSascha Wildner 
441df54c2f9SSascha Wildner #define GET_SGL_ENTRIES(lun_h4__sgl_entries)	\
442df54c2f9SSascha Wildner 	(lun_h4__sgl_entries & 0xFFF)		/* 4:12 */
443df54c2f9SSascha Wildner 
444df54c2f9SSascha Wildner #define GET_LUN_H4(lun_h4__sgl_entries)	\
445df54c2f9SSascha Wildner 	((lun_h4__sgl_entries >> 12) & 0xF)	/* 4:12 */
446df54c2f9SSascha Wildner 
447df54c2f9SSascha Wildner 
448df54c2f9SSascha Wildner 
449df54c2f9SSascha Wildner #endif /* TW_CL_FWIF_H */
450