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