Hannes Reinecke | 081ff39 | 2018-10-17 17:25:11 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 |
| 2 | * |
| 3 | * Linux Driver for Mylex DAC960/AcceleRAID/eXtremeRAID PCI RAID Controllers |
| 4 | * |
| 5 | * Copyright 2017 Hannes Reinecke, SUSE Linux GmbH <hare@suse.com> |
| 6 | * |
| 7 | * Based on the original DAC960 driver, |
| 8 | * Copyright 1998-2001 by Leonard N. Zubkoff <lnz@dandelion.com> |
| 9 | * Portions Copyright 2002 by Mylex (An IBM Business Unit) |
| 10 | * |
| 11 | */ |
| 12 | |
| 13 | #ifndef MYRB_H |
| 14 | #define MYRB_H |
| 15 | |
| 16 | #define MYRB_MAX_LDEVS 32 |
| 17 | #define MYRB_MAX_CHANNELS 3 |
| 18 | #define MYRB_MAX_TARGETS 16 |
| 19 | #define MYRB_MAX_PHYSICAL_DEVICES 45 |
| 20 | #define MYRB_SCATTER_GATHER_LIMIT 32 |
| 21 | #define MYRB_CMD_MBOX_COUNT 256 |
| 22 | #define MYRB_STAT_MBOX_COUNT 1024 |
| 23 | |
| 24 | #define MYRB_BLKSIZE_BITS 9 |
| 25 | #define MYRB_MAILBOX_TIMEOUT 1000000 |
| 26 | |
| 27 | #define MYRB_DCMD_TAG 1 |
| 28 | #define MYRB_MCMD_TAG 2 |
| 29 | |
| 30 | #define MYRB_PRIMARY_MONITOR_INTERVAL (10 * HZ) |
| 31 | #define MYRB_SECONDARY_MONITOR_INTERVAL (60 * HZ) |
| 32 | |
| 33 | /* |
| 34 | * DAC960 V1 Firmware Command Opcodes. |
| 35 | */ |
| 36 | enum myrb_cmd_opcode { |
| 37 | /* I/O Commands */ |
| 38 | MYRB_CMD_READ_EXTENDED = 0x33, |
| 39 | MYRB_CMD_WRITE_EXTENDED = 0x34, |
| 40 | MYRB_CMD_READAHEAD_EXTENDED = 0x35, |
| 41 | MYRB_CMD_READ_EXTENDED_SG = 0xB3, |
| 42 | MYRB_CMD_WRITE_EXTENDED_SG = 0xB4, |
| 43 | MYRB_CMD_READ = 0x36, |
| 44 | MYRB_CMD_READ_SG = 0xB6, |
| 45 | MYRB_CMD_WRITE = 0x37, |
| 46 | MYRB_CMD_WRITE_SG = 0xB7, |
| 47 | MYRB_CMD_DCDB = 0x04, |
| 48 | MYRB_CMD_DCDB_SG = 0x84, |
| 49 | MYRB_CMD_FLUSH = 0x0A, |
| 50 | /* Controller Status Related Commands */ |
| 51 | MYRB_CMD_ENQUIRY = 0x53, |
| 52 | MYRB_CMD_ENQUIRY2 = 0x1C, |
| 53 | MYRB_CMD_GET_LDRV_ELEMENT = 0x55, |
| 54 | MYRB_CMD_GET_LDEV_INFO = 0x19, |
| 55 | MYRB_CMD_IOPORTREAD = 0x39, |
| 56 | MYRB_CMD_IOPORTWRITE = 0x3A, |
| 57 | MYRB_CMD_GET_SD_STATS = 0x3E, |
| 58 | MYRB_CMD_GET_PD_STATS = 0x3F, |
| 59 | MYRB_CMD_EVENT_LOG_OPERATION = 0x72, |
| 60 | /* Device Related Commands */ |
| 61 | MYRB_CMD_START_DEVICE = 0x10, |
| 62 | MYRB_CMD_GET_DEVICE_STATE = 0x50, |
| 63 | MYRB_CMD_STOP_CHANNEL = 0x13, |
| 64 | MYRB_CMD_START_CHANNEL = 0x12, |
| 65 | MYRB_CMD_RESET_CHANNEL = 0x1A, |
| 66 | /* Commands Associated with Data Consistency and Errors */ |
| 67 | MYRB_CMD_REBUILD = 0x09, |
| 68 | MYRB_CMD_REBUILD_ASYNC = 0x16, |
| 69 | MYRB_CMD_CHECK_CONSISTENCY = 0x0F, |
| 70 | MYRB_CMD_CHECK_CONSISTENCY_ASYNC = 0x1E, |
| 71 | MYRB_CMD_REBUILD_STAT = 0x0C, |
| 72 | MYRB_CMD_GET_REBUILD_PROGRESS = 0x27, |
| 73 | MYRB_CMD_REBUILD_CONTROL = 0x1F, |
| 74 | MYRB_CMD_READ_BADBLOCK_TABLE = 0x0B, |
| 75 | MYRB_CMD_READ_BADDATA_TABLE = 0x25, |
| 76 | MYRB_CMD_CLEAR_BADDATA_TABLE = 0x26, |
| 77 | MYRB_CMD_GET_ERROR_TABLE = 0x17, |
| 78 | MYRB_CMD_ADD_CAPACITY_ASYNC = 0x2A, |
| 79 | MYRB_CMD_BGI_CONTROL = 0x2B, |
| 80 | /* Configuration Related Commands */ |
| 81 | MYRB_CMD_READ_CONFIG2 = 0x3D, |
| 82 | MYRB_CMD_WRITE_CONFIG2 = 0x3C, |
| 83 | MYRB_CMD_READ_CONFIG_ONDISK = 0x4A, |
| 84 | MYRB_CMD_WRITE_CONFIG_ONDISK = 0x4B, |
| 85 | MYRB_CMD_READ_CONFIG = 0x4E, |
| 86 | MYRB_CMD_READ_BACKUP_CONFIG = 0x4D, |
| 87 | MYRB_CMD_WRITE_CONFIG = 0x4F, |
| 88 | MYRB_CMD_ADD_CONFIG = 0x4C, |
| 89 | MYRB_CMD_READ_CONFIG_LABEL = 0x48, |
| 90 | MYRB_CMD_WRITE_CONFIG_LABEL = 0x49, |
| 91 | /* Firmware Upgrade Related Commands */ |
| 92 | MYRB_CMD_LOAD_IMAGE = 0x20, |
| 93 | MYRB_CMD_STORE_IMAGE = 0x21, |
| 94 | MYRB_CMD_PROGRAM_IMAGE = 0x22, |
| 95 | /* Diagnostic Commands */ |
| 96 | MYRB_CMD_SET_DIAGNOSTIC_MODE = 0x31, |
| 97 | MYRB_CMD_RUN_DIAGNOSTIC = 0x32, |
| 98 | /* Subsystem Service Commands */ |
| 99 | MYRB_CMD_GET_SUBSYS_DATA = 0x70, |
| 100 | MYRB_CMD_SET_SUBSYS_PARAM = 0x71, |
| 101 | /* Version 2.xx Firmware Commands */ |
| 102 | MYRB_CMD_ENQUIRY_OLD = 0x05, |
| 103 | MYRB_CMD_GET_DEVICE_STATE_OLD = 0x14, |
| 104 | MYRB_CMD_READ_OLD = 0x02, |
| 105 | MYRB_CMD_WRITE_OLD = 0x03, |
| 106 | MYRB_CMD_READ_SG_OLD = 0x82, |
| 107 | MYRB_CMD_WRITE_SG_OLD = 0x83 |
| 108 | } __packed; |
| 109 | |
| 110 | /* |
| 111 | * DAC960 V1 Firmware Command Status Codes. |
| 112 | */ |
| 113 | #define MYRB_STATUS_SUCCESS 0x0000 /* Common */ |
| 114 | #define MYRB_STATUS_CHECK_CONDITION 0x0002 /* Common */ |
| 115 | #define MYRB_STATUS_NO_DEVICE 0x0102 /* Common */ |
| 116 | #define MYRB_STATUS_INVALID_ADDRESS 0x0105 /* Common */ |
| 117 | #define MYRB_STATUS_INVALID_PARAM 0x0105 /* Common */ |
| 118 | #define MYRB_STATUS_IRRECOVERABLE_DATA_ERROR 0x0001 /* I/O */ |
| 119 | #define MYRB_STATUS_LDRV_NONEXISTENT_OR_OFFLINE 0x0002 /* I/O */ |
| 120 | #define MYRB_STATUS_ACCESS_BEYOND_END_OF_LDRV 0x0105 /* I/O */ |
| 121 | #define MYRB_STATUS_BAD_DATA 0x010C /* I/O */ |
| 122 | #define MYRB_STATUS_DEVICE_BUSY 0x0008 /* DCDB */ |
| 123 | #define MYRB_STATUS_DEVICE_NONRESPONSIVE 0x000E /* DCDB */ |
| 124 | #define MYRB_STATUS_COMMAND_TERMINATED 0x000F /* DCDB */ |
| 125 | #define MYRB_STATUS_START_DEVICE_FAILED 0x0002 /* Device */ |
| 126 | #define MYRB_STATUS_INVALID_CHANNEL_OR_TARGET 0x0105 /* Device */ |
| 127 | #define MYRB_STATUS_CHANNEL_BUSY 0x0106 /* Device */ |
| 128 | #define MYRB_STATUS_OUT_OF_MEMORY 0x0107 /* Device */ |
| 129 | #define MYRB_STATUS_CHANNEL_NOT_STOPPED 0x0002 /* Device */ |
| 130 | #define MYRB_STATUS_ATTEMPT_TO_RBLD_ONLINE_DRIVE 0x0002 /* Consistency */ |
| 131 | #define MYRB_STATUS_RBLD_BADBLOCKS 0x0003 /* Consistency */ |
| 132 | #define MYRB_STATUS_RBLD_NEW_DISK_FAILED 0x0004 /* Consistency */ |
| 133 | #define MYRB_STATUS_RBLD_OR_CHECK_INPROGRESS 0x0106 /* Consistency */ |
| 134 | #define MYRB_STATUS_DEPENDENT_DISK_DEAD 0x0002 /* Consistency */ |
| 135 | #define MYRB_STATUS_INCONSISTENT_BLOCKS 0x0003 /* Consistency */ |
| 136 | #define MYRB_STATUS_INVALID_OR_NONREDUNDANT_LDRV 0x0105 /* Consistency */ |
| 137 | #define MYRB_STATUS_NO_RBLD_OR_CHECK_INPROGRESS 0x0105 /* Consistency */ |
| 138 | #define MYRB_STATUS_RBLD_IN_PROGRESS_DATA_VALID 0x0000 /* Consistency */ |
| 139 | #define MYRB_STATUS_RBLD_FAILED_LDEV_FAILURE 0x0002 /* Consistency */ |
| 140 | #define MYRB_STATUS_RBLD_FAILED_BADBLOCKS 0x0003 /* Consistency */ |
| 141 | #define MYRB_STATUS_RBLD_FAILED_NEW_DRIVE_FAILED 0x0004 /* Consistency */ |
| 142 | #define MYRB_STATUS_RBLD_SUCCESS 0x0100 /* Consistency */ |
| 143 | #define MYRB_STATUS_RBLD_SUCCESS_TERMINATED 0x0107 /* Consistency */ |
| 144 | #define MYRB_STATUS_RBLD_NOT_CHECKED 0x0108 /* Consistency */ |
| 145 | #define MYRB_STATUS_BGI_SUCCESS 0x0100 /* Consistency */ |
| 146 | #define MYRB_STATUS_BGI_ABORTED 0x0005 /* Consistency */ |
| 147 | #define MYRB_STATUS_NO_BGI_INPROGRESS 0x0105 /* Consistency */ |
| 148 | #define MYRB_STATUS_ADD_CAPACITY_INPROGRESS 0x0004 /* Consistency */ |
| 149 | #define MYRB_STATUS_ADD_CAPACITY_FAILED_OR_SUSPENDED 0x00F4 /* Consistency */ |
| 150 | #define MYRB_STATUS_CONFIG2_CSUM_ERROR 0x0002 /* Configuration */ |
| 151 | #define MYRB_STATUS_CONFIGURATION_SUSPENDED 0x0106 /* Configuration */ |
| 152 | #define MYRB_STATUS_FAILED_TO_CONFIGURE_NVRAM 0x0105 /* Configuration */ |
| 153 | #define MYRB_STATUS_CONFIGURATION_NOT_SAVED 0x0106 /* Configuration */ |
| 154 | #define MYRB_STATUS_SUBSYS_NOTINSTALLED 0x0001 /* Subsystem */ |
| 155 | #define MYRB_STATUS_SUBSYS_FAILED 0x0002 /* Subsystem */ |
| 156 | #define MYRB_STATUS_SUBSYS_BUSY 0x0106 /* Subsystem */ |
| 157 | #define MYRB_STATUS_SUBSYS_TIMEOUT 0x0108 /* Subsystem */ |
| 158 | |
| 159 | /* |
| 160 | * DAC960 V1 Firmware Enquiry Command reply structure. |
| 161 | */ |
| 162 | struct myrb_enquiry { |
| 163 | unsigned char ldev_count; /* Byte 0 */ |
| 164 | unsigned int rsvd1:24; /* Bytes 1-3 */ |
| 165 | unsigned int ldev_sizes[32]; /* Bytes 4-131 */ |
| 166 | unsigned short flash_age; /* Bytes 132-133 */ |
| 167 | struct { |
| 168 | unsigned char deferred:1; /* Byte 134 Bit 0 */ |
| 169 | unsigned char low_bat:1; /* Byte 134 Bit 1 */ |
| 170 | unsigned char rsvd2:6; /* Byte 134 Bits 2-7 */ |
| 171 | } status; |
| 172 | unsigned char rsvd3:8; /* Byte 135 */ |
| 173 | unsigned char fw_minor_version; /* Byte 136 */ |
| 174 | unsigned char fw_major_version; /* Byte 137 */ |
| 175 | enum { |
| 176 | MYRB_NO_STDBY_RBLD_OR_CHECK_IN_PROGRESS = 0x00, |
| 177 | MYRB_STDBY_RBLD_IN_PROGRESS = 0x01, |
| 178 | MYRB_BG_RBLD_IN_PROGRESS = 0x02, |
| 179 | MYRB_BG_CHECK_IN_PROGRESS = 0x03, |
| 180 | MYRB_STDBY_RBLD_COMPLETED_WITH_ERROR = 0xFF, |
| 181 | MYRB_BG_RBLD_OR_CHECK_FAILED_DRIVE_FAILED = 0xF0, |
| 182 | MYRB_BG_RBLD_OR_CHECK_FAILED_LDEV_FAILED = 0xF1, |
| 183 | MYRB_BG_RBLD_OR_CHECK_FAILED_OTHER = 0xF2, |
| 184 | MYRB_BG_RBLD_OR_CHECK_SUCCESS_TERMINATED = 0xF3 |
| 185 | } __packed rbld; /* Byte 138 */ |
| 186 | unsigned char max_tcq; /* Byte 139 */ |
| 187 | unsigned char ldev_offline; /* Byte 140 */ |
| 188 | unsigned char rsvd4:8; /* Byte 141 */ |
| 189 | unsigned short ev_seq; /* Bytes 142-143 */ |
| 190 | unsigned char ldev_critical; /* Byte 144 */ |
| 191 | unsigned int rsvd5:24; /* Bytes 145-147 */ |
| 192 | unsigned char pdev_dead; /* Byte 148 */ |
| 193 | unsigned char rsvd6:8; /* Byte 149 */ |
| 194 | unsigned char rbld_count; /* Byte 150 */ |
| 195 | struct { |
| 196 | unsigned char rsvd7:3; /* Byte 151 Bits 0-2 */ |
| 197 | unsigned char bbu_present:1; /* Byte 151 Bit 3 */ |
| 198 | unsigned char rsvd8:4; /* Byte 151 Bits 4-7 */ |
| 199 | } misc; |
| 200 | struct { |
| 201 | unsigned char target; |
| 202 | unsigned char channel; |
| 203 | } dead_drives[21]; /* Bytes 152-194 */ |
| 204 | unsigned char rsvd9[62]; /* Bytes 195-255 */ |
| 205 | } __packed; |
| 206 | |
| 207 | /* |
| 208 | * DAC960 V1 Firmware Enquiry2 Command reply structure. |
| 209 | */ |
| 210 | struct myrb_enquiry2 { |
| 211 | struct { |
| 212 | enum { |
| 213 | DAC960_V1_P_PD_PU = 0x01, |
| 214 | DAC960_V1_PL = 0x02, |
| 215 | DAC960_V1_PG = 0x10, |
| 216 | DAC960_V1_PJ = 0x11, |
| 217 | DAC960_V1_PR = 0x12, |
| 218 | DAC960_V1_PT = 0x13, |
| 219 | DAC960_V1_PTL0 = 0x14, |
| 220 | DAC960_V1_PRL = 0x15, |
| 221 | DAC960_V1_PTL1 = 0x16, |
| 222 | DAC960_V1_1164P = 0x20 |
| 223 | } __packed sub_model; /* Byte 0 */ |
| 224 | unsigned char actual_channels; /* Byte 1 */ |
| 225 | enum { |
| 226 | MYRB_5_CHANNEL_BOARD = 0x01, |
| 227 | MYRB_3_CHANNEL_BOARD = 0x02, |
| 228 | MYRB_2_CHANNEL_BOARD = 0x03, |
| 229 | MYRB_3_CHANNEL_ASIC_DAC = 0x04 |
| 230 | } __packed model; /* Byte 2 */ |
| 231 | enum { |
| 232 | MYRB_EISA_CONTROLLER = 0x01, |
| 233 | MYRB_MCA_CONTROLLER = 0x02, |
| 234 | MYRB_PCI_CONTROLLER = 0x03, |
| 235 | MYRB_SCSI_TO_SCSI = 0x08 |
| 236 | } __packed controller; /* Byte 3 */ |
| 237 | } hw; /* Bytes 0-3 */ |
| 238 | /* MajorVersion.MinorVersion-FirmwareType-TurnID */ |
| 239 | struct { |
| 240 | unsigned char major_version; /* Byte 4 */ |
| 241 | unsigned char minor_version; /* Byte 5 */ |
| 242 | unsigned char turn_id; /* Byte 6 */ |
| 243 | char firmware_type; /* Byte 7 */ |
| 244 | } fw; /* Bytes 4-7 */ |
| 245 | unsigned int rsvd1; /* Byte 8-11 */ |
| 246 | unsigned char cfg_chan; /* Byte 12 */ |
| 247 | unsigned char cur_chan; /* Byte 13 */ |
| 248 | unsigned char max_targets; /* Byte 14 */ |
| 249 | unsigned char max_tcq; /* Byte 15 */ |
| 250 | unsigned char max_ldev; /* Byte 16 */ |
| 251 | unsigned char max_arms; /* Byte 17 */ |
| 252 | unsigned char max_spans; /* Byte 18 */ |
| 253 | unsigned char rsvd2; /* Byte 19 */ |
| 254 | unsigned int rsvd3; /* Bytes 20-23 */ |
| 255 | unsigned int mem_size; /* Bytes 24-27 */ |
| 256 | unsigned int cache_size; /* Bytes 28-31 */ |
| 257 | unsigned int flash_size; /* Bytes 32-35 */ |
| 258 | unsigned int nvram_size; /* Bytes 36-39 */ |
| 259 | struct { |
| 260 | enum { |
| 261 | MYRB_RAM_TYPE_DRAM = 0x0, |
| 262 | MYRB_RAM_TYPE_EDO = 0x1, |
| 263 | MYRB_RAM_TYPE_SDRAM = 0x2, |
| 264 | MYRB_RAM_TYPE_Last = 0x7 |
| 265 | } __packed ram:3; /* Byte 40 Bits 0-2 */ |
| 266 | enum { |
| 267 | MYRB_ERR_CORR_None = 0x0, |
| 268 | MYRB_ERR_CORR_Parity = 0x1, |
| 269 | MYRB_ERR_CORR_ECC = 0x2, |
| 270 | MYRB_ERR_CORR_Last = 0x7 |
| 271 | } __packed ec:3; /* Byte 40 Bits 3-5 */ |
| 272 | unsigned char fast_page:1; /* Byte 40 Bit 6 */ |
| 273 | unsigned char low_power:1; /* Byte 40 Bit 7 */ |
| 274 | unsigned char rsvd4; /* Bytes 41 */ |
| 275 | } mem_type; |
| 276 | unsigned short clock_speed; /* Bytes 42-43 */ |
| 277 | unsigned short mem_speed; /* Bytes 44-45 */ |
| 278 | unsigned short hw_speed; /* Bytes 46-47 */ |
| 279 | unsigned char rsvd5[12]; /* Bytes 48-59 */ |
| 280 | unsigned short max_cmds; /* Bytes 60-61 */ |
| 281 | unsigned short max_sge; /* Bytes 62-63 */ |
| 282 | unsigned short max_drv_cmds; /* Bytes 64-65 */ |
| 283 | unsigned short max_io_desc; /* Bytes 66-67 */ |
| 284 | unsigned short max_sectors; /* Bytes 68-69 */ |
| 285 | unsigned char latency; /* Byte 70 */ |
| 286 | unsigned char rsvd6; /* Byte 71 */ |
| 287 | unsigned char scsi_tmo; /* Byte 72 */ |
| 288 | unsigned char rsvd7; /* Byte 73 */ |
| 289 | unsigned short min_freelines; /* Bytes 74-75 */ |
| 290 | unsigned char rsvd8[8]; /* Bytes 76-83 */ |
| 291 | unsigned char rbld_rate_const; /* Byte 84 */ |
| 292 | unsigned char rsvd9[11]; /* Byte 85-95 */ |
| 293 | unsigned short pdrv_block_size; /* Bytes 96-97 */ |
| 294 | unsigned short ldev_block_size; /* Bytes 98-99 */ |
| 295 | unsigned short max_blocks_per_cmd; /* Bytes 100-101 */ |
| 296 | unsigned short block_factor; /* Bytes 102-103 */ |
| 297 | unsigned short cacheline_size; /* Bytes 104-105 */ |
| 298 | struct { |
| 299 | enum { |
| 300 | MYRB_WIDTH_NARROW_8BIT = 0x0, |
| 301 | MYRB_WIDTH_WIDE_16BIT = 0x1, |
| 302 | MYRB_WIDTH_WIDE_32BIT = 0x2 |
| 303 | } __packed bus_width:2; /* Byte 106 Bits 0-1 */ |
| 304 | enum { |
| 305 | MYRB_SCSI_SPEED_FAST = 0x0, |
| 306 | MYRB_SCSI_SPEED_ULTRA = 0x1, |
| 307 | MYRB_SCSI_SPEED_ULTRA2 = 0x2 |
| 308 | } __packed bus_speed:2; /* Byte 106 Bits 2-3 */ |
| 309 | unsigned char differential:1; /* Byte 106 Bit 4 */ |
| 310 | unsigned char rsvd10:3; /* Byte 106 Bits 5-7 */ |
| 311 | } scsi_cap; |
| 312 | unsigned char rsvd11[5]; /* Byte 107-111 */ |
| 313 | unsigned short fw_build; /* Bytes 112-113 */ |
| 314 | enum { |
| 315 | MYRB_FAULT_AEMI = 0x01, |
| 316 | MYRB_FAULT_OEM1 = 0x02, |
| 317 | MYRB_FAULT_OEM2 = 0x04, |
| 318 | MYRB_FAULT_OEM3 = 0x08, |
| 319 | MYRB_FAULT_CONNER = 0x10, |
| 320 | MYRB_FAULT_SAFTE = 0x20 |
| 321 | } __packed fault_mgmt; /* Byte 114 */ |
| 322 | unsigned char rsvd12; /* Byte 115 */ |
| 323 | struct { |
| 324 | unsigned int clustering:1; /* Byte 116 Bit 0 */ |
| 325 | unsigned int online_RAID_expansion:1; /* Byte 116 Bit 1 */ |
| 326 | unsigned int readahead:1; /* Byte 116 Bit 2 */ |
| 327 | unsigned int bgi:1; /* Byte 116 Bit 3 */ |
| 328 | unsigned int rsvd13:28; /* Bytes 116-119 */ |
| 329 | } fw_features; |
| 330 | unsigned char rsvd14[8]; /* Bytes 120-127 */ |
| 331 | } __packed; |
| 332 | |
| 333 | /* |
| 334 | * DAC960 V1 Firmware Logical Drive State type. |
| 335 | */ |
| 336 | enum myrb_devstate { |
| 337 | MYRB_DEVICE_DEAD = 0x00, |
| 338 | MYRB_DEVICE_WO = 0x02, |
| 339 | MYRB_DEVICE_ONLINE = 0x03, |
| 340 | MYRB_DEVICE_CRITICAL = 0x04, |
| 341 | MYRB_DEVICE_STANDBY = 0x10, |
| 342 | MYRB_DEVICE_OFFLINE = 0xFF |
| 343 | } __packed; |
| 344 | |
| 345 | /* |
| 346 | * DAC960 V1 RAID Levels |
| 347 | */ |
| 348 | enum myrb_raidlevel { |
| 349 | MYRB_RAID_LEVEL0 = 0x0, /* RAID 0 */ |
| 350 | MYRB_RAID_LEVEL1 = 0x1, /* RAID 1 */ |
| 351 | MYRB_RAID_LEVEL3 = 0x3, /* RAID 3 */ |
| 352 | MYRB_RAID_LEVEL5 = 0x5, /* RAID 5 */ |
| 353 | MYRB_RAID_LEVEL6 = 0x6, /* RAID 6 */ |
| 354 | MYRB_RAID_JBOD = 0x7, /* RAID 7 (JBOD) */ |
| 355 | } __packed; |
| 356 | |
| 357 | /* |
| 358 | * DAC960 V1 Firmware Logical Drive Information structure. |
| 359 | */ |
| 360 | struct myrb_ldev_info { |
| 361 | unsigned int size; /* Bytes 0-3 */ |
| 362 | enum myrb_devstate state; /* Byte 4 */ |
| 363 | unsigned int raid_level:7; /* Byte 5 Bits 0-6 */ |
| 364 | unsigned int wb_enabled:1; /* Byte 5 Bit 7 */ |
| 365 | unsigned int rsvd:16; /* Bytes 6-7 */ |
| 366 | }; |
| 367 | |
| 368 | /* |
| 369 | * DAC960 V1 Firmware Perform Event Log Operation Types. |
| 370 | */ |
| 371 | #define DAC960_V1_GetEventLogEntry 0x00 |
| 372 | |
| 373 | /* |
| 374 | * DAC960 V1 Firmware Get Event Log Entry Command reply structure. |
| 375 | */ |
| 376 | struct myrb_log_entry { |
| 377 | unsigned char msg_type; /* Byte 0 */ |
| 378 | unsigned char msg_len; /* Byte 1 */ |
| 379 | unsigned char target:5; /* Byte 2 Bits 0-4 */ |
| 380 | unsigned char channel:3; /* Byte 2 Bits 5-7 */ |
| 381 | unsigned char lun:6; /* Byte 3 Bits 0-5 */ |
| 382 | unsigned char rsvd1:2; /* Byte 3 Bits 6-7 */ |
| 383 | unsigned short seq_num; /* Bytes 4-5 */ |
| 384 | unsigned char sense[26]; /* Bytes 6-31 */ |
| 385 | }; |
| 386 | |
| 387 | /* |
| 388 | * DAC960 V1 Firmware Get Device State Command reply structure. |
| 389 | * The structure is padded by 2 bytes for compatibility with Version 2.xx |
| 390 | * Firmware. |
| 391 | */ |
| 392 | struct myrb_pdev_state { |
| 393 | unsigned int present:1; /* Byte 0 Bit 0 */ |
| 394 | unsigned int :7; /* Byte 0 Bits 1-7 */ |
| 395 | enum { |
| 396 | MYRB_TYPE_OTHER = 0x0, |
| 397 | MYRB_TYPE_DISK = 0x1, |
| 398 | MYRB_TYPE_TAPE = 0x2, |
| 399 | MYRB_TYPE_CDROM_OR_WORM = 0x3 |
| 400 | } __packed devtype:2; /* Byte 1 Bits 0-1 */ |
| 401 | unsigned int rsvd1:1; /* Byte 1 Bit 2 */ |
| 402 | unsigned int fast20:1; /* Byte 1 Bit 3 */ |
| 403 | unsigned int sync:1; /* Byte 1 Bit 4 */ |
| 404 | unsigned int fast:1; /* Byte 1 Bit 5 */ |
| 405 | unsigned int wide:1; /* Byte 1 Bit 6 */ |
| 406 | unsigned int tcq_supported:1; /* Byte 1 Bit 7 */ |
| 407 | enum myrb_devstate state; /* Byte 2 */ |
| 408 | unsigned int rsvd2:8; /* Byte 3 */ |
| 409 | unsigned int sync_multiplier; /* Byte 4 */ |
| 410 | unsigned int sync_offset:5; /* Byte 5 Bits 0-4 */ |
| 411 | unsigned int rsvd3:3; /* Byte 5 Bits 5-7 */ |
| 412 | unsigned int size; /* Bytes 6-9 */ |
| 413 | unsigned int rsvd4:16; /* Bytes 10-11 */ |
| 414 | } __packed; |
| 415 | |
| 416 | /* |
| 417 | * DAC960 V1 Firmware Get Rebuild Progress Command reply structure. |
| 418 | */ |
| 419 | struct myrb_rbld_progress { |
| 420 | unsigned int ldev_num; /* Bytes 0-3 */ |
| 421 | unsigned int ldev_size; /* Bytes 4-7 */ |
| 422 | unsigned int blocks_left; /* Bytes 8-11 */ |
| 423 | }; |
| 424 | |
| 425 | /* |
| 426 | * DAC960 V1 Firmware Background Initialization Status Command reply structure. |
| 427 | */ |
| 428 | struct myrb_bgi_status { |
| 429 | unsigned int ldev_size; /* Bytes 0-3 */ |
| 430 | unsigned int blocks_done; /* Bytes 4-7 */ |
| 431 | unsigned char rsvd1[12]; /* Bytes 8-19 */ |
| 432 | unsigned int ldev_num; /* Bytes 20-23 */ |
| 433 | unsigned char raid_level; /* Byte 24 */ |
| 434 | enum { |
| 435 | MYRB_BGI_INVALID = 0x00, |
| 436 | MYRB_BGI_STARTED = 0x02, |
| 437 | MYRB_BGI_INPROGRESS = 0x04, |
| 438 | MYRB_BGI_SUSPENDED = 0x05, |
| 439 | MYRB_BGI_CANCELLED = 0x06 |
| 440 | } __packed status; /* Byte 25 */ |
| 441 | unsigned char rsvd2[6]; /* Bytes 26-31 */ |
| 442 | }; |
| 443 | |
| 444 | /* |
| 445 | * DAC960 V1 Firmware Error Table Entry structure. |
| 446 | */ |
| 447 | struct myrb_error_entry { |
| 448 | unsigned char parity_err; /* Byte 0 */ |
| 449 | unsigned char soft_err; /* Byte 1 */ |
| 450 | unsigned char hard_err; /* Byte 2 */ |
| 451 | unsigned char misc_err; /* Byte 3 */ |
| 452 | }; |
| 453 | |
| 454 | /* |
| 455 | * DAC960 V1 Firmware Read Config2 Command reply structure. |
| 456 | */ |
| 457 | struct myrb_config2 { |
| 458 | unsigned rsvd1:1; /* Byte 0 Bit 0 */ |
| 459 | unsigned active_negation:1; /* Byte 0 Bit 1 */ |
| 460 | unsigned rsvd2:5; /* Byte 0 Bits 2-6 */ |
| 461 | unsigned no_rescan_on_reset_during_scan:1; /* Byte 0 Bit 7 */ |
| 462 | unsigned StorageWorks_support:1; /* Byte 1 Bit 0 */ |
| 463 | unsigned HewlettPackard_support:1; /* Byte 1 Bit 1 */ |
| 464 | unsigned no_disconnect_on_first_command:1; /* Byte 1 Bit 2 */ |
| 465 | unsigned rsvd3:2; /* Byte 1 Bits 3-4 */ |
| 466 | unsigned AEMI_ARM:1; /* Byte 1 Bit 5 */ |
| 467 | unsigned AEMI_OFM:1; /* Byte 1 Bit 6 */ |
| 468 | unsigned rsvd4:1; /* Byte 1 Bit 7 */ |
| 469 | enum { |
| 470 | MYRB_OEMID_MYLEX = 0x00, |
| 471 | MYRB_OEMID_IBM = 0x08, |
| 472 | MYRB_OEMID_HP = 0x0A, |
| 473 | MYRB_OEMID_DEC = 0x0C, |
| 474 | MYRB_OEMID_SIEMENS = 0x10, |
| 475 | MYRB_OEMID_INTEL = 0x12 |
| 476 | } __packed OEMID; /* Byte 2 */ |
| 477 | unsigned char oem_model_number; /* Byte 3 */ |
| 478 | unsigned char physical_sector; /* Byte 4 */ |
| 479 | unsigned char logical_sector; /* Byte 5 */ |
| 480 | unsigned char block_factor; /* Byte 6 */ |
| 481 | unsigned readahead_enabled:1; /* Byte 7 Bit 0 */ |
| 482 | unsigned low_BIOS_delay:1; /* Byte 7 Bit 1 */ |
| 483 | unsigned rsvd5:2; /* Byte 7 Bits 2-3 */ |
| 484 | unsigned restrict_reassign_to_one_sector:1; /* Byte 7 Bit 4 */ |
| 485 | unsigned rsvd6:1; /* Byte 7 Bit 5 */ |
| 486 | unsigned FUA_during_write_recovery:1; /* Byte 7 Bit 6 */ |
| 487 | unsigned enable_LeftSymmetricRAID5Algorithm:1; /* Byte 7 Bit 7 */ |
| 488 | unsigned char default_rebuild_rate; /* Byte 8 */ |
| 489 | unsigned char rsvd7; /* Byte 9 */ |
| 490 | unsigned char blocks_per_cacheline; /* Byte 10 */ |
| 491 | unsigned char blocks_per_stripe; /* Byte 11 */ |
| 492 | struct { |
| 493 | enum { |
| 494 | MYRB_SPEED_ASYNC = 0x0, |
| 495 | MYRB_SPEED_SYNC_8MHz = 0x1, |
| 496 | MYRB_SPEED_SYNC_5MHz = 0x2, |
| 497 | MYRB_SPEED_SYNC_10_OR_20MHz = 0x3 |
| 498 | } __packed speed:2; /* Byte 11 Bits 0-1 */ |
| 499 | unsigned force_8bit:1; /* Byte 11 Bit 2 */ |
| 500 | unsigned disable_fast20:1; /* Byte 11 Bit 3 */ |
| 501 | unsigned rsvd8:3; /* Byte 11 Bits 4-6 */ |
| 502 | unsigned enable_tcq:1; /* Byte 11 Bit 7 */ |
| 503 | } __packed channelparam[6]; /* Bytes 12-17 */ |
| 504 | unsigned char SCSIInitiatorID; /* Byte 18 */ |
| 505 | unsigned char rsvd9; /* Byte 19 */ |
| 506 | enum { |
| 507 | MYRB_STARTUP_CONTROLLER_SPINUP = 0x00, |
| 508 | MYRB_STARTUP_POWERON_SPINUP = 0x01 |
| 509 | } __packed startup; /* Byte 20 */ |
| 510 | unsigned char simultaneous_device_spinup_count; /* Byte 21 */ |
| 511 | unsigned char seconds_delay_between_spinups; /* Byte 22 */ |
| 512 | unsigned char rsvd10[29]; /* Bytes 23-51 */ |
| 513 | unsigned BIOS_disabled:1; /* Byte 52 Bit 0 */ |
| 514 | unsigned CDROM_boot_enabled:1; /* Byte 52 Bit 1 */ |
| 515 | unsigned rsvd11:3; /* Byte 52 Bits 2-4 */ |
| 516 | enum { |
| 517 | MYRB_GEOM_128_32 = 0x0, |
| 518 | MYRB_GEOM_255_63 = 0x1, |
| 519 | MYRB_GEOM_RESERVED1 = 0x2, |
| 520 | MYRB_GEOM_RESERVED2 = 0x3 |
| 521 | } __packed drive_geometry:2; /* Byte 52 Bits 5-6 */ |
| 522 | unsigned rsvd12:1; /* Byte 52 Bit 7 */ |
| 523 | unsigned char rsvd13[9]; /* Bytes 53-61 */ |
| 524 | unsigned short csum; /* Bytes 62-63 */ |
| 525 | }; |
| 526 | |
| 527 | /* |
| 528 | * DAC960 V1 Firmware DCDB request structure. |
| 529 | */ |
| 530 | struct myrb_dcdb { |
| 531 | unsigned target:4; /* Byte 0 Bits 0-3 */ |
| 532 | unsigned channel:4; /* Byte 0 Bits 4-7 */ |
| 533 | enum { |
| 534 | MYRB_DCDB_XFER_NONE = 0, |
| 535 | MYRB_DCDB_XFER_DEVICE_TO_SYSTEM = 1, |
| 536 | MYRB_DCDB_XFER_SYSTEM_TO_DEVICE = 2, |
| 537 | MYRB_DCDB_XFER_ILLEGAL = 3 |
| 538 | } __packed data_xfer:2; /* Byte 1 Bits 0-1 */ |
| 539 | unsigned early_status:1; /* Byte 1 Bit 2 */ |
| 540 | unsigned rsvd1:1; /* Byte 1 Bit 3 */ |
| 541 | enum { |
| 542 | MYRB_DCDB_TMO_24_HRS = 0, |
| 543 | MYRB_DCDB_TMO_10_SECS = 1, |
| 544 | MYRB_DCDB_TMO_60_SECS = 2, |
| 545 | MYRB_DCDB_TMO_10_MINS = 3 |
| 546 | } __packed timeout:2; /* Byte 1 Bits 4-5 */ |
| 547 | unsigned no_autosense:1; /* Byte 1 Bit 6 */ |
| 548 | unsigned allow_disconnect:1; /* Byte 1 Bit 7 */ |
| 549 | unsigned short xfer_len_lo; /* Bytes 2-3 */ |
| 550 | u32 dma_addr; /* Bytes 4-7 */ |
| 551 | unsigned char cdb_len:4; /* Byte 8 Bits 0-3 */ |
| 552 | unsigned char xfer_len_hi4:4; /* Byte 8 Bits 4-7 */ |
| 553 | unsigned char sense_len; /* Byte 9 */ |
| 554 | unsigned char cdb[12]; /* Bytes 10-21 */ |
| 555 | unsigned char sense[64]; /* Bytes 22-85 */ |
| 556 | unsigned char status; /* Byte 86 */ |
| 557 | unsigned char rsvd2; /* Byte 87 */ |
| 558 | }; |
| 559 | |
| 560 | /* |
| 561 | * DAC960 V1 Firmware Scatter/Gather List Type 1 32 Bit Address |
| 562 | *32 Bit Byte Count structure. |
| 563 | */ |
| 564 | struct myrb_sge { |
| 565 | u32 sge_addr; /* Bytes 0-3 */ |
| 566 | u32 sge_count; /* Bytes 4-7 */ |
| 567 | }; |
| 568 | |
| 569 | /* |
| 570 | * 13 Byte DAC960 V1 Firmware Command Mailbox structure. |
| 571 | * Bytes 13-15 are not used. The structure is padded to 16 bytes for |
| 572 | * efficient access. |
| 573 | */ |
| 574 | union myrb_cmd_mbox { |
| 575 | unsigned int words[4]; /* Words 0-3 */ |
| 576 | unsigned char bytes[16]; /* Bytes 0-15 */ |
| 577 | struct { |
| 578 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 579 | unsigned char id; /* Byte 1 */ |
| 580 | unsigned char rsvd[14]; /* Bytes 2-15 */ |
| 581 | } __packed common; |
| 582 | struct { |
| 583 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 584 | unsigned char id; /* Byte 1 */ |
| 585 | unsigned char rsvd1[6]; /* Bytes 2-7 */ |
| 586 | u32 addr; /* Bytes 8-11 */ |
| 587 | unsigned char rsvd2[4]; /* Bytes 12-15 */ |
| 588 | } __packed type3; |
| 589 | struct { |
| 590 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 591 | unsigned char id; /* Byte 1 */ |
| 592 | unsigned char optype; /* Byte 2 */ |
| 593 | unsigned char rsvd1[5]; /* Bytes 3-7 */ |
| 594 | u32 addr; /* Bytes 8-11 */ |
| 595 | unsigned char rsvd2[4]; /* Bytes 12-15 */ |
| 596 | } __packed type3B; |
| 597 | struct { |
| 598 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 599 | unsigned char id; /* Byte 1 */ |
| 600 | unsigned char rsvd1[5]; /* Bytes 2-6 */ |
| 601 | unsigned char ldev_num:6; /* Byte 7 Bits 0-6 */ |
| 602 | unsigned char auto_restore:1; /* Byte 7 Bit 7 */ |
| 603 | unsigned char rsvd2[8]; /* Bytes 8-15 */ |
| 604 | } __packed type3C; |
| 605 | struct { |
| 606 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 607 | unsigned char id; /* Byte 1 */ |
| 608 | unsigned char channel; /* Byte 2 */ |
| 609 | unsigned char target; /* Byte 3 */ |
| 610 | enum myrb_devstate state; /* Byte 4 */ |
| 611 | unsigned char rsvd1[3]; /* Bytes 5-7 */ |
| 612 | u32 addr; /* Bytes 8-11 */ |
| 613 | unsigned char rsvd2[4]; /* Bytes 12-15 */ |
| 614 | } __packed type3D; |
| 615 | struct { |
| 616 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 617 | unsigned char id; /* Byte 1 */ |
| 618 | unsigned char optype; /* Byte 2 */ |
| 619 | unsigned char opqual; /* Byte 3 */ |
| 620 | unsigned short ev_seq; /* Bytes 4-5 */ |
| 621 | unsigned char rsvd1[2]; /* Bytes 6-7 */ |
| 622 | u32 addr; /* Bytes 8-11 */ |
| 623 | unsigned char rsvd2[4]; /* Bytes 12-15 */ |
| 624 | } __packed type3E; |
| 625 | struct { |
| 626 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 627 | unsigned char id; /* Byte 1 */ |
| 628 | unsigned char rsvd1[2]; /* Bytes 2-3 */ |
| 629 | unsigned char rbld_rate; /* Byte 4 */ |
| 630 | unsigned char rsvd2[3]; /* Bytes 5-7 */ |
| 631 | u32 addr; /* Bytes 8-11 */ |
| 632 | unsigned char rsvd3[4]; /* Bytes 12-15 */ |
| 633 | } __packed type3R; |
| 634 | struct { |
| 635 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 636 | unsigned char id; /* Byte 1 */ |
| 637 | unsigned short xfer_len; /* Bytes 2-3 */ |
| 638 | unsigned int lba; /* Bytes 4-7 */ |
| 639 | u32 addr; /* Bytes 8-11 */ |
| 640 | unsigned char ldev_num; /* Byte 12 */ |
| 641 | unsigned char rsvd[3]; /* Bytes 13-15 */ |
| 642 | } __packed type4; |
| 643 | struct { |
| 644 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 645 | unsigned char id; /* Byte 1 */ |
| 646 | struct { |
| 647 | unsigned short xfer_len:11; /* Bytes 2-3 */ |
| 648 | unsigned char ldev_num:5; /* Byte 3 Bits 3-7 */ |
| 649 | } __packed ld; |
| 650 | unsigned int lba; /* Bytes 4-7 */ |
| 651 | u32 addr; /* Bytes 8-11 */ |
| 652 | unsigned char sg_count:6; /* Byte 12 Bits 0-5 */ |
| 653 | enum { |
| 654 | MYRB_SGL_ADDR32_COUNT32 = 0x0, |
| 655 | MYRB_SGL_ADDR32_COUNT16 = 0x1, |
| 656 | MYRB_SGL_COUNT32_ADDR32 = 0x2, |
| 657 | MYRB_SGL_COUNT16_ADDR32 = 0x3 |
| 658 | } __packed sg_type:2; /* Byte 12 Bits 6-7 */ |
| 659 | unsigned char rsvd[3]; /* Bytes 13-15 */ |
| 660 | } __packed type5; |
| 661 | struct { |
| 662 | enum myrb_cmd_opcode opcode; /* Byte 0 */ |
| 663 | unsigned char id; /* Byte 1 */ |
| 664 | unsigned char opcode2; /* Byte 2 */ |
| 665 | unsigned char rsvd1:8; /* Byte 3 */ |
| 666 | u32 cmd_mbox_addr; /* Bytes 4-7 */ |
| 667 | u32 stat_mbox_addr; /* Bytes 8-11 */ |
| 668 | unsigned char rsvd2[4]; /* Bytes 12-15 */ |
| 669 | } __packed typeX; |
| 670 | }; |
| 671 | |
| 672 | /* |
| 673 | * DAC960 V1 Firmware Controller Status Mailbox structure. |
| 674 | */ |
| 675 | struct myrb_stat_mbox { |
| 676 | unsigned char id; /* Byte 0 */ |
| 677 | unsigned char rsvd:7; /* Byte 1 Bits 0-6 */ |
| 678 | unsigned char valid:1; /* Byte 1 Bit 7 */ |
| 679 | unsigned short status; /* Bytes 2-3 */ |
| 680 | }; |
| 681 | |
| 682 | struct myrb_cmdblk { |
| 683 | union myrb_cmd_mbox mbox; |
| 684 | unsigned short status; |
| 685 | struct completion *completion; |
| 686 | struct myrb_dcdb *dcdb; |
| 687 | dma_addr_t dcdb_addr; |
| 688 | struct myrb_sge *sgl; |
| 689 | dma_addr_t sgl_addr; |
| 690 | }; |
| 691 | |
| 692 | struct myrb_hba { |
| 693 | unsigned int ldev_block_size; |
| 694 | unsigned char ldev_geom_heads; |
| 695 | unsigned char ldev_geom_sectors; |
| 696 | unsigned char bus_width; |
| 697 | unsigned short stripe_size; |
| 698 | unsigned short segment_size; |
| 699 | unsigned short new_ev_seq; |
| 700 | unsigned short old_ev_seq; |
| 701 | bool dual_mode_interface; |
| 702 | bool bgi_status_supported; |
| 703 | bool safte_enabled; |
| 704 | bool need_ldev_info; |
| 705 | bool need_err_info; |
| 706 | bool need_rbld; |
| 707 | bool need_cc_status; |
| 708 | bool need_bgi_status; |
| 709 | bool rbld_first; |
| 710 | |
| 711 | struct pci_dev *pdev; |
| 712 | struct Scsi_Host *host; |
| 713 | |
| 714 | struct workqueue_struct *work_q; |
| 715 | char work_q_name[20]; |
| 716 | struct delayed_work monitor_work; |
| 717 | unsigned long primary_monitor_time; |
| 718 | unsigned long secondary_monitor_time; |
| 719 | |
| 720 | struct dma_pool *sg_pool; |
| 721 | struct dma_pool *dcdb_pool; |
| 722 | |
| 723 | spinlock_t queue_lock; |
| 724 | |
| 725 | void (*qcmd)(struct myrb_hba *cs, struct myrb_cmdblk *cmd_blk); |
| 726 | void (*write_cmd_mbox)(union myrb_cmd_mbox *next_mbox, |
| 727 | union myrb_cmd_mbox *cmd_mbox); |
| 728 | void (*get_cmd_mbox)(void __iomem *base); |
| 729 | void (*disable_intr)(void __iomem *base); |
| 730 | void (*reset)(void __iomem *base); |
| 731 | |
| 732 | unsigned int ctlr_num; |
| 733 | unsigned char model_name[20]; |
| 734 | unsigned char fw_version[12]; |
| 735 | |
| 736 | unsigned int irq; |
| 737 | phys_addr_t io_addr; |
| 738 | phys_addr_t pci_addr; |
| 739 | void __iomem *io_base; |
| 740 | void __iomem *mmio_base; |
| 741 | |
| 742 | size_t cmd_mbox_size; |
| 743 | dma_addr_t cmd_mbox_addr; |
| 744 | union myrb_cmd_mbox *first_cmd_mbox; |
| 745 | union myrb_cmd_mbox *last_cmd_mbox; |
| 746 | union myrb_cmd_mbox *next_cmd_mbox; |
| 747 | union myrb_cmd_mbox *prev_cmd_mbox1; |
| 748 | union myrb_cmd_mbox *prev_cmd_mbox2; |
| 749 | |
| 750 | size_t stat_mbox_size; |
| 751 | dma_addr_t stat_mbox_addr; |
| 752 | struct myrb_stat_mbox *first_stat_mbox; |
| 753 | struct myrb_stat_mbox *last_stat_mbox; |
| 754 | struct myrb_stat_mbox *next_stat_mbox; |
| 755 | |
| 756 | struct myrb_cmdblk dcmd_blk; |
| 757 | struct myrb_cmdblk mcmd_blk; |
| 758 | struct mutex dcmd_mutex; |
| 759 | |
| 760 | struct myrb_enquiry *enquiry; |
| 761 | dma_addr_t enquiry_addr; |
| 762 | |
| 763 | struct myrb_error_entry *err_table; |
| 764 | dma_addr_t err_table_addr; |
| 765 | |
| 766 | unsigned short last_rbld_status; |
| 767 | |
| 768 | struct myrb_ldev_info *ldev_info_buf; |
| 769 | dma_addr_t ldev_info_addr; |
| 770 | |
| 771 | struct myrb_bgi_status bgi_status; |
| 772 | |
| 773 | struct mutex dma_mutex; |
| 774 | }; |
| 775 | |
| 776 | /* |
| 777 | * DAC960 LA Series Controller Interface Register Offsets. |
| 778 | */ |
| 779 | #define DAC960_LA_mmio_size 0x80 |
| 780 | |
| 781 | enum DAC960_LA_reg_offset { |
| 782 | DAC960_LA_IRQMASK_OFFSET = 0x34, |
| 783 | DAC960_LA_CMDOP_OFFSET = 0x50, |
| 784 | DAC960_LA_CMDID_OFFSET = 0x51, |
| 785 | DAC960_LA_MBOX2_OFFSET = 0x52, |
| 786 | DAC960_LA_MBOX3_OFFSET = 0x53, |
| 787 | DAC960_LA_MBOX4_OFFSET = 0x54, |
| 788 | DAC960_LA_MBOX5_OFFSET = 0x55, |
| 789 | DAC960_LA_MBOX6_OFFSET = 0x56, |
| 790 | DAC960_LA_MBOX7_OFFSET = 0x57, |
| 791 | DAC960_LA_MBOX8_OFFSET = 0x58, |
| 792 | DAC960_LA_MBOX9_OFFSET = 0x59, |
| 793 | DAC960_LA_MBOX10_OFFSET = 0x5A, |
| 794 | DAC960_LA_MBOX11_OFFSET = 0x5B, |
| 795 | DAC960_LA_MBOX12_OFFSET = 0x5C, |
| 796 | DAC960_LA_STSID_OFFSET = 0x5D, |
| 797 | DAC960_LA_STS_OFFSET = 0x5E, |
| 798 | DAC960_LA_IDB_OFFSET = 0x60, |
| 799 | DAC960_LA_ODB_OFFSET = 0x61, |
| 800 | DAC960_LA_ERRSTS_OFFSET = 0x63, |
| 801 | }; |
| 802 | |
| 803 | /* |
| 804 | * DAC960 LA Series Inbound Door Bell Register. |
| 805 | */ |
| 806 | #define DAC960_LA_IDB_HWMBOX_NEW_CMD 0x01 |
| 807 | #define DAC960_LA_IDB_HWMBOX_ACK_STS 0x02 |
| 808 | #define DAC960_LA_IDB_GEN_IRQ 0x04 |
| 809 | #define DAC960_LA_IDB_CTRL_RESET 0x08 |
| 810 | #define DAC960_LA_IDB_MMBOX_NEW_CMD 0x10 |
| 811 | |
| 812 | #define DAC960_LA_IDB_HWMBOX_EMPTY 0x01 |
| 813 | #define DAC960_LA_IDB_INIT_DONE 0x02 |
| 814 | |
| 815 | /* |
| 816 | * DAC960 LA Series Outbound Door Bell Register. |
| 817 | */ |
| 818 | #define DAC960_LA_ODB_HWMBOX_ACK_IRQ 0x01 |
| 819 | #define DAC960_LA_ODB_MMBOX_ACK_IRQ 0x02 |
| 820 | #define DAC960_LA_ODB_HWMBOX_STS_AVAIL 0x01 |
| 821 | #define DAC960_LA_ODB_MMBOX_STS_AVAIL 0x02 |
| 822 | |
| 823 | /* |
| 824 | * DAC960 LA Series Interrupt Mask Register. |
| 825 | */ |
| 826 | #define DAC960_LA_IRQMASK_DISABLE_IRQ 0x04 |
| 827 | |
| 828 | /* |
| 829 | * DAC960 LA Series Error Status Register. |
| 830 | */ |
| 831 | #define DAC960_LA_ERRSTS_PENDING 0x02 |
| 832 | |
| 833 | /* |
| 834 | * DAC960 PG Series Controller Interface Register Offsets. |
| 835 | */ |
| 836 | #define DAC960_PG_mmio_size 0x2000 |
| 837 | |
| 838 | enum DAC960_PG_reg_offset { |
| 839 | DAC960_PG_IDB_OFFSET = 0x0020, |
| 840 | DAC960_PG_ODB_OFFSET = 0x002C, |
| 841 | DAC960_PG_IRQMASK_OFFSET = 0x0034, |
| 842 | DAC960_PG_CMDOP_OFFSET = 0x1000, |
| 843 | DAC960_PG_CMDID_OFFSET = 0x1001, |
| 844 | DAC960_PG_MBOX2_OFFSET = 0x1002, |
| 845 | DAC960_PG_MBOX3_OFFSET = 0x1003, |
| 846 | DAC960_PG_MBOX4_OFFSET = 0x1004, |
| 847 | DAC960_PG_MBOX5_OFFSET = 0x1005, |
| 848 | DAC960_PG_MBOX6_OFFSET = 0x1006, |
| 849 | DAC960_PG_MBOX7_OFFSET = 0x1007, |
| 850 | DAC960_PG_MBOX8_OFFSET = 0x1008, |
| 851 | DAC960_PG_MBOX9_OFFSET = 0x1009, |
| 852 | DAC960_PG_MBOX10_OFFSET = 0x100A, |
| 853 | DAC960_PG_MBOX11_OFFSET = 0x100B, |
| 854 | DAC960_PG_MBOX12_OFFSET = 0x100C, |
| 855 | DAC960_PG_STSID_OFFSET = 0x1018, |
| 856 | DAC960_PG_STS_OFFSET = 0x101A, |
| 857 | DAC960_PG_ERRSTS_OFFSET = 0x103F, |
| 858 | }; |
| 859 | |
| 860 | /* |
| 861 | * DAC960 PG Series Inbound Door Bell Register. |
| 862 | */ |
| 863 | #define DAC960_PG_IDB_HWMBOX_NEW_CMD 0x01 |
| 864 | #define DAC960_PG_IDB_HWMBOX_ACK_STS 0x02 |
| 865 | #define DAC960_PG_IDB_GEN_IRQ 0x04 |
| 866 | #define DAC960_PG_IDB_CTRL_RESET 0x08 |
| 867 | #define DAC960_PG_IDB_MMBOX_NEW_CMD 0x10 |
| 868 | |
| 869 | #define DAC960_PG_IDB_HWMBOX_FULL 0x01 |
| 870 | #define DAC960_PG_IDB_INIT_IN_PROGRESS 0x02 |
| 871 | |
| 872 | /* |
| 873 | * DAC960 PG Series Outbound Door Bell Register. |
| 874 | */ |
| 875 | #define DAC960_PG_ODB_HWMBOX_ACK_IRQ 0x01 |
| 876 | #define DAC960_PG_ODB_MMBOX_ACK_IRQ 0x02 |
| 877 | #define DAC960_PG_ODB_HWMBOX_STS_AVAIL 0x01 |
| 878 | #define DAC960_PG_ODB_MMBOX_STS_AVAIL 0x02 |
| 879 | |
| 880 | /* |
| 881 | * DAC960 PG Series Interrupt Mask Register. |
| 882 | */ |
| 883 | #define DAC960_PG_IRQMASK_MSI_MASK1 0x03 |
| 884 | #define DAC960_PG_IRQMASK_DISABLE_IRQ 0x04 |
| 885 | #define DAC960_PG_IRQMASK_MSI_MASK2 0xF8 |
| 886 | |
| 887 | /* |
| 888 | * DAC960 PG Series Error Status Register. |
| 889 | */ |
| 890 | #define DAC960_PG_ERRSTS_PENDING 0x04 |
| 891 | |
| 892 | /* |
| 893 | * DAC960 PD Series Controller Interface Register Offsets. |
| 894 | */ |
| 895 | #define DAC960_PD_mmio_size 0x80 |
| 896 | |
| 897 | enum DAC960_PD_reg_offset { |
| 898 | DAC960_PD_CMDOP_OFFSET = 0x00, |
| 899 | DAC960_PD_CMDID_OFFSET = 0x01, |
| 900 | DAC960_PD_MBOX2_OFFSET = 0x02, |
| 901 | DAC960_PD_MBOX3_OFFSET = 0x03, |
| 902 | DAC960_PD_MBOX4_OFFSET = 0x04, |
| 903 | DAC960_PD_MBOX5_OFFSET = 0x05, |
| 904 | DAC960_PD_MBOX6_OFFSET = 0x06, |
| 905 | DAC960_PD_MBOX7_OFFSET = 0x07, |
| 906 | DAC960_PD_MBOX8_OFFSET = 0x08, |
| 907 | DAC960_PD_MBOX9_OFFSET = 0x09, |
| 908 | DAC960_PD_MBOX10_OFFSET = 0x0A, |
| 909 | DAC960_PD_MBOX11_OFFSET = 0x0B, |
| 910 | DAC960_PD_MBOX12_OFFSET = 0x0C, |
| 911 | DAC960_PD_STSID_OFFSET = 0x0D, |
| 912 | DAC960_PD_STS_OFFSET = 0x0E, |
| 913 | DAC960_PD_ERRSTS_OFFSET = 0x3F, |
| 914 | DAC960_PD_IDB_OFFSET = 0x40, |
| 915 | DAC960_PD_ODB_OFFSET = 0x41, |
| 916 | DAC960_PD_IRQEN_OFFSET = 0x43, |
| 917 | }; |
| 918 | |
| 919 | /* |
| 920 | * DAC960 PD Series Inbound Door Bell Register. |
| 921 | */ |
| 922 | #define DAC960_PD_IDB_HWMBOX_NEW_CMD 0x01 |
| 923 | #define DAC960_PD_IDB_HWMBOX_ACK_STS 0x02 |
| 924 | #define DAC960_PD_IDB_GEN_IRQ 0x04 |
| 925 | #define DAC960_PD_IDB_CTRL_RESET 0x08 |
| 926 | |
| 927 | #define DAC960_PD_IDB_HWMBOX_FULL 0x01 |
| 928 | #define DAC960_PD_IDB_INIT_IN_PROGRESS 0x02 |
| 929 | |
| 930 | /* |
| 931 | * DAC960 PD Series Outbound Door Bell Register. |
| 932 | */ |
| 933 | #define DAC960_PD_ODB_HWMBOX_ACK_IRQ 0x01 |
| 934 | #define DAC960_PD_ODB_HWMBOX_STS_AVAIL 0x01 |
| 935 | |
| 936 | /* |
| 937 | * DAC960 PD Series Interrupt Enable Register. |
| 938 | */ |
| 939 | #define DAC960_PD_IRQMASK_ENABLE_IRQ 0x01 |
| 940 | |
| 941 | /* |
| 942 | * DAC960 PD Series Error Status Register. |
| 943 | */ |
| 944 | #define DAC960_PD_ERRSTS_PENDING 0x04 |
| 945 | |
| 946 | typedef int (*myrb_hw_init_t)(struct pci_dev *pdev, |
| 947 | struct myrb_hba *cb, void __iomem *base); |
| 948 | typedef unsigned short (*mbox_mmio_init_t)(struct pci_dev *pdev, |
| 949 | void __iomem *base, |
| 950 | union myrb_cmd_mbox *mbox); |
| 951 | |
| 952 | struct myrb_privdata { |
| 953 | myrb_hw_init_t hw_init; |
| 954 | irq_handler_t irq_handler; |
| 955 | unsigned int mmio_size; |
| 956 | }; |
| 957 | |
| 958 | #endif /* MYRB_H */ |