linux/drivers/scsi/qla2xxx/qla_tmpl.h
<<
>>
Prefs
   1/*
   2 * QLogic Fibre Channel HBA Driver
   3 * Copyright (c)  2003-2014 QLogic Corporation
   4 *
   5 * See LICENSE.qla2xxx for copyright and licensing details.
   6 */
   7
   8#ifndef __QLA_DMP27_H__
   9#define __QLA_DMP27_H__
  10
  11#define IOBASE_ADDR     offsetof(struct device_reg_24xx, iobase_addr)
  12
  13struct __packed qla27xx_fwdt_template {
  14        __le32 template_type;
  15        __le32 entry_offset;
  16        __le32 template_size;
  17        uint32_t count;         /* borrow field for running/residual count */
  18
  19        __le32 entry_count;
  20        uint32_t template_version;
  21        __le32 capture_timestamp;
  22        uint32_t template_checksum;
  23
  24        uint32_t reserved_2;
  25        __le32 driver_info[3];
  26
  27        uint32_t saved_state[16];
  28
  29        uint32_t reserved_3[8];
  30        __le32 firmware_version[5];
  31};
  32
  33#define TEMPLATE_TYPE_FWDUMP            99
  34
  35#define ENTRY_TYPE_NOP                  0
  36#define ENTRY_TYPE_TMP_END              255
  37#define ENTRY_TYPE_RD_IOB_T1            256
  38#define ENTRY_TYPE_WR_IOB_T1            257
  39#define ENTRY_TYPE_RD_IOB_T2            258
  40#define ENTRY_TYPE_WR_IOB_T2            259
  41#define ENTRY_TYPE_RD_PCI               260
  42#define ENTRY_TYPE_WR_PCI               261
  43#define ENTRY_TYPE_RD_RAM               262
  44#define ENTRY_TYPE_GET_QUEUE            263
  45#define ENTRY_TYPE_GET_FCE              264
  46#define ENTRY_TYPE_PSE_RISC             265
  47#define ENTRY_TYPE_RST_RISC             266
  48#define ENTRY_TYPE_DIS_INTR             267
  49#define ENTRY_TYPE_GET_HBUF             268
  50#define ENTRY_TYPE_SCRATCH              269
  51#define ENTRY_TYPE_RDREMREG             270
  52#define ENTRY_TYPE_WRREMREG             271
  53#define ENTRY_TYPE_RDREMRAM             272
  54#define ENTRY_TYPE_PCICFG               273
  55#define ENTRY_TYPE_GET_SHADOW           274
  56#define ENTRY_TYPE_WRITE_BUF            275
  57#define ENTRY_TYPE_CONDITIONAL          276
  58#define ENTRY_TYPE_RDPEPREG             277
  59#define ENTRY_TYPE_WRPEPREG             278
  60
  61#define CAPTURE_FLAG_PHYS_ONLY          BIT_0
  62#define CAPTURE_FLAG_PHYS_VIRT          BIT_1
  63
  64#define DRIVER_FLAG_SKIP_ENTRY          BIT_7
  65
  66struct __packed qla27xx_fwdt_entry {
  67        struct __packed {
  68                __le32 type;
  69                __le32 size;
  70                uint32_t reserved_1;
  71
  72                uint8_t  capture_flags;
  73                uint8_t  reserved_2[2];
  74                uint8_t  driver_flags;
  75        } hdr;
  76        union __packed {
  77                struct __packed {
  78                } t0;
  79
  80                struct __packed {
  81                } t255;
  82
  83                struct __packed {
  84                        __le32 base_addr;
  85                        uint8_t  reg_width;
  86                        __le16 reg_count;
  87                        uint8_t  pci_offset;
  88                } t256;
  89
  90                struct __packed {
  91                        __le32 base_addr;
  92                        __le32 write_data;
  93                        uint8_t  pci_offset;
  94                        uint8_t  reserved[3];
  95                } t257;
  96
  97                struct __packed {
  98                        __le32 base_addr;
  99                        uint8_t  reg_width;
 100                        __le16 reg_count;
 101                        uint8_t  pci_offset;
 102                        uint8_t  banksel_offset;
 103                        uint8_t  reserved[3];
 104                        __le32 bank;
 105                } t258;
 106
 107                struct __packed {
 108                        __le32 base_addr;
 109                        __le32 write_data;
 110                        uint8_t  reserved[2];
 111                        uint8_t  pci_offset;
 112                        uint8_t  banksel_offset;
 113                        __le32 bank;
 114                } t259;
 115
 116                struct __packed {
 117                        uint8_t pci_offset;
 118                        uint8_t reserved[3];
 119                } t260;
 120
 121                struct __packed {
 122                        uint8_t pci_offset;
 123                        uint8_t reserved[3];
 124                        __le32 write_data;
 125                } t261;
 126
 127                struct __packed {
 128                        uint8_t  ram_area;
 129                        uint8_t  reserved[3];
 130                        __le32 start_addr;
 131                        __le32 end_addr;
 132                } t262;
 133
 134                struct __packed {
 135                        uint32_t num_queues;
 136                        uint8_t  queue_type;
 137                        uint8_t  reserved[3];
 138                } t263;
 139
 140                struct __packed {
 141                        uint32_t fce_trace_size;
 142                        uint64_t write_pointer;
 143                        uint64_t base_pointer;
 144                        uint32_t fce_enable_mb0;
 145                        uint32_t fce_enable_mb2;
 146                        uint32_t fce_enable_mb3;
 147                        uint32_t fce_enable_mb4;
 148                        uint32_t fce_enable_mb5;
 149                        uint32_t fce_enable_mb6;
 150                } t264;
 151
 152                struct __packed {
 153                } t265;
 154
 155                struct __packed {
 156                } t266;
 157
 158                struct __packed {
 159                        uint8_t  pci_offset;
 160                        uint8_t  reserved[3];
 161                        __le32 data;
 162                } t267;
 163
 164                struct __packed {
 165                        uint8_t  buf_type;
 166                        uint8_t  reserved[3];
 167                        uint32_t buf_size;
 168                        uint64_t start_addr;
 169                } t268;
 170
 171                struct __packed {
 172                        uint32_t scratch_size;
 173                } t269;
 174
 175                struct __packed {
 176                        __le32 addr;
 177                        __le32 count;
 178                } t270;
 179
 180                struct __packed {
 181                        __le32 addr;
 182                        __le32 data;
 183                } t271;
 184
 185                struct __packed {
 186                        __le32 addr;
 187                        __le32 count;
 188                } t272;
 189
 190                struct __packed {
 191                        __le32 addr;
 192                        __le32 count;
 193                } t273;
 194
 195                struct __packed {
 196                        uint32_t num_queues;
 197                        uint8_t  queue_type;
 198                        uint8_t  reserved[3];
 199                } t274;
 200
 201                struct __packed {
 202                        __le32 length;
 203                        uint8_t  buffer[];
 204                } t275;
 205
 206                struct __packed {
 207                        __le32 cond1;
 208                        __le32 cond2;
 209                } t276;
 210
 211                struct __packed {
 212                        __le32 cmd_addr;
 213                        __le32 wr_cmd_data;
 214                        __le32 data_addr;
 215                } t277;
 216
 217                struct __packed {
 218                        __le32 cmd_addr;
 219                        __le32 wr_cmd_data;
 220                        __le32 data_addr;
 221                        __le32 wr_data;
 222                } t278;
 223        };
 224};
 225
 226#define T262_RAM_AREA_CRITICAL_RAM      1
 227#define T262_RAM_AREA_EXTERNAL_RAM      2
 228#define T262_RAM_AREA_SHARED_RAM        3
 229#define T262_RAM_AREA_DDR_RAM           4
 230#define T262_RAM_AREA_MISC              5
 231
 232#define T263_QUEUE_TYPE_REQ             1
 233#define T263_QUEUE_TYPE_RSP             2
 234#define T263_QUEUE_TYPE_ATIO            3
 235
 236#define T268_BUF_TYPE_EXTD_TRACE        1
 237#define T268_BUF_TYPE_EXCH_BUFOFF       2
 238#define T268_BUF_TYPE_EXTD_LOGIN        3
 239#define T268_BUF_TYPE_REQ_MIRROR        4
 240#define T268_BUF_TYPE_RSP_MIRROR        5
 241
 242#define T274_QUEUE_TYPE_REQ_SHAD        1
 243#define T274_QUEUE_TYPE_RSP_SHAD        2
 244#define T274_QUEUE_TYPE_ATIO_SHAD       3
 245
 246#endif
 247