1 #define DRV_NAME "advansys"
 
   2 #define ASC_VERSION "3.4"       /* AdvanSys Driver Version */
 
   5  * advansys.c - Linux Host Driver for AdvanSys SCSI Adapters
 
   7  * Copyright (c) 1995-2000 Advanced System Products, Inc.
 
   8  * Copyright (c) 2000-2001 ConnectCom Solutions, Inc.
 
   9  * Copyright (c) 2007 Matthew Wilcox <matthew@wil.cx>
 
  10  * All Rights Reserved.
 
  12  * This program is free software; you can redistribute it and/or modify
 
  13  * it under the terms of the GNU General Public License as published by
 
  14  * the Free Software Foundation; either version 2 of the License, or
 
  15  * (at your option) any later version.
 
  19  * As of March 8, 2000 Advanced System Products, Inc. (AdvanSys)
 
  20  * changed its name to ConnectCom Solutions, Inc.
 
  21  * On June 18, 2001 Initio Corp. acquired ConnectCom's SCSI assets
 
  24 #include <linux/module.h>
 
  25 #include <linux/string.h>
 
  26 #include <linux/kernel.h>
 
  27 #include <linux/types.h>
 
  28 #include <linux/ioport.h>
 
  29 #include <linux/interrupt.h>
 
  30 #include <linux/delay.h>
 
  31 #include <linux/slab.h>
 
  33 #include <linux/proc_fs.h>
 
  34 #include <linux/init.h>
 
  35 #include <linux/blkdev.h>
 
  36 #include <linux/isa.h>
 
  37 #include <linux/eisa.h>
 
  38 #include <linux/pci.h>
 
  39 #include <linux/spinlock.h>
 
  40 #include <linux/dma-mapping.h>
 
  43 #include <asm/system.h>
 
  46 #include <scsi/scsi_cmnd.h>
 
  47 #include <scsi/scsi_device.h>
 
  48 #include <scsi/scsi_tcq.h>
 
  49 #include <scsi/scsi.h>
 
  50 #include <scsi/scsi_host.h>
 
  54  *  1. Although all of the necessary command mapping places have the
 
  55  *     appropriate dma_map.. APIs, the driver still processes its internal
 
  56  *     queue using bus_to_virt() and virt_to_bus() which are illegal under
 
  57  *     the API.  The entire queue processing structure will need to be
 
  58  *     altered to fix this.
 
  59  *  2. Need to add memory mapping workaround. Test the memory mapping.
 
  60  *     If it doesn't work revert to I/O port access. Can a test be done
 
  62  *  3. Handle an interrupt not working. Keep an interrupt counter in
 
  63  *     the interrupt handler. In the timeout function if the interrupt
 
  64  *     has not occurred then print a message and run in polled mode.
 
  65  *  4. Need to add support for target mode commands, cf. CAM XPT.
 
  66  *  5. check DMA mapping functions for failure
 
  67  *  6. Use scsi_transport_spi
 
  68  *  7. advansys_info is not safe against multiple simultaneous callers
 
  69  *  8. Add module_param to override ISA/VLB ioport array
 
  71 #warning this driver is still not properly converted to the DMA API
 
  73 /* Enable driver /proc statistics. */
 
  74 #define ADVANSYS_STATS
 
  76 /* Enable driver tracing. */
 
  82  * Any instance where a 32-bit long or pointer type is assumed
 
  83  * for precision or HW defined structures, the following define
 
  84  * types must be used. In Linux the char, short, and int types
 
  85  * are all consistent at 8, 16, and 32 bits respectively. Pointers
 
  86  * and long types are 64 bits on Alpha and UltraSPARC.
 
  88 #define ASC_PADDR __u32         /* Physical/Bus address data type. */
 
  89 #define ASC_VADDR __u32         /* Virtual address data type. */
 
  90 #define ASC_DCNT  __u32         /* Unsigned Data count type. */
 
  91 #define ASC_SDCNT __s32         /* Signed Data count type. */
 
  93 typedef unsigned char uchar;
 
 103 #define UW_ERR   (uint)(0xFFFF)
 
 104 #define isodd_word(val)   ((((uint)val) & (uint)0x0001) != 0)
 
 106 #define PCI_VENDOR_ID_ASP               0x10cd
 
 107 #define PCI_DEVICE_ID_ASP_1200A         0x1100
 
 108 #define PCI_DEVICE_ID_ASP_ABP940        0x1200
 
 109 #define PCI_DEVICE_ID_ASP_ABP940U       0x1300
 
 110 #define PCI_DEVICE_ID_ASP_ABP940UW      0x2300
 
 111 #define PCI_DEVICE_ID_38C0800_REV1      0x2500
 
 112 #define PCI_DEVICE_ID_38C1600_REV1      0x2700
 
 115  * Enable CC_VERY_LONG_SG_LIST to support up to 64K element SG lists.
 
 116  * The SRB structure will have to be changed and the ASC_SRB2SCSIQ()
 
 117  * macro re-defined to be able to obtain a ASC_SCSI_Q pointer from the
 
 120 #define CC_VERY_LONG_SG_LIST 0
 
 121 #define ASC_SRB2SCSIQ(srb_ptr)  (srb_ptr)
 
 123 #define PortAddr                 unsigned int   /* port address size  */
 
 124 #define inp(port)                inb(port)
 
 125 #define outp(port, byte)         outb((byte), (port))
 
 127 #define inpw(port)               inw(port)
 
 128 #define outpw(port, word)        outw((word), (port))
 
 130 #define ASC_MAX_SG_QUEUE    7
 
 131 #define ASC_MAX_SG_LIST     255
 
 133 #define ASC_CS_TYPE  unsigned short
 
 135 #define ASC_IS_ISA          (0x0001)
 
 136 #define ASC_IS_ISAPNP       (0x0081)
 
 137 #define ASC_IS_EISA         (0x0002)
 
 138 #define ASC_IS_PCI          (0x0004)
 
 139 #define ASC_IS_PCI_ULTRA    (0x0104)
 
 140 #define ASC_IS_PCMCIA       (0x0008)
 
 141 #define ASC_IS_MCA          (0x0020)
 
 142 #define ASC_IS_VL           (0x0040)
 
 143 #define ASC_IS_WIDESCSI_16  (0x0100)
 
 144 #define ASC_IS_WIDESCSI_32  (0x0200)
 
 145 #define ASC_IS_BIG_ENDIAN   (0x8000)
 
 147 #define ASC_CHIP_MIN_VER_VL      (0x01)
 
 148 #define ASC_CHIP_MAX_VER_VL      (0x07)
 
 149 #define ASC_CHIP_MIN_VER_PCI     (0x09)
 
 150 #define ASC_CHIP_MAX_VER_PCI     (0x0F)
 
 151 #define ASC_CHIP_VER_PCI_BIT     (0x08)
 
 152 #define ASC_CHIP_MIN_VER_ISA     (0x11)
 
 153 #define ASC_CHIP_MIN_VER_ISA_PNP (0x21)
 
 154 #define ASC_CHIP_MAX_VER_ISA     (0x27)
 
 155 #define ASC_CHIP_VER_ISA_BIT     (0x30)
 
 156 #define ASC_CHIP_VER_ISAPNP_BIT  (0x20)
 
 157 #define ASC_CHIP_VER_ASYN_BUG    (0x21)
 
 158 #define ASC_CHIP_VER_PCI             0x08
 
 159 #define ASC_CHIP_VER_PCI_ULTRA_3150  (ASC_CHIP_VER_PCI | 0x02)
 
 160 #define ASC_CHIP_VER_PCI_ULTRA_3050  (ASC_CHIP_VER_PCI | 0x03)
 
 161 #define ASC_CHIP_MIN_VER_EISA (0x41)
 
 162 #define ASC_CHIP_MAX_VER_EISA (0x47)
 
 163 #define ASC_CHIP_VER_EISA_BIT (0x40)
 
 164 #define ASC_CHIP_LATEST_VER_EISA   ((ASC_CHIP_MIN_VER_EISA - 1) + 3)
 
 165 #define ASC_MAX_VL_DMA_COUNT    (0x07FFFFFFL)
 
 166 #define ASC_MAX_PCI_DMA_COUNT   (0xFFFFFFFFL)
 
 167 #define ASC_MAX_ISA_DMA_COUNT   (0x00FFFFFFL)
 
 169 #define ASC_SCSI_ID_BITS  3
 
 170 #define ASC_SCSI_TIX_TYPE     uchar
 
 171 #define ASC_ALL_DEVICE_BIT_SET  0xFF
 
 172 #define ASC_SCSI_BIT_ID_TYPE  uchar
 
 173 #define ASC_MAX_TID       7
 
 174 #define ASC_MAX_LUN       7
 
 175 #define ASC_SCSI_WIDTH_BIT_SET  0xFF
 
 176 #define ASC_MAX_SENSE_LEN   32
 
 177 #define ASC_MIN_SENSE_LEN   14
 
 178 #define ASC_SCSI_RESET_HOLD_TIME_US  60
 
 181  * Narrow boards only support 12-byte commands, while wide boards
 
 182  * extend to 16-byte commands.
 
 184 #define ASC_MAX_CDB_LEN     12
 
 185 #define ADV_MAX_CDB_LEN     16
 
 187 #define MS_SDTR_LEN    0x03
 
 188 #define MS_WDTR_LEN    0x02
 
 190 #define ASC_SG_LIST_PER_Q   7
 
 192 #define QS_READY       0x01
 
 193 #define QS_DISC1       0x02
 
 194 #define QS_DISC2       0x04
 
 196 #define QS_ABORTED     0x40
 
 198 #define QC_NO_CALLBACK   0x01
 
 199 #define QC_SG_SWAP_QUEUE 0x02
 
 200 #define QC_SG_HEAD       0x04
 
 201 #define QC_DATA_IN       0x08
 
 202 #define QC_DATA_OUT      0x10
 
 203 #define QC_URGENT        0x20
 
 204 #define QC_MSG_OUT       0x40
 
 205 #define QC_REQ_SENSE     0x80
 
 206 #define QCSG_SG_XFER_LIST  0x02
 
 207 #define QCSG_SG_XFER_MORE  0x04
 
 208 #define QCSG_SG_XFER_END   0x08
 
 209 #define QD_IN_PROGRESS       0x00
 
 210 #define QD_NO_ERROR          0x01
 
 211 #define QD_ABORTED_BY_HOST   0x02
 
 212 #define QD_WITH_ERROR        0x04
 
 213 #define QD_INVALID_REQUEST   0x80
 
 214 #define QD_INVALID_HOST_NUM  0x81
 
 215 #define QD_INVALID_DEVICE    0x82
 
 216 #define QD_ERR_INTERNAL      0xFF
 
 217 #define QHSTA_NO_ERROR               0x00
 
 218 #define QHSTA_M_SEL_TIMEOUT          0x11
 
 219 #define QHSTA_M_DATA_OVER_RUN        0x12
 
 220 #define QHSTA_M_DATA_UNDER_RUN       0x12
 
 221 #define QHSTA_M_UNEXPECTED_BUS_FREE  0x13
 
 222 #define QHSTA_M_BAD_BUS_PHASE_SEQ    0x14
 
 223 #define QHSTA_D_QDONE_SG_LIST_CORRUPTED 0x21
 
 224 #define QHSTA_D_ASC_DVC_ERROR_CODE_SET  0x22
 
 225 #define QHSTA_D_HOST_ABORT_FAILED       0x23
 
 226 #define QHSTA_D_EXE_SCSI_Q_FAILED       0x24
 
 227 #define QHSTA_D_EXE_SCSI_Q_BUSY_TIMEOUT 0x25
 
 228 #define QHSTA_D_ASPI_NO_BUF_POOL        0x26
 
 229 #define QHSTA_M_WTM_TIMEOUT         0x41
 
 230 #define QHSTA_M_BAD_CMPL_STATUS_IN  0x42
 
 231 #define QHSTA_M_NO_AUTO_REQ_SENSE   0x43
 
 232 #define QHSTA_M_AUTO_REQ_SENSE_FAIL 0x44
 
 233 #define QHSTA_M_TARGET_STATUS_BUSY  0x45
 
 234 #define QHSTA_M_BAD_TAG_CODE        0x46
 
 235 #define QHSTA_M_BAD_QUEUE_FULL_OR_BUSY  0x47
 
 236 #define QHSTA_M_HUNG_REQ_SCSI_BUS_RESET 0x48
 
 237 #define QHSTA_D_LRAM_CMP_ERROR        0x81
 
 238 #define QHSTA_M_MICRO_CODE_ERROR_HALT 0xA1
 
 239 #define ASC_FLAG_SCSIQ_REQ        0x01
 
 240 #define ASC_FLAG_BIOS_SCSIQ_REQ   0x02
 
 241 #define ASC_FLAG_BIOS_ASYNC_IO    0x04
 
 242 #define ASC_FLAG_SRB_LINEAR_ADDR  0x08
 
 243 #define ASC_FLAG_WIN16            0x10
 
 244 #define ASC_FLAG_WIN32            0x20
 
 245 #define ASC_FLAG_ISA_OVER_16MB    0x40
 
 246 #define ASC_FLAG_DOS_VM_CALLBACK  0x80
 
 247 #define ASC_TAG_FLAG_EXTRA_BYTES               0x10
 
 248 #define ASC_TAG_FLAG_DISABLE_DISCONNECT        0x04
 
 249 #define ASC_TAG_FLAG_DISABLE_ASYN_USE_SYN_FIX  0x08
 
 250 #define ASC_TAG_FLAG_DISABLE_CHK_COND_INT_HOST 0x40
 
 251 #define ASC_SCSIQ_CPY_BEG              4
 
 252 #define ASC_SCSIQ_SGHD_CPY_BEG         2
 
 253 #define ASC_SCSIQ_B_FWD                0
 
 254 #define ASC_SCSIQ_B_BWD                1
 
 255 #define ASC_SCSIQ_B_STATUS             2
 
 256 #define ASC_SCSIQ_B_QNO                3
 
 257 #define ASC_SCSIQ_B_CNTL               4
 
 258 #define ASC_SCSIQ_B_SG_QUEUE_CNT       5
 
 259 #define ASC_SCSIQ_D_DATA_ADDR          8
 
 260 #define ASC_SCSIQ_D_DATA_CNT          12
 
 261 #define ASC_SCSIQ_B_SENSE_LEN         20
 
 262 #define ASC_SCSIQ_DONE_INFO_BEG       22
 
 263 #define ASC_SCSIQ_D_SRBPTR            22
 
 264 #define ASC_SCSIQ_B_TARGET_IX         26
 
 265 #define ASC_SCSIQ_B_CDB_LEN           28
 
 266 #define ASC_SCSIQ_B_TAG_CODE          29
 
 267 #define ASC_SCSIQ_W_VM_ID             30
 
 268 #define ASC_SCSIQ_DONE_STATUS         32
 
 269 #define ASC_SCSIQ_HOST_STATUS         33
 
 270 #define ASC_SCSIQ_SCSI_STATUS         34
 
 271 #define ASC_SCSIQ_CDB_BEG             36
 
 272 #define ASC_SCSIQ_DW_REMAIN_XFER_ADDR 56
 
 273 #define ASC_SCSIQ_DW_REMAIN_XFER_CNT  60
 
 274 #define ASC_SCSIQ_B_FIRST_SG_WK_QP    48
 
 275 #define ASC_SCSIQ_B_SG_WK_QP          49
 
 276 #define ASC_SCSIQ_B_SG_WK_IX          50
 
 277 #define ASC_SCSIQ_W_ALT_DC1           52
 
 278 #define ASC_SCSIQ_B_LIST_CNT          6
 
 279 #define ASC_SCSIQ_B_CUR_LIST_CNT      7
 
 280 #define ASC_SGQ_B_SG_CNTL             4
 
 281 #define ASC_SGQ_B_SG_HEAD_QP          5
 
 282 #define ASC_SGQ_B_SG_LIST_CNT         6
 
 283 #define ASC_SGQ_B_SG_CUR_LIST_CNT     7
 
 284 #define ASC_SGQ_LIST_BEG              8
 
 285 #define ASC_DEF_SCSI1_QNG    4
 
 286 #define ASC_MAX_SCSI1_QNG    4
 
 287 #define ASC_DEF_SCSI2_QNG    16
 
 288 #define ASC_MAX_SCSI2_QNG    32
 
 289 #define ASC_TAG_CODE_MASK    0x23
 
 290 #define ASC_STOP_REQ_RISC_STOP      0x01
 
 291 #define ASC_STOP_ACK_RISC_STOP      0x03
 
 292 #define ASC_STOP_CLEAN_UP_BUSY_Q    0x10
 
 293 #define ASC_STOP_CLEAN_UP_DISC_Q    0x20
 
 294 #define ASC_STOP_HOST_REQ_RISC_HALT 0x40
 
 295 #define ASC_TIDLUN_TO_IX(tid, lun)  (ASC_SCSI_TIX_TYPE)((tid) + ((lun)<<ASC_SCSI_ID_BITS))
 
 296 #define ASC_TID_TO_TARGET_ID(tid)   (ASC_SCSI_BIT_ID_TYPE)(0x01 << (tid))
 
 297 #define ASC_TIX_TO_TARGET_ID(tix)   (0x01 << ((tix) & ASC_MAX_TID))
 
 298 #define ASC_TIX_TO_TID(tix)         ((tix) & ASC_MAX_TID)
 
 299 #define ASC_TID_TO_TIX(tid)         ((tid) & ASC_MAX_TID)
 
 300 #define ASC_TIX_TO_LUN(tix)         (((tix) >> ASC_SCSI_ID_BITS) & ASC_MAX_LUN)
 
 301 #define ASC_QNO_TO_QADDR(q_no)      ((ASC_QADR_BEG)+((int)(q_no) << 6))
 
 303 typedef struct asc_scsiq_1 {
 
 312         ASC_PADDR sense_addr;
 
 317 typedef struct asc_scsiq_2 {
 
 326 typedef struct asc_scsiq_3 {
 
 333 typedef struct asc_scsiq_4 {
 
 334         uchar cdb[ASC_MAX_CDB_LEN];
 
 335         uchar y_first_sg_list_qp;
 
 336         uchar y_working_sg_qp;
 
 337         uchar y_working_sg_ix;
 
 340         ushort x_reconnect_rtn;
 
 341         ASC_PADDR x_saved_data_addr;
 
 342         ASC_DCNT x_saved_data_cnt;
 
 345 typedef struct asc_q_done_info {
 
 354         ASC_DCNT remain_bytes;
 
 357 typedef struct asc_sg_list {
 
 362 typedef struct asc_sg_head {
 
 365         ushort entry_to_copy;
 
 367         ASC_SG_LIST sg_list[0];
 
 370 typedef struct asc_scsi_q {
 
 374         ASC_SG_HEAD *sg_head;
 
 375         ushort remain_sg_entry_cnt;
 
 376         ushort next_sg_index;
 
 379 typedef struct asc_scsi_req_q {
 
 383         ASC_SG_HEAD *sg_head;
 
 386         uchar cdb[ASC_MAX_CDB_LEN];
 
 387         uchar sense[ASC_MIN_SENSE_LEN];
 
 390 typedef struct asc_scsi_bios_req_q {
 
 394         ASC_SG_HEAD *sg_head;
 
 397         uchar cdb[ASC_MAX_CDB_LEN];
 
 398         uchar sense[ASC_MIN_SENSE_LEN];
 
 399 } ASC_SCSI_BIOS_REQ_Q;
 
 401 typedef struct asc_risc_q {
 
 410 typedef struct asc_sg_list_q {
 
 416         uchar sg_cur_list_cnt;
 
 419 typedef struct asc_risc_sg_list_q {
 
 423         ASC_SG_LIST sg_list[7];
 
 424 } ASC_RISC_SG_LIST_Q;
 
 426 #define ASCQ_ERR_Q_STATUS             0x0D
 
 427 #define ASCQ_ERR_CUR_QNG              0x17
 
 428 #define ASCQ_ERR_SG_Q_LINKS           0x18
 
 429 #define ASCQ_ERR_ISR_RE_ENTRY         0x1A
 
 430 #define ASCQ_ERR_CRITICAL_RE_ENTRY    0x1B
 
 431 #define ASCQ_ERR_ISR_ON_CRITICAL      0x1C
 
 434  * Warning code values are set in ASC_DVC_VAR  'warn_code'.
 
 436 #define ASC_WARN_NO_ERROR             0x0000
 
 437 #define ASC_WARN_IO_PORT_ROTATE       0x0001
 
 438 #define ASC_WARN_EEPROM_CHKSUM        0x0002
 
 439 #define ASC_WARN_IRQ_MODIFIED         0x0004
 
 440 #define ASC_WARN_AUTO_CONFIG          0x0008
 
 441 #define ASC_WARN_CMD_QNG_CONFLICT     0x0010
 
 442 #define ASC_WARN_EEPROM_RECOVER       0x0020
 
 443 #define ASC_WARN_CFG_MSW_RECOVER      0x0040
 
 446  * Error code values are set in {ASC/ADV}_DVC_VAR  'err_code'.
 
 448 #define ASC_IERR_NO_CARRIER             0x0001  /* No more carrier memory */
 
 449 #define ASC_IERR_MCODE_CHKSUM           0x0002  /* micro code check sum error */
 
 450 #define ASC_IERR_SET_PC_ADDR            0x0004
 
 451 #define ASC_IERR_START_STOP_CHIP        0x0008  /* start/stop chip failed */
 
 452 #define ASC_IERR_ILLEGAL_CONNECTION     0x0010  /* Illegal cable connection */
 
 453 #define ASC_IERR_SINGLE_END_DEVICE      0x0020  /* SE device on DIFF bus */
 
 454 #define ASC_IERR_REVERSED_CABLE         0x0040  /* Narrow flat cable reversed */
 
 455 #define ASC_IERR_SET_SCSI_ID            0x0080  /* set SCSI ID failed */
 
 456 #define ASC_IERR_HVD_DEVICE             0x0100  /* HVD device on LVD port */
 
 457 #define ASC_IERR_BAD_SIGNATURE          0x0200  /* signature not found */
 
 458 #define ASC_IERR_NO_BUS_TYPE            0x0400
 
 459 #define ASC_IERR_BIST_PRE_TEST          0x0800  /* BIST pre-test error */
 
 460 #define ASC_IERR_BIST_RAM_TEST          0x1000  /* BIST RAM test error */
 
 461 #define ASC_IERR_BAD_CHIPTYPE           0x2000  /* Invalid chip_type setting */
 
 463 #define ASC_DEF_MAX_TOTAL_QNG   (0xF0)
 
 464 #define ASC_MIN_TAG_Q_PER_DVC   (0x04)
 
 465 #define ASC_MIN_FREE_Q        (0x02)
 
 466 #define ASC_MIN_TOTAL_QNG     ((ASC_MAX_SG_QUEUE)+(ASC_MIN_FREE_Q))
 
 467 #define ASC_MAX_TOTAL_QNG 240
 
 468 #define ASC_MAX_PCI_ULTRA_INRAM_TOTAL_QNG 16
 
 469 #define ASC_MAX_PCI_ULTRA_INRAM_TAG_QNG   8
 
 470 #define ASC_MAX_PCI_INRAM_TOTAL_QNG  20
 
 471 #define ASC_MAX_INRAM_TAG_QNG   16
 
 472 #define ASC_IOADR_GAP   0x10
 
 473 #define ASC_SYN_MAX_OFFSET         0x0F
 
 474 #define ASC_DEF_SDTR_OFFSET        0x0F
 
 475 #define ASC_SDTR_ULTRA_PCI_10MB_INDEX  0x02
 
 476 #define ASYN_SDTR_DATA_FIX_PCI_REV_AB 0x41
 
 478 /* The narrow chip only supports a limited selection of transfer rates.
 
 479  * These are encoded in the range 0..7 or 0..15 depending whether the chip
 
 480  * is Ultra-capable or not.  These tables let us convert from one to the other.
 
 482 static const unsigned char asc_syn_xfer_period[8] = {
 
 483         25, 30, 35, 40, 50, 60, 70, 85
 
 486 static const unsigned char asc_syn_ultra_xfer_period[16] = {
 
 487         12, 19, 25, 32, 38, 44, 50, 57, 63, 69, 75, 82, 88, 94, 100, 107
 
 490 typedef struct ext_msg {
 
 496                         uchar sdtr_xfer_period;
 
 497                         uchar sdtr_req_ack_offset;
 
 512 #define xfer_period     u_ext_msg.sdtr.sdtr_xfer_period
 
 513 #define req_ack_offset  u_ext_msg.sdtr.sdtr_req_ack_offset
 
 514 #define wdtr_width      u_ext_msg.wdtr.wdtr_width
 
 515 #define mdp_b3          u_ext_msg.mdp_b3
 
 516 #define mdp_b2          u_ext_msg.mdp_b2
 
 517 #define mdp_b1          u_ext_msg.mdp_b1
 
 518 #define mdp_b0          u_ext_msg.mdp_b0
 
 520 typedef struct asc_dvc_cfg {
 
 521         ASC_SCSI_BIT_ID_TYPE can_tagged_qng;
 
 522         ASC_SCSI_BIT_ID_TYPE cmd_qng_enabled;
 
 523         ASC_SCSI_BIT_ID_TYPE disc_enable;
 
 524         ASC_SCSI_BIT_ID_TYPE sdtr_enable;
 
 527         uchar isa_dma_channel;
 
 530         ushort mcode_version;
 
 531         uchar max_tag_qng[ASC_MAX_TID + 1];
 
 532         uchar sdtr_period_offset[ASC_MAX_TID + 1];
 
 533         uchar adapter_info[6];
 
 536 #define ASC_DEF_DVC_CNTL       0xFFFF
 
 537 #define ASC_DEF_CHIP_SCSI_ID   7
 
 538 #define ASC_DEF_ISA_DMA_SPEED  4
 
 539 #define ASC_INIT_STATE_BEG_GET_CFG   0x0001
 
 540 #define ASC_INIT_STATE_END_GET_CFG   0x0002
 
 541 #define ASC_INIT_STATE_BEG_SET_CFG   0x0004
 
 542 #define ASC_INIT_STATE_END_SET_CFG   0x0008
 
 543 #define ASC_INIT_STATE_BEG_LOAD_MC   0x0010
 
 544 #define ASC_INIT_STATE_END_LOAD_MC   0x0020
 
 545 #define ASC_INIT_STATE_BEG_INQUIRY   0x0040
 
 546 #define ASC_INIT_STATE_END_INQUIRY   0x0080
 
 547 #define ASC_INIT_RESET_SCSI_DONE     0x0100
 
 548 #define ASC_INIT_STATE_WITHOUT_EEP   0x8000
 
 549 #define ASC_BUG_FIX_IF_NOT_DWB       0x0001
 
 550 #define ASC_BUG_FIX_ASYN_USE_SYN     0x0002
 
 551 #define ASC_MIN_TAGGED_CMD  7
 
 552 #define ASC_MAX_SCSI_RESET_WAIT      30
 
 553 #define ASC_OVERRUN_BSIZE               64
 
 555 struct asc_dvc_var;             /* Forward Declaration. */
 
 557 typedef struct asc_dvc_var {
 
 563         ASC_SCSI_BIT_ID_TYPE init_sdtr;
 
 564         ASC_SCSI_BIT_ID_TYPE sdtr_done;
 
 565         ASC_SCSI_BIT_ID_TYPE use_tagged_qng;
 
 566         ASC_SCSI_BIT_ID_TYPE unit_not_ready;
 
 567         ASC_SCSI_BIT_ID_TYPE queue_full_or_busy;
 
 568         ASC_SCSI_BIT_ID_TYPE start_motor;
 
 569         uchar overrun_buf[ASC_OVERRUN_BSIZE] __aligned(8);
 
 570         dma_addr_t overrun_dma;
 
 571         uchar scsi_reset_wait;
 
 576         uchar in_critical_cnt;
 
 577         uchar last_q_shortage;
 
 579         uchar cur_dvc_qng[ASC_MAX_TID + 1];
 
 580         uchar max_dvc_qng[ASC_MAX_TID + 1];
 
 581         ASC_SCSI_Q *scsiq_busy_head[ASC_MAX_TID + 1];
 
 582         ASC_SCSI_Q *scsiq_busy_tail[ASC_MAX_TID + 1];
 
 583         const uchar *sdtr_period_tbl;
 
 585         ASC_SCSI_BIT_ID_TYPE pci_fix_asyn_xfer_always;
 
 588         uchar dos_int13_table[ASC_MAX_TID + 1];
 
 589         ASC_DCNT max_dma_count;
 
 590         ASC_SCSI_BIT_ID_TYPE no_scam;
 
 591         ASC_SCSI_BIT_ID_TYPE pci_fix_asyn_xfer;
 
 592         uchar min_sdtr_index;
 
 593         uchar max_sdtr_index;
 
 594         struct asc_board *drv_ptr;
 
 600 typedef struct asc_dvc_inq_info {
 
 601         uchar type[ASC_MAX_TID + 1][ASC_MAX_LUN + 1];
 
 604 typedef struct asc_cap_info {
 
 609 typedef struct asc_cap_info_array {
 
 610         ASC_CAP_INFO cap_info[ASC_MAX_TID + 1][ASC_MAX_LUN + 1];
 
 611 } ASC_CAP_INFO_ARRAY;
 
 613 #define ASC_MCNTL_NO_SEL_TIMEOUT  (ushort)0x0001
 
 614 #define ASC_MCNTL_NULL_TARGET     (ushort)0x0002
 
 615 #define ASC_CNTL_INITIATOR         (ushort)0x0001
 
 616 #define ASC_CNTL_BIOS_GT_1GB       (ushort)0x0002
 
 617 #define ASC_CNTL_BIOS_GT_2_DISK    (ushort)0x0004
 
 618 #define ASC_CNTL_BIOS_REMOVABLE    (ushort)0x0008
 
 619 #define ASC_CNTL_NO_SCAM           (ushort)0x0010
 
 620 #define ASC_CNTL_INT_MULTI_Q       (ushort)0x0080
 
 621 #define ASC_CNTL_NO_LUN_SUPPORT    (ushort)0x0040
 
 622 #define ASC_CNTL_NO_VERIFY_COPY    (ushort)0x0100
 
 623 #define ASC_CNTL_RESET_SCSI        (ushort)0x0200
 
 624 #define ASC_CNTL_INIT_INQUIRY      (ushort)0x0400
 
 625 #define ASC_CNTL_INIT_VERBOSE      (ushort)0x0800
 
 626 #define ASC_CNTL_SCSI_PARITY       (ushort)0x1000
 
 627 #define ASC_CNTL_BURST_MODE        (ushort)0x2000
 
 628 #define ASC_CNTL_SDTR_ENABLE_ULTRA (ushort)0x4000
 
 629 #define ASC_EEP_DVC_CFG_BEG_VL    2
 
 630 #define ASC_EEP_MAX_DVC_ADDR_VL   15
 
 631 #define ASC_EEP_DVC_CFG_BEG      32
 
 632 #define ASC_EEP_MAX_DVC_ADDR     45
 
 633 #define ASC_EEP_MAX_RETRY        20
 
 636  * These macros keep the chip SCSI id and ISA DMA speed
 
 637  * bitfields in board order. C bitfields aren't portable
 
 638  * between big and little-endian platforms so they are
 
 642 #define ASC_EEP_GET_CHIP_ID(cfg)    ((cfg)->id_speed & 0x0f)
 
 643 #define ASC_EEP_GET_DMA_SPD(cfg)    (((cfg)->id_speed & 0xf0) >> 4)
 
 644 #define ASC_EEP_SET_CHIP_ID(cfg, sid) \
 
 645    ((cfg)->id_speed = ((cfg)->id_speed & 0xf0) | ((sid) & ASC_MAX_TID))
 
 646 #define ASC_EEP_SET_DMA_SPD(cfg, spd) \
 
 647    ((cfg)->id_speed = ((cfg)->id_speed & 0x0f) | ((spd) & 0x0f) << 4)
 
 649 typedef struct asceep_config {
 
 661         uchar id_speed;         /* low order 4 bits is chip scsi id */
 
 662         /* high order 4 bits is isa dma speed */
 
 663         uchar dos_int13_table[ASC_MAX_TID + 1];
 
 664         uchar adapter_info[6];
 
 669 #define ASC_EEP_CMD_READ          0x80
 
 670 #define ASC_EEP_CMD_WRITE         0x40
 
 671 #define ASC_EEP_CMD_WRITE_ABLE    0x30
 
 672 #define ASC_EEP_CMD_WRITE_DISABLE 0x00
 
 673 #define ASCV_MSGOUT_BEG         0x0000
 
 674 #define ASCV_MSGOUT_SDTR_PERIOD (ASCV_MSGOUT_BEG+3)
 
 675 #define ASCV_MSGOUT_SDTR_OFFSET (ASCV_MSGOUT_BEG+4)
 
 676 #define ASCV_BREAK_SAVED_CODE   (ushort)0x0006
 
 677 #define ASCV_MSGIN_BEG          (ASCV_MSGOUT_BEG+8)
 
 678 #define ASCV_MSGIN_SDTR_PERIOD  (ASCV_MSGIN_BEG+3)
 
 679 #define ASCV_MSGIN_SDTR_OFFSET  (ASCV_MSGIN_BEG+4)
 
 680 #define ASCV_SDTR_DATA_BEG      (ASCV_MSGIN_BEG+8)
 
 681 #define ASCV_SDTR_DONE_BEG      (ASCV_SDTR_DATA_BEG+8)
 
 682 #define ASCV_MAX_DVC_QNG_BEG    (ushort)0x0020
 
 683 #define ASCV_BREAK_ADDR           (ushort)0x0028
 
 684 #define ASCV_BREAK_NOTIFY_COUNT   (ushort)0x002A
 
 685 #define ASCV_BREAK_CONTROL        (ushort)0x002C
 
 686 #define ASCV_BREAK_HIT_COUNT      (ushort)0x002E
 
 688 #define ASCV_ASCDVC_ERR_CODE_W  (ushort)0x0030
 
 689 #define ASCV_MCODE_CHKSUM_W   (ushort)0x0032
 
 690 #define ASCV_MCODE_SIZE_W     (ushort)0x0034
 
 691 #define ASCV_STOP_CODE_B      (ushort)0x0036
 
 692 #define ASCV_DVC_ERR_CODE_B   (ushort)0x0037
 
 693 #define ASCV_OVERRUN_PADDR_D  (ushort)0x0038
 
 694 #define ASCV_OVERRUN_BSIZE_D  (ushort)0x003C
 
 695 #define ASCV_HALTCODE_W       (ushort)0x0040
 
 696 #define ASCV_CHKSUM_W         (ushort)0x0042
 
 697 #define ASCV_MC_DATE_W        (ushort)0x0044
 
 698 #define ASCV_MC_VER_W         (ushort)0x0046
 
 699 #define ASCV_NEXTRDY_B        (ushort)0x0048
 
 700 #define ASCV_DONENEXT_B       (ushort)0x0049
 
 701 #define ASCV_USE_TAGGED_QNG_B (ushort)0x004A
 
 702 #define ASCV_SCSIBUSY_B       (ushort)0x004B
 
 703 #define ASCV_Q_DONE_IN_PROGRESS_B  (ushort)0x004C
 
 704 #define ASCV_CURCDB_B         (ushort)0x004D
 
 705 #define ASCV_RCLUN_B          (ushort)0x004E
 
 706 #define ASCV_BUSY_QHEAD_B     (ushort)0x004F
 
 707 #define ASCV_DISC1_QHEAD_B    (ushort)0x0050
 
 708 #define ASCV_DISC_ENABLE_B    (ushort)0x0052
 
 709 #define ASCV_CAN_TAGGED_QNG_B (ushort)0x0053
 
 710 #define ASCV_HOSTSCSI_ID_B    (ushort)0x0055
 
 711 #define ASCV_MCODE_CNTL_B     (ushort)0x0056
 
 712 #define ASCV_NULL_TARGET_B    (ushort)0x0057
 
 713 #define ASCV_FREE_Q_HEAD_W    (ushort)0x0058
 
 714 #define ASCV_DONE_Q_TAIL_W    (ushort)0x005A
 
 715 #define ASCV_FREE_Q_HEAD_B    (ushort)(ASCV_FREE_Q_HEAD_W+1)
 
 716 #define ASCV_DONE_Q_TAIL_B    (ushort)(ASCV_DONE_Q_TAIL_W+1)
 
 717 #define ASCV_HOST_FLAG_B      (ushort)0x005D
 
 718 #define ASCV_TOTAL_READY_Q_B  (ushort)0x0064
 
 719 #define ASCV_VER_SERIAL_B     (ushort)0x0065
 
 720 #define ASCV_HALTCODE_SAVED_W (ushort)0x0066
 
 721 #define ASCV_WTM_FLAG_B       (ushort)0x0068
 
 722 #define ASCV_RISC_FLAG_B      (ushort)0x006A
 
 723 #define ASCV_REQ_SG_LIST_QP   (ushort)0x006B
 
 724 #define ASC_HOST_FLAG_IN_ISR        0x01
 
 725 #define ASC_HOST_FLAG_ACK_INT       0x02
 
 726 #define ASC_RISC_FLAG_GEN_INT      0x01
 
 727 #define ASC_RISC_FLAG_REQ_SG_LIST  0x02
 
 728 #define IOP_CTRL         (0x0F)
 
 729 #define IOP_STATUS       (0x0E)
 
 730 #define IOP_INT_ACK      IOP_STATUS
 
 731 #define IOP_REG_IFC      (0x0D)
 
 732 #define IOP_SYN_OFFSET    (0x0B)
 
 733 #define IOP_EXTRA_CONTROL (0x0D)
 
 734 #define IOP_REG_PC        (0x0C)
 
 735 #define IOP_RAM_ADDR      (0x0A)
 
 736 #define IOP_RAM_DATA      (0x08)
 
 737 #define IOP_EEP_DATA      (0x06)
 
 738 #define IOP_EEP_CMD       (0x07)
 
 739 #define IOP_VERSION       (0x03)
 
 740 #define IOP_CONFIG_HIGH   (0x04)
 
 741 #define IOP_CONFIG_LOW    (0x02)
 
 742 #define IOP_SIG_BYTE      (0x01)
 
 743 #define IOP_SIG_WORD      (0x00)
 
 744 #define IOP_REG_DC1      (0x0E)
 
 745 #define IOP_REG_DC0      (0x0C)
 
 746 #define IOP_REG_SB       (0x0B)
 
 747 #define IOP_REG_DA1      (0x0A)
 
 748 #define IOP_REG_DA0      (0x08)
 
 749 #define IOP_REG_SC       (0x09)
 
 750 #define IOP_DMA_SPEED    (0x07)
 
 751 #define IOP_REG_FLAG     (0x07)
 
 752 #define IOP_FIFO_H       (0x06)
 
 753 #define IOP_FIFO_L       (0x04)
 
 754 #define IOP_REG_ID       (0x05)
 
 755 #define IOP_REG_QP       (0x03)
 
 756 #define IOP_REG_IH       (0x02)
 
 757 #define IOP_REG_IX       (0x01)
 
 758 #define IOP_REG_AX       (0x00)
 
 759 #define IFC_REG_LOCK      (0x00)
 
 760 #define IFC_REG_UNLOCK    (0x09)
 
 761 #define IFC_WR_EN_FILTER  (0x10)
 
 762 #define IFC_RD_NO_EEPROM  (0x10)
 
 763 #define IFC_SLEW_RATE     (0x20)
 
 764 #define IFC_ACT_NEG       (0x40)
 
 765 #define IFC_INP_FILTER    (0x80)
 
 766 #define IFC_INIT_DEFAULT  (IFC_ACT_NEG | IFC_REG_UNLOCK)
 
 767 #define SC_SEL   (uchar)(0x80)
 
 768 #define SC_BSY   (uchar)(0x40)
 
 769 #define SC_ACK   (uchar)(0x20)
 
 770 #define SC_REQ   (uchar)(0x10)
 
 771 #define SC_ATN   (uchar)(0x08)
 
 772 #define SC_IO    (uchar)(0x04)
 
 773 #define SC_CD    (uchar)(0x02)
 
 774 #define SC_MSG   (uchar)(0x01)
 
 775 #define SEC_SCSI_CTL         (uchar)(0x80)
 
 776 #define SEC_ACTIVE_NEGATE    (uchar)(0x40)
 
 777 #define SEC_SLEW_RATE        (uchar)(0x20)
 
 778 #define SEC_ENABLE_FILTER    (uchar)(0x10)
 
 779 #define ASC_HALT_EXTMSG_IN     (ushort)0x8000
 
 780 #define ASC_HALT_CHK_CONDITION (ushort)0x8100
 
 781 #define ASC_HALT_SS_QUEUE_FULL (ushort)0x8200
 
 782 #define ASC_HALT_DISABLE_ASYN_USE_SYN_FIX  (ushort)0x8300
 
 783 #define ASC_HALT_ENABLE_ASYN_USE_SYN_FIX   (ushort)0x8400
 
 784 #define ASC_HALT_SDTR_REJECTED (ushort)0x4000
 
 785 #define ASC_HALT_HOST_COPY_SG_LIST_TO_RISC ( ushort )0x2000
 
 786 #define ASC_MAX_QNO        0xF8
 
 787 #define ASC_DATA_SEC_BEG   (ushort)0x0080
 
 788 #define ASC_DATA_SEC_END   (ushort)0x0080
 
 789 #define ASC_CODE_SEC_BEG   (ushort)0x0080
 
 790 #define ASC_CODE_SEC_END   (ushort)0x0080
 
 791 #define ASC_QADR_BEG       (0x4000)
 
 792 #define ASC_QADR_USED      (ushort)(ASC_MAX_QNO * 64)
 
 793 #define ASC_QADR_END       (ushort)0x7FFF
 
 794 #define ASC_QLAST_ADR      (ushort)0x7FC0
 
 795 #define ASC_QBLK_SIZE      0x40
 
 796 #define ASC_BIOS_DATA_QBEG 0xF8
 
 797 #define ASC_MIN_ACTIVE_QNO 0x01
 
 798 #define ASC_QLINK_END      0xFF
 
 799 #define ASC_EEPROM_WORDS   0x10
 
 800 #define ASC_MAX_MGS_LEN    0x10
 
 801 #define ASC_BIOS_ADDR_DEF  0xDC00
 
 802 #define ASC_BIOS_SIZE      0x3800
 
 803 #define ASC_BIOS_RAM_OFF   0x3800
 
 804 #define ASC_BIOS_RAM_SIZE  0x800
 
 805 #define ASC_BIOS_MIN_ADDR  0xC000
 
 806 #define ASC_BIOS_MAX_ADDR  0xEC00
 
 807 #define ASC_BIOS_BANK_SIZE 0x0400
 
 808 #define ASC_MCODE_START_ADDR  0x0080
 
 809 #define ASC_CFG0_HOST_INT_ON    0x0020
 
 810 #define ASC_CFG0_BIOS_ON        0x0040
 
 811 #define ASC_CFG0_VERA_BURST_ON  0x0080
 
 812 #define ASC_CFG0_SCSI_PARITY_ON 0x0800
 
 813 #define ASC_CFG1_SCSI_TARGET_ON 0x0080
 
 814 #define ASC_CFG1_LRAM_8BITS_ON  0x0800
 
 815 #define ASC_CFG_MSW_CLR_MASK    0x3080
 
 816 #define CSW_TEST1             (ASC_CS_TYPE)0x8000
 
 817 #define CSW_AUTO_CONFIG       (ASC_CS_TYPE)0x4000
 
 818 #define CSW_RESERVED1         (ASC_CS_TYPE)0x2000
 
 819 #define CSW_IRQ_WRITTEN       (ASC_CS_TYPE)0x1000
 
 820 #define CSW_33MHZ_SELECTED    (ASC_CS_TYPE)0x0800
 
 821 #define CSW_TEST2             (ASC_CS_TYPE)0x0400
 
 822 #define CSW_TEST3             (ASC_CS_TYPE)0x0200
 
 823 #define CSW_RESERVED2         (ASC_CS_TYPE)0x0100
 
 824 #define CSW_DMA_DONE          (ASC_CS_TYPE)0x0080
 
 825 #define CSW_FIFO_RDY          (ASC_CS_TYPE)0x0040
 
 826 #define CSW_EEP_READ_DONE     (ASC_CS_TYPE)0x0020
 
 827 #define CSW_HALTED            (ASC_CS_TYPE)0x0010
 
 828 #define CSW_SCSI_RESET_ACTIVE (ASC_CS_TYPE)0x0008
 
 829 #define CSW_PARITY_ERR        (ASC_CS_TYPE)0x0004
 
 830 #define CSW_SCSI_RESET_LATCH  (ASC_CS_TYPE)0x0002
 
 831 #define CSW_INT_PENDING       (ASC_CS_TYPE)0x0001
 
 832 #define CIW_CLR_SCSI_RESET_INT (ASC_CS_TYPE)0x1000
 
 833 #define CIW_INT_ACK      (ASC_CS_TYPE)0x0100
 
 834 #define CIW_TEST1        (ASC_CS_TYPE)0x0200
 
 835 #define CIW_TEST2        (ASC_CS_TYPE)0x0400
 
 836 #define CIW_SEL_33MHZ    (ASC_CS_TYPE)0x0800
 
 837 #define CIW_IRQ_ACT      (ASC_CS_TYPE)0x1000
 
 838 #define CC_CHIP_RESET   (uchar)0x80
 
 839 #define CC_SCSI_RESET   (uchar)0x40
 
 840 #define CC_HALT         (uchar)0x20
 
 841 #define CC_SINGLE_STEP  (uchar)0x10
 
 842 #define CC_DMA_ABLE     (uchar)0x08
 
 843 #define CC_TEST         (uchar)0x04
 
 844 #define CC_BANK_ONE     (uchar)0x02
 
 845 #define CC_DIAG         (uchar)0x01
 
 846 #define ASC_1000_ID0W      0x04C1
 
 847 #define ASC_1000_ID0W_FIX  0x00C1
 
 848 #define ASC_1000_ID1B      0x25
 
 849 #define ASC_EISA_REV_IOP_MASK  (0x0C83)
 
 850 #define ASC_EISA_CFG_IOP_MASK  (0x0C86)
 
 851 #define ASC_GET_EISA_SLOT(iop)  (PortAddr)((iop) & 0xF000)
 
 852 #define INS_HALTINT        (ushort)0x6281
 
 853 #define INS_HALT           (ushort)0x6280
 
 854 #define INS_SINT           (ushort)0x6200
 
 855 #define INS_RFLAG_WTM      (ushort)0x7380
 
 856 #define ASC_MC_SAVE_CODE_WSIZE  0x500
 
 857 #define ASC_MC_SAVE_DATA_WSIZE  0x40
 
 859 typedef struct asc_mc_saved {
 
 860         ushort data[ASC_MC_SAVE_DATA_WSIZE];
 
 861         ushort code[ASC_MC_SAVE_CODE_WSIZE];
 
 864 #define AscGetQDoneInProgress(port)         AscReadLramByte((port), ASCV_Q_DONE_IN_PROGRESS_B)
 
 865 #define AscPutQDoneInProgress(port, val)    AscWriteLramByte((port), ASCV_Q_DONE_IN_PROGRESS_B, val)
 
 866 #define AscGetVarFreeQHead(port)            AscReadLramWord((port), ASCV_FREE_Q_HEAD_W)
 
 867 #define AscGetVarDoneQTail(port)            AscReadLramWord((port), ASCV_DONE_Q_TAIL_W)
 
 868 #define AscPutVarFreeQHead(port, val)       AscWriteLramWord((port), ASCV_FREE_Q_HEAD_W, val)
 
 869 #define AscPutVarDoneQTail(port, val)       AscWriteLramWord((port), ASCV_DONE_Q_TAIL_W, val)
 
 870 #define AscGetRiscVarFreeQHead(port)        AscReadLramByte((port), ASCV_NEXTRDY_B)
 
 871 #define AscGetRiscVarDoneQTail(port)        AscReadLramByte((port), ASCV_DONENEXT_B)
 
 872 #define AscPutRiscVarFreeQHead(port, val)   AscWriteLramByte((port), ASCV_NEXTRDY_B, val)
 
 873 #define AscPutRiscVarDoneQTail(port, val)   AscWriteLramByte((port), ASCV_DONENEXT_B, val)
 
 874 #define AscPutMCodeSDTRDoneAtID(port, id, data)  AscWriteLramByte((port), (ushort)((ushort)ASCV_SDTR_DONE_BEG+(ushort)id), (data))
 
 875 #define AscGetMCodeSDTRDoneAtID(port, id)        AscReadLramByte((port), (ushort)((ushort)ASCV_SDTR_DONE_BEG+(ushort)id))
 
 876 #define AscPutMCodeInitSDTRAtID(port, id, data)  AscWriteLramByte((port), (ushort)((ushort)ASCV_SDTR_DATA_BEG+(ushort)id), data)
 
 877 #define AscGetMCodeInitSDTRAtID(port, id)        AscReadLramByte((port), (ushort)((ushort)ASCV_SDTR_DATA_BEG+(ushort)id))
 
 878 #define AscGetChipSignatureByte(port)     (uchar)inp((port)+IOP_SIG_BYTE)
 
 879 #define AscGetChipSignatureWord(port)     (ushort)inpw((port)+IOP_SIG_WORD)
 
 880 #define AscGetChipVerNo(port)             (uchar)inp((port)+IOP_VERSION)
 
 881 #define AscGetChipCfgLsw(port)            (ushort)inpw((port)+IOP_CONFIG_LOW)
 
 882 #define AscGetChipCfgMsw(port)            (ushort)inpw((port)+IOP_CONFIG_HIGH)
 
 883 #define AscSetChipCfgLsw(port, data)      outpw((port)+IOP_CONFIG_LOW, data)
 
 884 #define AscSetChipCfgMsw(port, data)      outpw((port)+IOP_CONFIG_HIGH, data)
 
 885 #define AscGetChipEEPCmd(port)            (uchar)inp((port)+IOP_EEP_CMD)
 
 886 #define AscSetChipEEPCmd(port, data)      outp((port)+IOP_EEP_CMD, data)
 
 887 #define AscGetChipEEPData(port)           (ushort)inpw((port)+IOP_EEP_DATA)
 
 888 #define AscSetChipEEPData(port, data)     outpw((port)+IOP_EEP_DATA, data)
 
 889 #define AscGetChipLramAddr(port)          (ushort)inpw((PortAddr)((port)+IOP_RAM_ADDR))
 
 890 #define AscSetChipLramAddr(port, addr)    outpw((PortAddr)((port)+IOP_RAM_ADDR), addr)
 
 891 #define AscGetChipLramData(port)          (ushort)inpw((port)+IOP_RAM_DATA)
 
 892 #define AscSetChipLramData(port, data)    outpw((port)+IOP_RAM_DATA, data)
 
 893 #define AscGetChipIFC(port)               (uchar)inp((port)+IOP_REG_IFC)
 
 894 #define AscSetChipIFC(port, data)          outp((port)+IOP_REG_IFC, data)
 
 895 #define AscGetChipStatus(port)            (ASC_CS_TYPE)inpw((port)+IOP_STATUS)
 
 896 #define AscSetChipStatus(port, cs_val)    outpw((port)+IOP_STATUS, cs_val)
 
 897 #define AscGetChipControl(port)           (uchar)inp((port)+IOP_CTRL)
 
 898 #define AscSetChipControl(port, cc_val)   outp((port)+IOP_CTRL, cc_val)
 
 899 #define AscGetChipSyn(port)               (uchar)inp((port)+IOP_SYN_OFFSET)
 
 900 #define AscSetChipSyn(port, data)         outp((port)+IOP_SYN_OFFSET, data)
 
 901 #define AscSetPCAddr(port, data)          outpw((port)+IOP_REG_PC, data)
 
 902 #define AscGetPCAddr(port)                (ushort)inpw((port)+IOP_REG_PC)
 
 903 #define AscIsIntPending(port)             (AscGetChipStatus(port) & (CSW_INT_PENDING | CSW_SCSI_RESET_LATCH))
 
 904 #define AscGetChipScsiID(port)            ((AscGetChipCfgLsw(port) >> 8) & ASC_MAX_TID)
 
 905 #define AscGetExtraControl(port)          (uchar)inp((port)+IOP_EXTRA_CONTROL)
 
 906 #define AscSetExtraControl(port, data)    outp((port)+IOP_EXTRA_CONTROL, data)
 
 907 #define AscReadChipAX(port)               (ushort)inpw((port)+IOP_REG_AX)
 
 908 #define AscWriteChipAX(port, data)        outpw((port)+IOP_REG_AX, data)
 
 909 #define AscReadChipIX(port)               (uchar)inp((port)+IOP_REG_IX)
 
 910 #define AscWriteChipIX(port, data)        outp((port)+IOP_REG_IX, data)
 
 911 #define AscReadChipIH(port)               (ushort)inpw((port)+IOP_REG_IH)
 
 912 #define AscWriteChipIH(port, data)        outpw((port)+IOP_REG_IH, data)
 
 913 #define AscReadChipQP(port)               (uchar)inp((port)+IOP_REG_QP)
 
 914 #define AscWriteChipQP(port, data)        outp((port)+IOP_REG_QP, data)
 
 915 #define AscReadChipFIFO_L(port)           (ushort)inpw((port)+IOP_REG_FIFO_L)
 
 916 #define AscWriteChipFIFO_L(port, data)    outpw((port)+IOP_REG_FIFO_L, data)
 
 917 #define AscReadChipFIFO_H(port)           (ushort)inpw((port)+IOP_REG_FIFO_H)
 
 918 #define AscWriteChipFIFO_H(port, data)    outpw((port)+IOP_REG_FIFO_H, data)
 
 919 #define AscReadChipDmaSpeed(port)         (uchar)inp((port)+IOP_DMA_SPEED)
 
 920 #define AscWriteChipDmaSpeed(port, data)  outp((port)+IOP_DMA_SPEED, data)
 
 921 #define AscReadChipDA0(port)              (ushort)inpw((port)+IOP_REG_DA0)
 
 922 #define AscWriteChipDA0(port)             outpw((port)+IOP_REG_DA0, data)
 
 923 #define AscReadChipDA1(port)              (ushort)inpw((port)+IOP_REG_DA1)
 
 924 #define AscWriteChipDA1(port)             outpw((port)+IOP_REG_DA1, data)
 
 925 #define AscReadChipDC0(port)              (ushort)inpw((port)+IOP_REG_DC0)
 
 926 #define AscWriteChipDC0(port)             outpw((port)+IOP_REG_DC0, data)
 
 927 #define AscReadChipDC1(port)              (ushort)inpw((port)+IOP_REG_DC1)
 
 928 #define AscWriteChipDC1(port)             outpw((port)+IOP_REG_DC1, data)
 
 929 #define AscReadChipDvcID(port)            (uchar)inp((port)+IOP_REG_ID)
 
 930 #define AscWriteChipDvcID(port, data)     outp((port)+IOP_REG_ID, data)
 
 933  * Portable Data Types
 
 935  * Any instance where a 32-bit long or pointer type is assumed
 
 936  * for precision or HW defined structures, the following define
 
 937  * types must be used. In Linux the char, short, and int types
 
 938  * are all consistent at 8, 16, and 32 bits respectively. Pointers
 
 939  * and long types are 64 bits on Alpha and UltraSPARC.
 
 941 #define ADV_PADDR __u32         /* Physical address data type. */
 
 942 #define ADV_VADDR __u32         /* Virtual address data type. */
 
 943 #define ADV_DCNT  __u32         /* Unsigned Data count type. */
 
 944 #define ADV_SDCNT __s32         /* Signed Data count type. */
 
 947  * These macros are used to convert a virtual address to a
 
 948  * 32-bit value. This currently can be used on Linux Alpha
 
 949  * which uses 64-bit virtual address but a 32-bit bus address.
 
 950  * This is likely to break in the future, but doing this now
 
 951  * will give us time to change the HW and FW to handle 64-bit
 
 954 #define ADV_VADDR_TO_U32   virt_to_bus
 
 955 #define ADV_U32_TO_VADDR   bus_to_virt
 
 957 #define AdvPortAddr  void __iomem *     /* Virtual memory address size */
 
 960  * Define Adv Library required memory access macros.
 
 962 #define ADV_MEM_READB(addr) readb(addr)
 
 963 #define ADV_MEM_READW(addr) readw(addr)
 
 964 #define ADV_MEM_WRITEB(addr, byte) writeb(byte, addr)
 
 965 #define ADV_MEM_WRITEW(addr, word) writew(word, addr)
 
 966 #define ADV_MEM_WRITEDW(addr, dword) writel(dword, addr)
 
 968 #define ADV_CARRIER_COUNT (ASC_DEF_MAX_HOST_QNG + 15)
 
 971  * Define total number of simultaneous maximum element scatter-gather
 
 972  * request blocks per wide adapter. ASC_DEF_MAX_HOST_QNG (253) is the
 
 973  * maximum number of outstanding commands per wide host adapter. Each
 
 974  * command uses one or more ADV_SG_BLOCK each with 15 scatter-gather
 
 975  * elements. Allow each command to have at least one ADV_SG_BLOCK structure.
 
 976  * This allows about 15 commands to have the maximum 17 ADV_SG_BLOCK
 
 977  * structures or 255 scatter-gather elements.
 
 979 #define ADV_TOT_SG_BLOCK        ASC_DEF_MAX_HOST_QNG
 
 982  * Define maximum number of scatter-gather elements per request.
 
 984 #define ADV_MAX_SG_LIST         255
 
 985 #define NO_OF_SG_PER_BLOCK              15
 
 987 #define ADV_EEP_DVC_CFG_BEGIN           (0x00)
 
 988 #define ADV_EEP_DVC_CFG_END             (0x15)
 
 989 #define ADV_EEP_DVC_CTL_BEGIN           (0x16)  /* location of OEM name */
 
 990 #define ADV_EEP_MAX_WORD_ADDR           (0x1E)
 
 992 #define ADV_EEP_DELAY_MS                100
 
 994 #define ADV_EEPROM_BIG_ENDIAN          0x8000   /* EEPROM Bit 15 */
 
 995 #define ADV_EEPROM_BIOS_ENABLE         0x4000   /* EEPROM Bit 14 */
 
 997  * For the ASC3550 Bit 13 is Termination Polarity control bit.
 
 998  * For later ICs Bit 13 controls whether the CIS (Card Information
 
 999  * Service Section) is loaded from EEPROM.
 
1001 #define ADV_EEPROM_TERM_POL            0x2000   /* EEPROM Bit 13 */
 
1002 #define ADV_EEPROM_CIS_LD              0x2000   /* EEPROM Bit 13 */
 
1006  * If EEPROM Bit 11 is 0 for Function 0, then Function 0 will specify
 
1007  * INT A in the PCI Configuration Space Int Pin field. If it is 1, then
 
1008  * Function 0 will specify INT B.
 
1010  * If EEPROM Bit 11 is 0 for Function 1, then Function 1 will specify
 
1011  * INT B in the PCI Configuration Space Int Pin field. If it is 1, then
 
1012  * Function 1 will specify INT A.
 
1014 #define ADV_EEPROM_INTAB               0x0800   /* EEPROM Bit 11 */
 
1016 typedef struct adveep_3550_config {
 
1017         /* Word Offset, Description */
 
1019         ushort cfg_lsw;         /* 00 power up initialization */
 
1020         /*  bit 13 set - Term Polarity Control */
 
1021         /*  bit 14 set - BIOS Enable */
 
1022         /*  bit 15 set - Big Endian Mode */
 
1023         ushort cfg_msw;         /* 01 unused      */
 
1024         ushort disc_enable;     /* 02 disconnect enable */
 
1025         ushort wdtr_able;       /* 03 Wide DTR able */
 
1026         ushort sdtr_able;       /* 04 Synchronous DTR able */
 
1027         ushort start_motor;     /* 05 send start up motor */
 
1028         ushort tagqng_able;     /* 06 tag queuing able */
 
1029         ushort bios_scan;       /* 07 BIOS device control */
 
1030         ushort scam_tolerant;   /* 08 no scam */
 
1032         uchar adapter_scsi_id;  /* 09 Host Adapter ID */
 
1033         uchar bios_boot_delay;  /*    power up wait */
 
1035         uchar scsi_reset_delay; /* 10 reset delay */
 
1036         uchar bios_id_lun;      /*    first boot device scsi id & lun */
 
1037         /*    high nibble is lun */
 
1038         /*    low nibble is scsi id */
 
1040         uchar termination;      /* 11 0 - automatic */
 
1041         /*    1 - low off / high off */
 
1042         /*    2 - low off / high on */
 
1043         /*    3 - low on  / high on */
 
1044         /*    There is no low on  / high off */
 
1046         uchar reserved1;        /*    reserved byte (not used) */
 
1048         ushort bios_ctrl;       /* 12 BIOS control bits */
 
1049         /*  bit 0  BIOS don't act as initiator. */
 
1050         /*  bit 1  BIOS > 1 GB support */
 
1051         /*  bit 2  BIOS > 2 Disk Support */
 
1052         /*  bit 3  BIOS don't support removables */
 
1053         /*  bit 4  BIOS support bootable CD */
 
1054         /*  bit 5  BIOS scan enabled */
 
1055         /*  bit 6  BIOS support multiple LUNs */
 
1056         /*  bit 7  BIOS display of message */
 
1057         /*  bit 8  SCAM disabled */
 
1058         /*  bit 9  Reset SCSI bus during init. */
 
1060         /*  bit 11 No verbose initialization. */
 
1061         /*  bit 12 SCSI parity enabled */
 
1065         ushort ultra_able;      /* 13 ULTRA speed able */
 
1066         ushort reserved2;       /* 14 reserved */
 
1067         uchar max_host_qng;     /* 15 maximum host queuing */
 
1068         uchar max_dvc_qng;      /*    maximum per device queuing */
 
1069         ushort dvc_cntl;        /* 16 control bit for driver */
 
1070         ushort bug_fix;         /* 17 control bit for bug fix */
 
1071         ushort serial_number_word1;     /* 18 Board serial number word 1 */
 
1072         ushort serial_number_word2;     /* 19 Board serial number word 2 */
 
1073         ushort serial_number_word3;     /* 20 Board serial number word 3 */
 
1074         ushort check_sum;       /* 21 EEP check sum */
 
1075         uchar oem_name[16];     /* 22 OEM name */
 
1076         ushort dvc_err_code;    /* 30 last device driver error code */
 
1077         ushort adv_err_code;    /* 31 last uc and Adv Lib error code */
 
1078         ushort adv_err_addr;    /* 32 last uc error address */
 
1079         ushort saved_dvc_err_code;      /* 33 saved last dev. driver error code   */
 
1080         ushort saved_adv_err_code;      /* 34 saved last uc and Adv Lib error code */
 
1081         ushort saved_adv_err_addr;      /* 35 saved last uc error address         */
 
1082         ushort num_of_err;      /* 36 number of error */
 
1083 } ADVEEP_3550_CONFIG;
 
1085 typedef struct adveep_38C0800_config {
 
1086         /* Word Offset, Description */
 
1088         ushort cfg_lsw;         /* 00 power up initialization */
 
1089         /*  bit 13 set - Load CIS */
 
1090         /*  bit 14 set - BIOS Enable */
 
1091         /*  bit 15 set - Big Endian Mode */
 
1092         ushort cfg_msw;         /* 01 unused      */
 
1093         ushort disc_enable;     /* 02 disconnect enable */
 
1094         ushort wdtr_able;       /* 03 Wide DTR able */
 
1095         ushort sdtr_speed1;     /* 04 SDTR Speed TID 0-3 */
 
1096         ushort start_motor;     /* 05 send start up motor */
 
1097         ushort tagqng_able;     /* 06 tag queuing able */
 
1098         ushort bios_scan;       /* 07 BIOS device control */
 
1099         ushort scam_tolerant;   /* 08 no scam */
 
1101         uchar adapter_scsi_id;  /* 09 Host Adapter ID */
 
1102         uchar bios_boot_delay;  /*    power up wait */
 
1104         uchar scsi_reset_delay; /* 10 reset delay */
 
1105         uchar bios_id_lun;      /*    first boot device scsi id & lun */
 
1106         /*    high nibble is lun */
 
1107         /*    low nibble is scsi id */
 
1109         uchar termination_se;   /* 11 0 - automatic */
 
1110         /*    1 - low off / high off */
 
1111         /*    2 - low off / high on */
 
1112         /*    3 - low on  / high on */
 
1113         /*    There is no low on  / high off */
 
1115         uchar termination_lvd;  /* 11 0 - automatic */
 
1116         /*    1 - low off / high off */
 
1117         /*    2 - low off / high on */
 
1118         /*    3 - low on  / high on */
 
1119         /*    There is no low on  / high off */
 
1121         ushort bios_ctrl;       /* 12 BIOS control bits */
 
1122         /*  bit 0  BIOS don't act as initiator. */
 
1123         /*  bit 1  BIOS > 1 GB support */
 
1124         /*  bit 2  BIOS > 2 Disk Support */
 
1125         /*  bit 3  BIOS don't support removables */
 
1126         /*  bit 4  BIOS support bootable CD */
 
1127         /*  bit 5  BIOS scan enabled */
 
1128         /*  bit 6  BIOS support multiple LUNs */
 
1129         /*  bit 7  BIOS display of message */
 
1130         /*  bit 8  SCAM disabled */
 
1131         /*  bit 9  Reset SCSI bus during init. */
 
1133         /*  bit 11 No verbose initialization. */
 
1134         /*  bit 12 SCSI parity enabled */
 
1138         ushort sdtr_speed2;     /* 13 SDTR speed TID 4-7 */
 
1139         ushort sdtr_speed3;     /* 14 SDTR speed TID 8-11 */
 
1140         uchar max_host_qng;     /* 15 maximum host queueing */
 
1141         uchar max_dvc_qng;      /*    maximum per device queuing */
 
1142         ushort dvc_cntl;        /* 16 control bit for driver */
 
1143         ushort sdtr_speed4;     /* 17 SDTR speed 4 TID 12-15 */
 
1144         ushort serial_number_word1;     /* 18 Board serial number word 1 */
 
1145         ushort serial_number_word2;     /* 19 Board serial number word 2 */
 
1146         ushort serial_number_word3;     /* 20 Board serial number word 3 */
 
1147         ushort check_sum;       /* 21 EEP check sum */
 
1148         uchar oem_name[16];     /* 22 OEM name */
 
1149         ushort dvc_err_code;    /* 30 last device driver error code */
 
1150         ushort adv_err_code;    /* 31 last uc and Adv Lib error code */
 
1151         ushort adv_err_addr;    /* 32 last uc error address */
 
1152         ushort saved_dvc_err_code;      /* 33 saved last dev. driver error code   */
 
1153         ushort saved_adv_err_code;      /* 34 saved last uc and Adv Lib error code */
 
1154         ushort saved_adv_err_addr;      /* 35 saved last uc error address         */
 
1155         ushort reserved36;      /* 36 reserved */
 
1156         ushort reserved37;      /* 37 reserved */
 
1157         ushort reserved38;      /* 38 reserved */
 
1158         ushort reserved39;      /* 39 reserved */
 
1159         ushort reserved40;      /* 40 reserved */
 
1160         ushort reserved41;      /* 41 reserved */
 
1161         ushort reserved42;      /* 42 reserved */
 
1162         ushort reserved43;      /* 43 reserved */
 
1163         ushort reserved44;      /* 44 reserved */
 
1164         ushort reserved45;      /* 45 reserved */
 
1165         ushort reserved46;      /* 46 reserved */
 
1166         ushort reserved47;      /* 47 reserved */
 
1167         ushort reserved48;      /* 48 reserved */
 
1168         ushort reserved49;      /* 49 reserved */
 
1169         ushort reserved50;      /* 50 reserved */
 
1170         ushort reserved51;      /* 51 reserved */
 
1171         ushort reserved52;      /* 52 reserved */
 
1172         ushort reserved53;      /* 53 reserved */
 
1173         ushort reserved54;      /* 54 reserved */
 
1174         ushort reserved55;      /* 55 reserved */
 
1175         ushort cisptr_lsw;      /* 56 CIS PTR LSW */
 
1176         ushort cisprt_msw;      /* 57 CIS PTR MSW */
 
1177         ushort subsysvid;       /* 58 SubSystem Vendor ID */
 
1178         ushort subsysid;        /* 59 SubSystem ID */
 
1179         ushort reserved60;      /* 60 reserved */
 
1180         ushort reserved61;      /* 61 reserved */
 
1181         ushort reserved62;      /* 62 reserved */
 
1182         ushort reserved63;      /* 63 reserved */
 
1183 } ADVEEP_38C0800_CONFIG;
 
1185 typedef struct adveep_38C1600_config {
 
1186         /* Word Offset, Description */
 
1188         ushort cfg_lsw;         /* 00 power up initialization */
 
1189         /*  bit 11 set - Func. 0 INTB, Func. 1 INTA */
 
1190         /*       clear - Func. 0 INTA, Func. 1 INTB */
 
1191         /*  bit 13 set - Load CIS */
 
1192         /*  bit 14 set - BIOS Enable */
 
1193         /*  bit 15 set - Big Endian Mode */
 
1194         ushort cfg_msw;         /* 01 unused */
 
1195         ushort disc_enable;     /* 02 disconnect enable */
 
1196         ushort wdtr_able;       /* 03 Wide DTR able */
 
1197         ushort sdtr_speed1;     /* 04 SDTR Speed TID 0-3 */
 
1198         ushort start_motor;     /* 05 send start up motor */
 
1199         ushort tagqng_able;     /* 06 tag queuing able */
 
1200         ushort bios_scan;       /* 07 BIOS device control */
 
1201         ushort scam_tolerant;   /* 08 no scam */
 
1203         uchar adapter_scsi_id;  /* 09 Host Adapter ID */
 
1204         uchar bios_boot_delay;  /*    power up wait */
 
1206         uchar scsi_reset_delay; /* 10 reset delay */
 
1207         uchar bios_id_lun;      /*    first boot device scsi id & lun */
 
1208         /*    high nibble is lun */
 
1209         /*    low nibble is scsi id */
 
1211         uchar termination_se;   /* 11 0 - automatic */
 
1212         /*    1 - low off / high off */
 
1213         /*    2 - low off / high on */
 
1214         /*    3 - low on  / high on */
 
1215         /*    There is no low on  / high off */
 
1217         uchar termination_lvd;  /* 11 0 - automatic */
 
1218         /*    1 - low off / high off */
 
1219         /*    2 - low off / high on */
 
1220         /*    3 - low on  / high on */
 
1221         /*    There is no low on  / high off */
 
1223         ushort bios_ctrl;       /* 12 BIOS control bits */
 
1224         /*  bit 0  BIOS don't act as initiator. */
 
1225         /*  bit 1  BIOS > 1 GB support */
 
1226         /*  bit 2  BIOS > 2 Disk Support */
 
1227         /*  bit 3  BIOS don't support removables */
 
1228         /*  bit 4  BIOS support bootable CD */
 
1229         /*  bit 5  BIOS scan enabled */
 
1230         /*  bit 6  BIOS support multiple LUNs */
 
1231         /*  bit 7  BIOS display of message */
 
1232         /*  bit 8  SCAM disabled */
 
1233         /*  bit 9  Reset SCSI bus during init. */
 
1234         /*  bit 10 Basic Integrity Checking disabled */
 
1235         /*  bit 11 No verbose initialization. */
 
1236         /*  bit 12 SCSI parity enabled */
 
1237         /*  bit 13 AIPP (Asyn. Info. Ph. Prot.) dis. */
 
1240         ushort sdtr_speed2;     /* 13 SDTR speed TID 4-7 */
 
1241         ushort sdtr_speed3;     /* 14 SDTR speed TID 8-11 */
 
1242         uchar max_host_qng;     /* 15 maximum host queueing */
 
1243         uchar max_dvc_qng;      /*    maximum per device queuing */
 
1244         ushort dvc_cntl;        /* 16 control bit for driver */
 
1245         ushort sdtr_speed4;     /* 17 SDTR speed 4 TID 12-15 */
 
1246         ushort serial_number_word1;     /* 18 Board serial number word 1 */
 
1247         ushort serial_number_word2;     /* 19 Board serial number word 2 */
 
1248         ushort serial_number_word3;     /* 20 Board serial number word 3 */
 
1249         ushort check_sum;       /* 21 EEP check sum */
 
1250         uchar oem_name[16];     /* 22 OEM name */
 
1251         ushort dvc_err_code;    /* 30 last device driver error code */
 
1252         ushort adv_err_code;    /* 31 last uc and Adv Lib error code */
 
1253         ushort adv_err_addr;    /* 32 last uc error address */
 
1254         ushort saved_dvc_err_code;      /* 33 saved last dev. driver error code   */
 
1255         ushort saved_adv_err_code;      /* 34 saved last uc and Adv Lib error code */
 
1256         ushort saved_adv_err_addr;      /* 35 saved last uc error address         */
 
1257         ushort reserved36;      /* 36 reserved */
 
1258         ushort reserved37;      /* 37 reserved */
 
1259         ushort reserved38;      /* 38 reserved */
 
1260         ushort reserved39;      /* 39 reserved */
 
1261         ushort reserved40;      /* 40 reserved */
 
1262         ushort reserved41;      /* 41 reserved */
 
1263         ushort reserved42;      /* 42 reserved */
 
1264         ushort reserved43;      /* 43 reserved */
 
1265         ushort reserved44;      /* 44 reserved */
 
1266         ushort reserved45;      /* 45 reserved */
 
1267         ushort reserved46;      /* 46 reserved */
 
1268         ushort reserved47;      /* 47 reserved */
 
1269         ushort reserved48;      /* 48 reserved */
 
1270         ushort reserved49;      /* 49 reserved */
 
1271         ushort reserved50;      /* 50 reserved */
 
1272         ushort reserved51;      /* 51 reserved */
 
1273         ushort reserved52;      /* 52 reserved */
 
1274         ushort reserved53;      /* 53 reserved */
 
1275         ushort reserved54;      /* 54 reserved */
 
1276         ushort reserved55;      /* 55 reserved */
 
1277         ushort cisptr_lsw;      /* 56 CIS PTR LSW */
 
1278         ushort cisprt_msw;      /* 57 CIS PTR MSW */
 
1279         ushort subsysvid;       /* 58 SubSystem Vendor ID */
 
1280         ushort subsysid;        /* 59 SubSystem ID */
 
1281         ushort reserved60;      /* 60 reserved */
 
1282         ushort reserved61;      /* 61 reserved */
 
1283         ushort reserved62;      /* 62 reserved */
 
1284         ushort reserved63;      /* 63 reserved */
 
1285 } ADVEEP_38C1600_CONFIG;
 
1290 #define ASC_EEP_CMD_DONE             0x0200
 
1293 #define BIOS_CTRL_BIOS               0x0001
 
1294 #define BIOS_CTRL_EXTENDED_XLAT      0x0002
 
1295 #define BIOS_CTRL_GT_2_DISK          0x0004
 
1296 #define BIOS_CTRL_BIOS_REMOVABLE     0x0008
 
1297 #define BIOS_CTRL_BOOTABLE_CD        0x0010
 
1298 #define BIOS_CTRL_MULTIPLE_LUN       0x0040
 
1299 #define BIOS_CTRL_DISPLAY_MSG        0x0080
 
1300 #define BIOS_CTRL_NO_SCAM            0x0100
 
1301 #define BIOS_CTRL_RESET_SCSI_BUS     0x0200
 
1302 #define BIOS_CTRL_INIT_VERBOSE       0x0800
 
1303 #define BIOS_CTRL_SCSI_PARITY        0x1000
 
1304 #define BIOS_CTRL_AIPP_DIS           0x2000
 
1306 #define ADV_3550_MEMSIZE   0x2000       /* 8 KB Internal Memory */
 
1308 #define ADV_38C0800_MEMSIZE  0x4000     /* 16 KB Internal Memory */
 
1311  * XXX - Since ASC38C1600 Rev.3 has a local RAM failure issue, there is
 
1312  * a special 16K Adv Library and Microcode version. After the issue is
 
1313  * resolved, should restore 32K support.
 
1315  * #define ADV_38C1600_MEMSIZE  0x8000L   * 32 KB Internal Memory *
 
1317 #define ADV_38C1600_MEMSIZE  0x4000     /* 16 KB Internal Memory */
 
1320  * Byte I/O register address from base of 'iop_base'.
 
1322 #define IOPB_INTR_STATUS_REG    0x00
 
1323 #define IOPB_CHIP_ID_1          0x01
 
1324 #define IOPB_INTR_ENABLES       0x02
 
1325 #define IOPB_CHIP_TYPE_REV      0x03
 
1326 #define IOPB_RES_ADDR_4         0x04
 
1327 #define IOPB_RES_ADDR_5         0x05
 
1328 #define IOPB_RAM_DATA           0x06
 
1329 #define IOPB_RES_ADDR_7         0x07
 
1330 #define IOPB_FLAG_REG           0x08
 
1331 #define IOPB_RES_ADDR_9         0x09
 
1332 #define IOPB_RISC_CSR           0x0A
 
1333 #define IOPB_RES_ADDR_B         0x0B
 
1334 #define IOPB_RES_ADDR_C         0x0C
 
1335 #define IOPB_RES_ADDR_D         0x0D
 
1336 #define IOPB_SOFT_OVER_WR       0x0E
 
1337 #define IOPB_RES_ADDR_F         0x0F
 
1338 #define IOPB_MEM_CFG            0x10
 
1339 #define IOPB_RES_ADDR_11        0x11
 
1340 #define IOPB_GPIO_DATA          0x12
 
1341 #define IOPB_RES_ADDR_13        0x13
 
1342 #define IOPB_FLASH_PAGE         0x14
 
1343 #define IOPB_RES_ADDR_15        0x15
 
1344 #define IOPB_GPIO_CNTL          0x16
 
1345 #define IOPB_RES_ADDR_17        0x17
 
1346 #define IOPB_FLASH_DATA         0x18
 
1347 #define IOPB_RES_ADDR_19        0x19
 
1348 #define IOPB_RES_ADDR_1A        0x1A
 
1349 #define IOPB_RES_ADDR_1B        0x1B
 
1350 #define IOPB_RES_ADDR_1C        0x1C
 
1351 #define IOPB_RES_ADDR_1D        0x1D
 
1352 #define IOPB_RES_ADDR_1E        0x1E
 
1353 #define IOPB_RES_ADDR_1F        0x1F
 
1354 #define IOPB_DMA_CFG0           0x20
 
1355 #define IOPB_DMA_CFG1           0x21
 
1356 #define IOPB_TICKLE             0x22
 
1357 #define IOPB_DMA_REG_WR         0x23
 
1358 #define IOPB_SDMA_STATUS        0x24
 
1359 #define IOPB_SCSI_BYTE_CNT      0x25
 
1360 #define IOPB_HOST_BYTE_CNT      0x26
 
1361 #define IOPB_BYTE_LEFT_TO_XFER  0x27
 
1362 #define IOPB_BYTE_TO_XFER_0     0x28
 
1363 #define IOPB_BYTE_TO_XFER_1     0x29
 
1364 #define IOPB_BYTE_TO_XFER_2     0x2A
 
1365 #define IOPB_BYTE_TO_XFER_3     0x2B
 
1366 #define IOPB_ACC_GRP            0x2C
 
1367 #define IOPB_RES_ADDR_2D        0x2D
 
1368 #define IOPB_DEV_ID             0x2E
 
1369 #define IOPB_RES_ADDR_2F        0x2F
 
1370 #define IOPB_SCSI_DATA          0x30
 
1371 #define IOPB_RES_ADDR_31        0x31
 
1372 #define IOPB_RES_ADDR_32        0x32
 
1373 #define IOPB_SCSI_DATA_HSHK     0x33
 
1374 #define IOPB_SCSI_CTRL          0x34
 
1375 #define IOPB_RES_ADDR_35        0x35
 
1376 #define IOPB_RES_ADDR_36        0x36
 
1377 #define IOPB_RES_ADDR_37        0x37
 
1378 #define IOPB_RAM_BIST           0x38
 
1379 #define IOPB_PLL_TEST           0x39
 
1380 #define IOPB_PCI_INT_CFG        0x3A
 
1381 #define IOPB_RES_ADDR_3B        0x3B
 
1382 #define IOPB_RFIFO_CNT          0x3C
 
1383 #define IOPB_RES_ADDR_3D        0x3D
 
1384 #define IOPB_RES_ADDR_3E        0x3E
 
1385 #define IOPB_RES_ADDR_3F        0x3F
 
1388  * Word I/O register address from base of 'iop_base'.
 
1390 #define IOPW_CHIP_ID_0          0x00    /* CID0  */
 
1391 #define IOPW_CTRL_REG           0x02    /* CC    */
 
1392 #define IOPW_RAM_ADDR           0x04    /* LA    */
 
1393 #define IOPW_RAM_DATA           0x06    /* LD    */
 
1394 #define IOPW_RES_ADDR_08        0x08
 
1395 #define IOPW_RISC_CSR           0x0A    /* CSR   */
 
1396 #define IOPW_SCSI_CFG0          0x0C    /* CFG0  */
 
1397 #define IOPW_SCSI_CFG1          0x0E    /* CFG1  */
 
1398 #define IOPW_RES_ADDR_10        0x10
 
1399 #define IOPW_SEL_MASK           0x12    /* SM    */
 
1400 #define IOPW_RES_ADDR_14        0x14
 
1401 #define IOPW_FLASH_ADDR         0x16    /* FA    */
 
1402 #define IOPW_RES_ADDR_18        0x18
 
1403 #define IOPW_EE_CMD             0x1A    /* EC    */
 
1404 #define IOPW_EE_DATA            0x1C    /* ED    */
 
1405 #define IOPW_SFIFO_CNT          0x1E    /* SFC   */
 
1406 #define IOPW_RES_ADDR_20        0x20
 
1407 #define IOPW_Q_BASE             0x22    /* QB    */
 
1408 #define IOPW_QP                 0x24    /* QP    */
 
1409 #define IOPW_IX                 0x26    /* IX    */
 
1410 #define IOPW_SP                 0x28    /* SP    */
 
1411 #define IOPW_PC                 0x2A    /* PC    */
 
1412 #define IOPW_RES_ADDR_2C        0x2C
 
1413 #define IOPW_RES_ADDR_2E        0x2E
 
1414 #define IOPW_SCSI_DATA          0x30    /* SD    */
 
1415 #define IOPW_SCSI_DATA_HSHK     0x32    /* SDH   */
 
1416 #define IOPW_SCSI_CTRL          0x34    /* SC    */
 
1417 #define IOPW_HSHK_CFG           0x36    /* HCFG  */
 
1418 #define IOPW_SXFR_STATUS        0x36    /* SXS   */
 
1419 #define IOPW_SXFR_CNTL          0x38    /* SXL   */
 
1420 #define IOPW_SXFR_CNTH          0x3A    /* SXH   */
 
1421 #define IOPW_RES_ADDR_3C        0x3C
 
1422 #define IOPW_RFIFO_DATA         0x3E    /* RFD   */
 
1425  * Doubleword I/O register address from base of 'iop_base'.
 
1427 #define IOPDW_RES_ADDR_0         0x00
 
1428 #define IOPDW_RAM_DATA           0x04
 
1429 #define IOPDW_RES_ADDR_8         0x08
 
1430 #define IOPDW_RES_ADDR_C         0x0C
 
1431 #define IOPDW_RES_ADDR_10        0x10
 
1432 #define IOPDW_COMMA              0x14
 
1433 #define IOPDW_COMMB              0x18
 
1434 #define IOPDW_RES_ADDR_1C        0x1C
 
1435 #define IOPDW_SDMA_ADDR0         0x20
 
1436 #define IOPDW_SDMA_ADDR1         0x24
 
1437 #define IOPDW_SDMA_COUNT         0x28
 
1438 #define IOPDW_SDMA_ERROR         0x2C
 
1439 #define IOPDW_RDMA_ADDR0         0x30
 
1440 #define IOPDW_RDMA_ADDR1         0x34
 
1441 #define IOPDW_RDMA_COUNT         0x38
 
1442 #define IOPDW_RDMA_ERROR         0x3C
 
1444 #define ADV_CHIP_ID_BYTE         0x25
 
1445 #define ADV_CHIP_ID_WORD         0x04C1
 
1447 #define ADV_INTR_ENABLE_HOST_INTR                   0x01
 
1448 #define ADV_INTR_ENABLE_SEL_INTR                    0x02
 
1449 #define ADV_INTR_ENABLE_DPR_INTR                    0x04
 
1450 #define ADV_INTR_ENABLE_RTA_INTR                    0x08
 
1451 #define ADV_INTR_ENABLE_RMA_INTR                    0x10
 
1452 #define ADV_INTR_ENABLE_RST_INTR                    0x20
 
1453 #define ADV_INTR_ENABLE_DPE_INTR                    0x40
 
1454 #define ADV_INTR_ENABLE_GLOBAL_INTR                 0x80
 
1456 #define ADV_INTR_STATUS_INTRA            0x01
 
1457 #define ADV_INTR_STATUS_INTRB            0x02
 
1458 #define ADV_INTR_STATUS_INTRC            0x04
 
1460 #define ADV_RISC_CSR_STOP           (0x0000)
 
1461 #define ADV_RISC_TEST_COND          (0x2000)
 
1462 #define ADV_RISC_CSR_RUN            (0x4000)
 
1463 #define ADV_RISC_CSR_SINGLE_STEP    (0x8000)
 
1465 #define ADV_CTRL_REG_HOST_INTR      0x0100
 
1466 #define ADV_CTRL_REG_SEL_INTR       0x0200
 
1467 #define ADV_CTRL_REG_DPR_INTR       0x0400
 
1468 #define ADV_CTRL_REG_RTA_INTR       0x0800
 
1469 #define ADV_CTRL_REG_RMA_INTR       0x1000
 
1470 #define ADV_CTRL_REG_RES_BIT14      0x2000
 
1471 #define ADV_CTRL_REG_DPE_INTR       0x4000
 
1472 #define ADV_CTRL_REG_POWER_DONE     0x8000
 
1473 #define ADV_CTRL_REG_ANY_INTR       0xFF00
 
1475 #define ADV_CTRL_REG_CMD_RESET             0x00C6
 
1476 #define ADV_CTRL_REG_CMD_WR_IO_REG         0x00C5
 
1477 #define ADV_CTRL_REG_CMD_RD_IO_REG         0x00C4
 
1478 #define ADV_CTRL_REG_CMD_WR_PCI_CFG_SPACE  0x00C3
 
1479 #define ADV_CTRL_REG_CMD_RD_PCI_CFG_SPACE  0x00C2
 
1481 #define ADV_TICKLE_NOP                      0x00
 
1482 #define ADV_TICKLE_A                        0x01
 
1483 #define ADV_TICKLE_B                        0x02
 
1484 #define ADV_TICKLE_C                        0x03
 
1486 #define AdvIsIntPending(port) \
 
1487     (AdvReadWordRegister(port, IOPW_CTRL_REG) & ADV_CTRL_REG_HOST_INTR)
 
1490  * SCSI_CFG0 Register bit definitions
 
1492 #define TIMER_MODEAB    0xC000  /* Watchdog, Second, and Select. Timer Ctrl. */
 
1493 #define PARITY_EN       0x2000  /* Enable SCSI Parity Error detection */
 
1494 #define EVEN_PARITY     0x1000  /* Select Even Parity */
 
1495 #define WD_LONG         0x0800  /* Watchdog Interval, 1: 57 min, 0: 13 sec */
 
1496 #define QUEUE_128       0x0400  /* Queue Size, 1: 128 byte, 0: 64 byte */
 
1497 #define PRIM_MODE       0x0100  /* Primitive SCSI mode */
 
1498 #define SCAM_EN         0x0080  /* Enable SCAM selection */
 
1499 #define SEL_TMO_LONG    0x0040  /* Sel/Resel Timeout, 1: 400 ms, 0: 1.6 ms */
 
1500 #define CFRM_ID         0x0020  /* SCAM id sel. confirm., 1: fast, 0: 6.4 ms */
 
1501 #define OUR_ID_EN       0x0010  /* Enable OUR_ID bits */
 
1502 #define OUR_ID          0x000F  /* SCSI ID */
 
1505  * SCSI_CFG1 Register bit definitions
 
1507 #define BIG_ENDIAN      0x8000  /* Enable Big Endian Mode MIO:15, EEP:15 */
 
1508 #define TERM_POL        0x2000  /* Terminator Polarity Ctrl. MIO:13, EEP:13 */
 
1509 #define SLEW_RATE       0x1000  /* SCSI output buffer slew rate */
 
1510 #define FILTER_SEL      0x0C00  /* Filter Period Selection */
 
1511 #define  FLTR_DISABLE    0x0000 /* Input Filtering Disabled */
 
1512 #define  FLTR_11_TO_20NS 0x0800 /* Input Filtering 11ns to 20ns */
 
1513 #define  FLTR_21_TO_39NS 0x0C00 /* Input Filtering 21ns to 39ns */
 
1514 #define ACTIVE_DBL      0x0200  /* Disable Active Negation */
 
1515 #define DIFF_MODE       0x0100  /* SCSI differential Mode (Read-Only) */
 
1516 #define DIFF_SENSE      0x0080  /* 1: No SE cables, 0: SE cable (Read-Only) */
 
1517 #define TERM_CTL_SEL    0x0040  /* Enable TERM_CTL_H and TERM_CTL_L */
 
1518 #define TERM_CTL        0x0030  /* External SCSI Termination Bits */
 
1519 #define  TERM_CTL_H      0x0020 /* Enable External SCSI Upper Termination */
 
1520 #define  TERM_CTL_L      0x0010 /* Enable External SCSI Lower Termination */
 
1521 #define CABLE_DETECT    0x000F  /* External SCSI Cable Connection Status */
 
1524  * Addendum for ASC-38C0800 Chip
 
1526  * The ASC-38C1600 Chip uses the same definitions except that the
 
1527  * bus mode override bits [12:10] have been moved to byte register
 
1528  * offset 0xE (IOPB_SOFT_OVER_WR) bits [12:10]. The [12:10] bits in
 
1529  * SCSI_CFG1 are read-only and always available. Bit 14 (DIS_TERM_DRV)
 
1530  * is not needed. The [12:10] bits in IOPB_SOFT_OVER_WR are write-only.
 
1531  * Also each ASC-38C1600 function or channel uses only cable bits [5:4]
 
1532  * and [1:0]. Bits [14], [7:6], [3:2] are unused.
 
1534 #define DIS_TERM_DRV    0x4000  /* 1: Read c_det[3:0], 0: cannot read */
 
1535 #define HVD_LVD_SE      0x1C00  /* Device Detect Bits */
 
1536 #define  HVD             0x1000 /* HVD Device Detect */
 
1537 #define  LVD             0x0800 /* LVD Device Detect */
 
1538 #define  SE              0x0400 /* SE Device Detect */
 
1539 #define TERM_LVD        0x00C0  /* LVD Termination Bits */
 
1540 #define  TERM_LVD_HI     0x0080 /* Enable LVD Upper Termination */
 
1541 #define  TERM_LVD_LO     0x0040 /* Enable LVD Lower Termination */
 
1542 #define TERM_SE         0x0030  /* SE Termination Bits */
 
1543 #define  TERM_SE_HI      0x0020 /* Enable SE Upper Termination */
 
1544 #define  TERM_SE_LO      0x0010 /* Enable SE Lower Termination */
 
1545 #define C_DET_LVD       0x000C  /* LVD Cable Detect Bits */
 
1546 #define  C_DET3          0x0008 /* Cable Detect for LVD External Wide */
 
1547 #define  C_DET2          0x0004 /* Cable Detect for LVD Internal Wide */
 
1548 #define C_DET_SE        0x0003  /* SE Cable Detect Bits */
 
1549 #define  C_DET1          0x0002 /* Cable Detect for SE Internal Wide */
 
1550 #define  C_DET0          0x0001 /* Cable Detect for SE Internal Narrow */
 
1552 #define CABLE_ILLEGAL_A 0x7
 
1553     /* x 0 0 0  | on  on | Illegal (all 3 connectors are used) */
 
1555 #define CABLE_ILLEGAL_B 0xB
 
1556     /* 0 x 0 0  | on  on | Illegal (all 3 connectors are used) */
 
1559  * MEM_CFG Register bit definitions
 
1561 #define BIOS_EN         0x40    /* BIOS Enable MIO:14,EEP:14 */
 
1562 #define FAST_EE_CLK     0x20    /* Diagnostic Bit */
 
1563 #define RAM_SZ          0x1C    /* Specify size of RAM to RISC */
 
1564 #define  RAM_SZ_2KB      0x00   /* 2 KB */
 
1565 #define  RAM_SZ_4KB      0x04   /* 4 KB */
 
1566 #define  RAM_SZ_8KB      0x08   /* 8 KB */
 
1567 #define  RAM_SZ_16KB     0x0C   /* 16 KB */
 
1568 #define  RAM_SZ_32KB     0x10   /* 32 KB */
 
1569 #define  RAM_SZ_64KB     0x14   /* 64 KB */
 
1572  * DMA_CFG0 Register bit definitions
 
1574  * This register is only accessible to the host.
 
1576 #define BC_THRESH_ENB   0x80    /* PCI DMA Start Conditions */
 
1577 #define FIFO_THRESH     0x70    /* PCI DMA FIFO Threshold */
 
1578 #define  FIFO_THRESH_16B  0x00  /* 16 bytes */
 
1579 #define  FIFO_THRESH_32B  0x20  /* 32 bytes */
 
1580 #define  FIFO_THRESH_48B  0x30  /* 48 bytes */
 
1581 #define  FIFO_THRESH_64B  0x40  /* 64 bytes */
 
1582 #define  FIFO_THRESH_80B  0x50  /* 80 bytes (default) */
 
1583 #define  FIFO_THRESH_96B  0x60  /* 96 bytes */
 
1584 #define  FIFO_THRESH_112B 0x70  /* 112 bytes */
 
1585 #define START_CTL       0x0C    /* DMA start conditions */
 
1586 #define  START_CTL_TH    0x00   /* Wait threshold level (default) */
 
1587 #define  START_CTL_ID    0x04   /* Wait SDMA/SBUS idle */
 
1588 #define  START_CTL_THID  0x08   /* Wait threshold and SDMA/SBUS idle */
 
1589 #define  START_CTL_EMFU  0x0C   /* Wait SDMA FIFO empty/full */
 
1590 #define READ_CMD        0x03    /* Memory Read Method */
 
1591 #define  READ_CMD_MR     0x00   /* Memory Read */
 
1592 #define  READ_CMD_MRL    0x02   /* Memory Read Long */
 
1593 #define  READ_CMD_MRM    0x03   /* Memory Read Multiple (default) */
 
1596  * ASC-38C0800 RAM BIST Register bit definitions
 
1598 #define RAM_TEST_MODE         0x80
 
1599 #define PRE_TEST_MODE         0x40
 
1600 #define NORMAL_MODE           0x00
 
1601 #define RAM_TEST_DONE         0x10
 
1602 #define RAM_TEST_STATUS       0x0F
 
1603 #define  RAM_TEST_HOST_ERROR   0x08
 
1604 #define  RAM_TEST_INTRAM_ERROR 0x04
 
1605 #define  RAM_TEST_RISC_ERROR   0x02
 
1606 #define  RAM_TEST_SCSI_ERROR   0x01
 
1607 #define  RAM_TEST_SUCCESS      0x00
 
1608 #define PRE_TEST_VALUE        0x05
 
1609 #define NORMAL_VALUE          0x00
 
1612  * ASC38C1600 Definitions
 
1614  * IOPB_PCI_INT_CFG Bit Field Definitions
 
1617 #define INTAB_LD        0x80    /* Value loaded from EEPROM Bit 11. */
 
1620  * Bit 1 can be set to change the interrupt for the Function to operate in
 
1621  * Totem Pole mode. By default Bit 1 is 0 and the interrupt operates in
 
1622  * Open Drain mode. Both functions of the ASC38C1600 must be set to the same
 
1623  * mode, otherwise the operating mode is undefined.
 
1625 #define TOTEMPOLE       0x02
 
1628  * Bit 0 can be used to change the Int Pin for the Function. The value is
 
1629  * 0 by default for both Functions with Function 0 using INT A and Function
 
1630  * B using INT B. For Function 0 if set, INT B is used. For Function 1 if set,
 
1633  * EEPROM Word 0 Bit 11 for each Function may change the initial Int Pin
 
1634  * value specified in the PCI Configuration Space.
 
1639  * Adv Library Status Definitions
 
1643 #define ADV_SUCCESS     1
 
1645 #define ADV_ERROR       (-1)
 
1648  * ADV_DVC_VAR 'warn_code' values
 
1650 #define ASC_WARN_BUSRESET_ERROR         0x0001  /* SCSI Bus Reset error */
 
1651 #define ASC_WARN_EEPROM_CHKSUM          0x0002  /* EEP check sum error */
 
1652 #define ASC_WARN_EEPROM_TERMINATION     0x0004  /* EEP termination bad field */
 
1653 #define ASC_WARN_ERROR                  0xFFFF  /* ADV_ERROR return */
 
1655 #define ADV_MAX_TID                     15      /* max. target identifier */
 
1656 #define ADV_MAX_LUN                     7       /* max. logical unit number */
 
1659  * Fixed locations of microcode operating variables.
 
1661 #define ASC_MC_CODE_BEGIN_ADDR          0x0028  /* microcode start address */
 
1662 #define ASC_MC_CODE_END_ADDR            0x002A  /* microcode end address */
 
1663 #define ASC_MC_CODE_CHK_SUM             0x002C  /* microcode code checksum */
 
1664 #define ASC_MC_VERSION_DATE             0x0038  /* microcode version */
 
1665 #define ASC_MC_VERSION_NUM              0x003A  /* microcode number */
 
1666 #define ASC_MC_BIOSMEM                  0x0040  /* BIOS RISC Memory Start */
 
1667 #define ASC_MC_BIOSLEN                  0x0050  /* BIOS RISC Memory Length */
 
1668 #define ASC_MC_BIOS_SIGNATURE           0x0058  /* BIOS Signature 0x55AA */
 
1669 #define ASC_MC_BIOS_VERSION             0x005A  /* BIOS Version (2 bytes) */
 
1670 #define ASC_MC_SDTR_SPEED1              0x0090  /* SDTR Speed for TID 0-3 */
 
1671 #define ASC_MC_SDTR_SPEED2              0x0092  /* SDTR Speed for TID 4-7 */
 
1672 #define ASC_MC_SDTR_SPEED3              0x0094  /* SDTR Speed for TID 8-11 */
 
1673 #define ASC_MC_SDTR_SPEED4              0x0096  /* SDTR Speed for TID 12-15 */
 
1674 #define ASC_MC_CHIP_TYPE                0x009A
 
1675 #define ASC_MC_INTRB_CODE               0x009B
 
1676 #define ASC_MC_WDTR_ABLE                0x009C
 
1677 #define ASC_MC_SDTR_ABLE                0x009E
 
1678 #define ASC_MC_TAGQNG_ABLE              0x00A0
 
1679 #define ASC_MC_DISC_ENABLE              0x00A2
 
1680 #define ASC_MC_IDLE_CMD_STATUS          0x00A4
 
1681 #define ASC_MC_IDLE_CMD                 0x00A6
 
1682 #define ASC_MC_IDLE_CMD_PARAMETER       0x00A8
 
1683 #define ASC_MC_DEFAULT_SCSI_CFG0        0x00AC
 
1684 #define ASC_MC_DEFAULT_SCSI_CFG1        0x00AE
 
1685 #define ASC_MC_DEFAULT_MEM_CFG          0x00B0
 
1686 #define ASC_MC_DEFAULT_SEL_MASK         0x00B2
 
1687 #define ASC_MC_SDTR_DONE                0x00B6
 
1688 #define ASC_MC_NUMBER_OF_QUEUED_CMD     0x00C0
 
1689 #define ASC_MC_NUMBER_OF_MAX_CMD        0x00D0
 
1690 #define ASC_MC_DEVICE_HSHK_CFG_TABLE    0x0100
 
1691 #define ASC_MC_CONTROL_FLAG             0x0122  /* Microcode control flag. */
 
1692 #define ASC_MC_WDTR_DONE                0x0124
 
1693 #define ASC_MC_CAM_MODE_MASK            0x015E  /* CAM mode TID bitmask. */
 
1694 #define ASC_MC_ICQ                      0x0160
 
1695 #define ASC_MC_IRQ                      0x0164
 
1696 #define ASC_MC_PPR_ABLE                 0x017A
 
1699  * BIOS LRAM variable absolute offsets.
 
1701 #define BIOS_CODESEG    0x54
 
1702 #define BIOS_CODELEN    0x56
 
1703 #define BIOS_SIGNATURE  0x58
 
1704 #define BIOS_VERSION    0x5A
 
1707  * Microcode Control Flags
 
1709  * Flags set by the Adv Library in RISC variable 'control_flag' (0x122)
 
1710  * and handled by the microcode.
 
1712 #define CONTROL_FLAG_IGNORE_PERR        0x0001  /* Ignore DMA Parity Errors */
 
1713 #define CONTROL_FLAG_ENABLE_AIPP        0x0002  /* Enabled AIPP checking. */
 
1716  * ASC_MC_DEVICE_HSHK_CFG_TABLE microcode table or HSHK_CFG register format
 
1718 #define HSHK_CFG_WIDE_XFR       0x8000
 
1719 #define HSHK_CFG_RATE           0x0F00
 
1720 #define HSHK_CFG_OFFSET         0x001F
 
1722 #define ASC_DEF_MAX_HOST_QNG    0xFD    /* Max. number of host commands (253) */
 
1723 #define ASC_DEF_MIN_HOST_QNG    0x10    /* Min. number of host commands (16) */
 
1724 #define ASC_DEF_MAX_DVC_QNG     0x3F    /* Max. number commands per device (63) */
 
1725 #define ASC_DEF_MIN_DVC_QNG     0x04    /* Min. number commands per device (4) */
 
1727 #define ASC_QC_DATA_CHECK  0x01 /* Require ASC_QC_DATA_OUT set or clear. */
 
1728 #define ASC_QC_DATA_OUT    0x02 /* Data out DMA transfer. */
 
1729 #define ASC_QC_START_MOTOR 0x04 /* Send auto-start motor before request. */
 
1730 #define ASC_QC_NO_OVERRUN  0x08 /* Don't report overrun. */
 
1731 #define ASC_QC_FREEZE_TIDQ 0x10 /* Freeze TID queue after request. XXX TBD */
 
1733 #define ASC_QSC_NO_DISC     0x01        /* Don't allow disconnect for request. */
 
1734 #define ASC_QSC_NO_TAGMSG   0x02        /* Don't allow tag queuing for request. */
 
1735 #define ASC_QSC_NO_SYNC     0x04        /* Don't use Synch. transfer on request. */
 
1736 #define ASC_QSC_NO_WIDE     0x08        /* Don't use Wide transfer on request. */
 
1737 #define ASC_QSC_REDO_DTR    0x10        /* Renegotiate WDTR/SDTR before request. */
 
1739  * Note: If a Tag Message is to be sent and neither ASC_QSC_HEAD_TAG or
 
1740  * ASC_QSC_ORDERED_TAG is set, then a Simple Tag Message (0x20) is used.
 
1742 #define ASC_QSC_HEAD_TAG    0x40        /* Use Head Tag Message (0x21). */
 
1743 #define ASC_QSC_ORDERED_TAG 0x80        /* Use Ordered Tag Message (0x22). */
 
1746  * All fields here are accessed by the board microcode and need to be
 
1749 typedef struct adv_carr_t {
 
1750         ADV_VADDR carr_va;      /* Carrier Virtual Address */
 
1751         ADV_PADDR carr_pa;      /* Carrier Physical Address */
 
1752         ADV_VADDR areq_vpa;     /* ASC_SCSI_REQ_Q Virtual or Physical Address */
 
1754          * next_vpa [31:4]            Carrier Virtual or Physical Next Pointer
 
1756          * next_vpa [3:1]             Reserved Bits
 
1757          * next_vpa [0]               Done Flag set in Response Queue.
 
1763  * Mask used to eliminate low 4 bits of carrier 'next_vpa' field.
 
1765 #define ASC_NEXT_VPA_MASK       0xFFFFFFF0
 
1767 #define ASC_RQ_DONE             0x00000001
 
1768 #define ASC_RQ_GOOD             0x00000002
 
1769 #define ASC_CQ_STOPPER          0x00000000
 
1771 #define ASC_GET_CARRP(carrp) ((carrp) & ASC_NEXT_VPA_MASK)
 
1773 #define ADV_CARRIER_NUM_PAGE_CROSSING \
 
1774     (((ADV_CARRIER_COUNT * sizeof(ADV_CARR_T)) + (PAGE_SIZE - 1))/PAGE_SIZE)
 
1776 #define ADV_CARRIER_BUFSIZE \
 
1777     ((ADV_CARRIER_COUNT + ADV_CARRIER_NUM_PAGE_CROSSING) * sizeof(ADV_CARR_T))
 
1780  * ASC_SCSI_REQ_Q 'a_flag' definitions
 
1782  * The Adv Library should limit use to the lower nibble (4 bits) of
 
1783  * a_flag. Drivers are free to use the upper nibble (4 bits) of a_flag.
 
1785 #define ADV_POLL_REQUEST                0x01    /* poll for request completion */
 
1786 #define ADV_SCSIQ_DONE                  0x02    /* request done */
 
1787 #define ADV_DONT_RETRY                  0x08    /* don't do retry */
 
1789 #define ADV_CHIP_ASC3550          0x01  /* Ultra-Wide IC */
 
1790 #define ADV_CHIP_ASC38C0800       0x02  /* Ultra2-Wide/LVD IC */
 
1791 #define ADV_CHIP_ASC38C1600       0x03  /* Ultra3-Wide/LVD2 IC */
 
1794  * Adapter temporary configuration structure
 
1796  * This structure can be discarded after initialization. Don't add
 
1797  * fields here needed after initialization.
 
1799  * Field naming convention:
 
1801  *  *_enable indicates the field enables or disables a feature. The
 
1802  *  value of the field is never reset.
 
1804 typedef struct adv_dvc_cfg {
 
1805         ushort disc_enable;     /* enable disconnection */
 
1806         uchar chip_version;     /* chip version */
 
1807         uchar termination;      /* Term. Ctrl. bits 6-5 of SCSI_CFG1 register */
 
1808         ushort control_flag;    /* Microcode Control Flag */
 
1809         ushort mcode_date;      /* Microcode date */
 
1810         ushort mcode_version;   /* Microcode version */
 
1811         ushort serial1;         /* EEPROM serial number word 1 */
 
1812         ushort serial2;         /* EEPROM serial number word 2 */
 
1813         ushort serial3;         /* EEPROM serial number word 3 */
 
1817 struct adv_scsi_req_q;
 
1819 typedef struct asc_sg_block {
 
1823         uchar sg_cnt;           /* Valid entries in block. */
 
1824         ADV_PADDR sg_ptr;       /* Pointer to next sg block. */
 
1826                 ADV_PADDR sg_addr;      /* SG element address. */
 
1827                 ADV_DCNT sg_count;      /* SG element count. */
 
1828         } sg_list[NO_OF_SG_PER_BLOCK];
 
1832  * ADV_SCSI_REQ_Q - microcode request structure
 
1834  * All fields in this structure up to byte 60 are used by the microcode.
 
1835  * The microcode makes assumptions about the size and ordering of fields
 
1836  * in this structure. Do not change the structure definition here without
 
1837  * coordinating the change with the microcode.
 
1839  * All fields accessed by microcode must be maintained in little_endian
 
1842 typedef struct adv_scsi_req_q {
 
1843         uchar cntl;             /* Ucode flags and state (ASC_MC_QC_*). */
 
1845         uchar target_id;        /* Device target identifier. */
 
1846         uchar target_lun;       /* Device target logical unit number. */
 
1847         ADV_PADDR data_addr;    /* Data buffer physical address. */
 
1848         ADV_DCNT data_cnt;      /* Data count. Ucode sets to residual. */
 
1849         ADV_PADDR sense_addr;
 
1853         uchar cdb_len;          /* SCSI CDB length. Must <= 16 bytes. */
 
1855         uchar done_status;      /* Completion status. */
 
1856         uchar scsi_status;      /* SCSI status byte. */
 
1857         uchar host_status;      /* Ucode host status. */
 
1858         uchar sg_working_ix;
 
1859         uchar cdb[12];          /* SCSI CDB bytes 0-11. */
 
1860         ADV_PADDR sg_real_addr; /* SG list physical address. */
 
1861         ADV_PADDR scsiq_rptr;
 
1862         uchar cdb16[4];         /* SCSI CDB bytes 12-15. */
 
1863         ADV_VADDR scsiq_ptr;
 
1866          * End of microcode structure - 60 bytes. The rest of the structure
 
1867          * is used by the Adv Library and ignored by the microcode.
 
1870         ADV_SG_BLOCK *sg_list_ptr;      /* SG list virtual address. */
 
1871         char *vdata_addr;       /* Data buffer virtual address. */
 
1873         uchar pad[2];           /* Pad out to a word boundary. */
 
1877  * The following two structures are used to process Wide Board requests.
 
1879  * The ADV_SCSI_REQ_Q structure in adv_req_t is passed to the Adv Library
 
1880  * and microcode with the ADV_SCSI_REQ_Q field 'srb_ptr' pointing to the
 
1881  * adv_req_t. The adv_req_t structure 'cmndp' field in turn points to the
 
1882  * Mid-Level SCSI request structure.
 
1884  * Zero or more ADV_SG_BLOCK are used with each ADV_SCSI_REQ_Q. Each
 
1885  * ADV_SG_BLOCK structure holds 15 scatter-gather elements. Under Linux
 
1886  * up to 255 scatter-gather elements may be used per request or
 
1889  * Both structures must be 32 byte aligned.
 
1891 typedef struct adv_sgblk {
 
1892         ADV_SG_BLOCK sg_block;  /* Sgblock structure. */
 
1893         uchar align[32];        /* Sgblock structure padding. */
 
1894         struct adv_sgblk *next_sgblkp;  /* Next scatter-gather structure. */
 
1897 typedef struct adv_req {
 
1898         ADV_SCSI_REQ_Q scsi_req_q;      /* Adv Library request structure. */
 
1899         uchar align[32];        /* Request structure padding. */
 
1900         struct scsi_cmnd *cmndp;        /* Mid-Level SCSI command pointer. */
 
1901         adv_sgblk_t *sgblkp;    /* Adv Library scatter-gather pointer. */
 
1902         struct adv_req *next_reqp;      /* Next Request Structure. */
 
1906  * Adapter operation variable structure.
 
1908  * One structure is required per host adapter.
 
1910  * Field naming convention:
 
1912  *  *_able indicates both whether a feature should be enabled or disabled
 
1913  *  and whether a device isi capable of the feature. At initialization
 
1914  *  this field may be set, but later if a device is found to be incapable
 
1915  *  of the feature, the field is cleared.
 
1917 typedef struct adv_dvc_var {
 
1918         AdvPortAddr iop_base;   /* I/O port address */
 
1919         ushort err_code;        /* fatal error code */
 
1920         ushort bios_ctrl;       /* BIOS control word, EEPROM word 12 */
 
1921         ushort wdtr_able;       /* try WDTR for a device */
 
1922         ushort sdtr_able;       /* try SDTR for a device */
 
1923         ushort ultra_able;      /* try SDTR Ultra speed for a device */
 
1924         ushort sdtr_speed1;     /* EEPROM SDTR Speed for TID 0-3   */
 
1925         ushort sdtr_speed2;     /* EEPROM SDTR Speed for TID 4-7   */
 
1926         ushort sdtr_speed3;     /* EEPROM SDTR Speed for TID 8-11  */
 
1927         ushort sdtr_speed4;     /* EEPROM SDTR Speed for TID 12-15 */
 
1928         ushort tagqng_able;     /* try tagged queuing with a device */
 
1929         ushort ppr_able;        /* PPR message capable per TID bitmask. */
 
1930         uchar max_dvc_qng;      /* maximum number of tagged commands per device */
 
1931         ushort start_motor;     /* start motor command allowed */
 
1932         uchar scsi_reset_wait;  /* delay in seconds after scsi bus reset */
 
1933         uchar chip_no;          /* should be assigned by caller */
 
1934         uchar max_host_qng;     /* maximum number of Q'ed command allowed */
 
1935         ushort no_scam;         /* scam_tolerant of EEPROM */
 
1936         struct asc_board *drv_ptr;      /* driver pointer to private structure */
 
1937         uchar chip_scsi_id;     /* chip SCSI target ID */
 
1939         uchar bist_err_code;
 
1940         ADV_CARR_T *carrier_buf;
 
1941         ADV_CARR_T *carr_freelist;      /* Carrier free list. */
 
1942         ADV_CARR_T *icq_sp;     /* Initiator command queue stopper pointer. */
 
1943         ADV_CARR_T *irq_sp;     /* Initiator response queue stopper pointer. */
 
1944         ushort carr_pending_cnt;        /* Count of pending carriers. */
 
1945         struct adv_req *orig_reqp;      /* adv_req_t memory block. */
 
1947          * Note: The following fields will not be used after initialization. The
 
1948          * driver may discard the buffer after initialization is done.
 
1950         ADV_DVC_CFG *cfg;       /* temporary configuration structure  */
 
1954  * Microcode idle loop commands
 
1956 #define IDLE_CMD_COMPLETED           0
 
1957 #define IDLE_CMD_STOP_CHIP           0x0001
 
1958 #define IDLE_CMD_STOP_CHIP_SEND_INT  0x0002
 
1959 #define IDLE_CMD_SEND_INT            0x0004
 
1960 #define IDLE_CMD_ABORT               0x0008
 
1961 #define IDLE_CMD_DEVICE_RESET        0x0010
 
1962 #define IDLE_CMD_SCSI_RESET_START    0x0020     /* Assert SCSI Bus Reset */
 
1963 #define IDLE_CMD_SCSI_RESET_END      0x0040     /* Deassert SCSI Bus Reset */
 
1964 #define IDLE_CMD_SCSIREQ             0x0080
 
1966 #define IDLE_CMD_STATUS_SUCCESS      0x0001
 
1967 #define IDLE_CMD_STATUS_FAILURE      0x0002
 
1970  * AdvSendIdleCmd() flag definitions.
 
1972 #define ADV_NOWAIT     0x01
 
1975  * Wait loop time out values.
 
1977 #define SCSI_WAIT_100_MSEC           100UL      /* 100 milliseconds */
 
1978 #define SCSI_US_PER_MSEC             1000       /* microseconds per millisecond */
 
1979 #define SCSI_MAX_RETRY               10 /* retry count */
 
1981 #define ADV_ASYNC_RDMA_FAILURE          0x01    /* Fatal RDMA failure. */
 
1982 #define ADV_ASYNC_SCSI_BUS_RESET_DET    0x02    /* Detected SCSI Bus Reset. */
 
1983 #define ADV_ASYNC_CARRIER_READY_FAILURE 0x03    /* Carrier Ready failure. */
 
1984 #define ADV_RDMA_IN_CARR_AND_Q_INVALID  0x04    /* RDMAed-in data invalid. */
 
1986 #define ADV_HOST_SCSI_BUS_RESET      0x80       /* Host Initiated SCSI Bus Reset. */
 
1988 /* Read byte from a register. */
 
1989 #define AdvReadByteRegister(iop_base, reg_off) \
 
1990      (ADV_MEM_READB((iop_base) + (reg_off)))
 
1992 /* Write byte to a register. */
 
1993 #define AdvWriteByteRegister(iop_base, reg_off, byte) \
 
1994      (ADV_MEM_WRITEB((iop_base) + (reg_off), (byte)))
 
1996 /* Read word (2 bytes) from a register. */
 
1997 #define AdvReadWordRegister(iop_base, reg_off) \
 
1998      (ADV_MEM_READW((iop_base) + (reg_off)))
 
2000 /* Write word (2 bytes) to a register. */
 
2001 #define AdvWriteWordRegister(iop_base, reg_off, word) \
 
2002      (ADV_MEM_WRITEW((iop_base) + (reg_off), (word)))
 
2004 /* Write dword (4 bytes) to a register. */
 
2005 #define AdvWriteDWordRegister(iop_base, reg_off, dword) \
 
2006      (ADV_MEM_WRITEDW((iop_base) + (reg_off), (dword)))
 
2008 /* Read byte from LRAM. */
 
2009 #define AdvReadByteLram(iop_base, addr, byte) \
 
2011     ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr)); \
 
2012     (byte) = ADV_MEM_READB((iop_base) + IOPB_RAM_DATA); \
 
2015 /* Write byte to LRAM. */
 
2016 #define AdvWriteByteLram(iop_base, addr, byte) \
 
2017     (ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr)), \
 
2018      ADV_MEM_WRITEB((iop_base) + IOPB_RAM_DATA, (byte)))
 
2020 /* Read word (2 bytes) from LRAM. */
 
2021 #define AdvReadWordLram(iop_base, addr, word) \
 
2023     ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr)); \
 
2024     (word) = (ADV_MEM_READW((iop_base) + IOPW_RAM_DATA)); \
 
2027 /* Write word (2 bytes) to LRAM. */
 
2028 #define AdvWriteWordLram(iop_base, addr, word) \
 
2029     (ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr)), \
 
2030      ADV_MEM_WRITEW((iop_base) + IOPW_RAM_DATA, (word)))
 
2032 /* Write little-endian double word (4 bytes) to LRAM */
 
2033 /* Because of unspecified C language ordering don't use auto-increment. */
 
2034 #define AdvWriteDWordLramNoSwap(iop_base, addr, dword) \
 
2035     ((ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr)), \
 
2036       ADV_MEM_WRITEW((iop_base) + IOPW_RAM_DATA, \
 
2037                      cpu_to_le16((ushort) ((dword) & 0xFFFF)))), \
 
2038      (ADV_MEM_WRITEW((iop_base) + IOPW_RAM_ADDR, (addr) + 2), \
 
2039       ADV_MEM_WRITEW((iop_base) + IOPW_RAM_DATA, \
 
2040                      cpu_to_le16((ushort) ((dword >> 16) & 0xFFFF)))))
 
2042 /* Read word (2 bytes) from LRAM assuming that the address is already set. */
 
2043 #define AdvReadWordAutoIncLram(iop_base) \
 
2044      (ADV_MEM_READW((iop_base) + IOPW_RAM_DATA))
 
2046 /* Write word (2 bytes) to LRAM assuming that the address is already set. */
 
2047 #define AdvWriteWordAutoIncLram(iop_base, word) \
 
2048      (ADV_MEM_WRITEW((iop_base) + IOPW_RAM_DATA, (word)))
 
2051  * Define macro to check for Condor signature.
 
2053  * Evaluate to ADV_TRUE if a Condor chip is found the specified port
 
2054  * address 'iop_base'. Otherwise evalue to ADV_FALSE.
 
2056 #define AdvFindSignature(iop_base) \
 
2057     (((AdvReadByteRegister((iop_base), IOPB_CHIP_ID_1) == \
 
2058     ADV_CHIP_ID_BYTE) && \
 
2059      (AdvReadWordRegister((iop_base), IOPW_CHIP_ID_0) == \
 
2060     ADV_CHIP_ID_WORD)) ?  ADV_TRUE : ADV_FALSE)
 
2063  * Define macro to Return the version number of the chip at 'iop_base'.
 
2065  * The second parameter 'bus_type' is currently unused.
 
2067 #define AdvGetChipVersion(iop_base, bus_type) \
 
2068     AdvReadByteRegister((iop_base), IOPB_CHIP_TYPE_REV)
 
2071  * Abort an SRB in the chip's RISC Memory. The 'srb_ptr' argument must
 
2072  * match the ASC_SCSI_REQ_Q 'srb_ptr' field.
 
2074  * If the request has not yet been sent to the device it will simply be
 
2075  * aborted from RISC memory. If the request is disconnected it will be
 
2076  * aborted on reselection by sending an Abort Message to the target ID.
 
2079  *      ADV_TRUE(1) - Queue was successfully aborted.
 
2080  *      ADV_FALSE(0) - Queue was not found on the active queue list.
 
2082 #define AdvAbortQueue(asc_dvc, scsiq) \
 
2083         AdvSendIdleCmd((asc_dvc), (ushort) IDLE_CMD_ABORT, \
 
2087  * Send a Bus Device Reset Message to the specified target ID.
 
2089  * All outstanding commands will be purged if sending the
 
2090  * Bus Device Reset Message is successful.
 
2093  *      ADV_TRUE(1) - All requests on the target are purged.
 
2094  *      ADV_FALSE(0) - Couldn't issue Bus Device Reset Message; Requests
 
2097 #define AdvResetDevice(asc_dvc, target_id) \
 
2098         AdvSendIdleCmd((asc_dvc), (ushort) IDLE_CMD_DEVICE_RESET, \
 
2099                     (ADV_DCNT) (target_id))
 
2102  * SCSI Wide Type definition.
 
2104 #define ADV_SCSI_BIT_ID_TYPE   ushort
 
2107  * AdvInitScsiTarget() 'cntl_flag' options.
 
2109 #define ADV_SCAN_LUN           0x01
 
2110 #define ADV_CAPINFO_NOLUN      0x02
 
2113  * Convert target id to target id bit mask.
 
2115 #define ADV_TID_TO_TIDMASK(tid)   (0x01 << ((tid) & ADV_MAX_TID))
 
2118  * ASC_SCSI_REQ_Q 'done_status' and 'host_status' return values.
 
2121 #define QD_NO_STATUS         0x00       /* Request not completed yet. */
 
2122 #define QD_NO_ERROR          0x01
 
2123 #define QD_ABORTED_BY_HOST   0x02
 
2124 #define QD_WITH_ERROR        0x04
 
2126 #define QHSTA_NO_ERROR              0x00
 
2127 #define QHSTA_M_SEL_TIMEOUT         0x11
 
2128 #define QHSTA_M_DATA_OVER_RUN       0x12
 
2129 #define QHSTA_M_UNEXPECTED_BUS_FREE 0x13
 
2130 #define QHSTA_M_QUEUE_ABORTED       0x15
 
2131 #define QHSTA_M_SXFR_SDMA_ERR       0x16        /* SXFR_STATUS SCSI DMA Error */
 
2132 #define QHSTA_M_SXFR_SXFR_PERR      0x17        /* SXFR_STATUS SCSI Bus Parity Error */
 
2133 #define QHSTA_M_RDMA_PERR           0x18        /* RISC PCI DMA parity error */
 
2134 #define QHSTA_M_SXFR_OFF_UFLW       0x19        /* SXFR_STATUS Offset Underflow */
 
2135 #define QHSTA_M_SXFR_OFF_OFLW       0x20        /* SXFR_STATUS Offset Overflow */
 
2136 #define QHSTA_M_SXFR_WD_TMO         0x21        /* SXFR_STATUS Watchdog Timeout */
 
2137 #define QHSTA_M_SXFR_DESELECTED     0x22        /* SXFR_STATUS Deselected */
 
2138 /* Note: QHSTA_M_SXFR_XFR_OFLW is identical to QHSTA_M_DATA_OVER_RUN. */
 
2139 #define QHSTA_M_SXFR_XFR_OFLW       0x12        /* SXFR_STATUS Transfer Overflow */
 
2140 #define QHSTA_M_SXFR_XFR_PH_ERR     0x24        /* SXFR_STATUS Transfer Phase Error */
 
2141 #define QHSTA_M_SXFR_UNKNOWN_ERROR  0x25        /* SXFR_STATUS Unknown Error */
 
2142 #define QHSTA_M_SCSI_BUS_RESET      0x30        /* Request aborted from SBR */
 
2143 #define QHSTA_M_SCSI_BUS_RESET_UNSOL 0x31       /* Request aborted from unsol. SBR */
 
2144 #define QHSTA_M_BUS_DEVICE_RESET    0x32        /* Request aborted from BDR */
 
2145 #define QHSTA_M_DIRECTION_ERR       0x35        /* Data Phase mismatch */
 
2146 #define QHSTA_M_DIRECTION_ERR_HUNG  0x36        /* Data Phase mismatch and bus hang */
 
2147 #define QHSTA_M_WTM_TIMEOUT         0x41
 
2148 #define QHSTA_M_BAD_CMPL_STATUS_IN  0x42
 
2149 #define QHSTA_M_NO_AUTO_REQ_SENSE   0x43
 
2150 #define QHSTA_M_AUTO_REQ_SENSE_FAIL 0x44
 
2151 #define QHSTA_M_INVALID_DEVICE      0x45        /* Bad target ID */
 
2152 #define QHSTA_M_FROZEN_TIDQ         0x46        /* TID Queue frozen. */
 
2153 #define QHSTA_M_SGBACKUP_ERROR      0x47        /* Scatter-Gather backup error */
 
2155 /* Return the address that is aligned at the next doubleword >= to 'addr'. */
 
2156 #define ADV_8BALIGN(addr)      (((ulong) (addr) + 0x7) & ~0x7)
 
2157 #define ADV_16BALIGN(addr)     (((ulong) (addr) + 0xF) & ~0xF)
 
2158 #define ADV_32BALIGN(addr)     (((ulong) (addr) + 0x1F) & ~0x1F)
 
2161  * Total contiguous memory needed for driver SG blocks.
 
2163  * ADV_MAX_SG_LIST must be defined by a driver. It is the maximum
 
2164  * number of scatter-gather elements the driver supports in a
 
2168 #define ADV_SG_LIST_MAX_BYTE_SIZE \
 
2169          (sizeof(ADV_SG_BLOCK) * \
 
2170           ((ADV_MAX_SG_LIST + (NO_OF_SG_PER_BLOCK - 1))/NO_OF_SG_PER_BLOCK))
 
2172 /* struct asc_board flags */
 
2173 #define ASC_IS_WIDE_BOARD       0x04    /* AdvanSys Wide Board */
 
2175 #define ASC_NARROW_BOARD(boardp) (((boardp)->flags & ASC_IS_WIDE_BOARD) == 0)
 
2177 #define NO_ISA_DMA              0xff    /* No ISA DMA Channel Used */
 
2179 #define ASC_INFO_SIZE           128     /* advansys_info() line size */
 
2181 #ifdef CONFIG_PROC_FS
 
2182 /* /proc/scsi/advansys/[0...] related definitions */
 
2183 #define ASC_PRTBUF_SIZE         2048
 
2184 #define ASC_PRTLINE_SIZE        160
 
2186 #define ASC_PRT_NEXT() \
 
2190         if (leftlen == 0) { \
 
2195 #endif /* CONFIG_PROC_FS */
 
2197 /* Asc Library return codes */
 
2200 #define ASC_NOERROR     1
 
2202 #define ASC_ERROR       (-1)
 
2204 /* struct scsi_cmnd function return codes */
 
2205 #define STATUS_BYTE(byte)   (byte)
 
2206 #define MSG_BYTE(byte)      ((byte) << 8)
 
2207 #define HOST_BYTE(byte)     ((byte) << 16)
 
2208 #define DRIVER_BYTE(byte)   ((byte) << 24)
 
2210 #define ASC_STATS(shost, counter) ASC_STATS_ADD(shost, counter, 1)
 
2211 #ifndef ADVANSYS_STATS
 
2212 #define ASC_STATS_ADD(shost, counter, count)
 
2213 #else /* ADVANSYS_STATS */
 
2214 #define ASC_STATS_ADD(shost, counter, count) \
 
2215         (((struct asc_board *) shost_priv(shost))->asc_stats.counter += (count))
 
2216 #endif /* ADVANSYS_STATS */
 
2218 /* If the result wraps when calculating tenths, return 0. */
 
2219 #define ASC_TENTHS(num, den) \
 
2220     (((10 * ((num)/(den))) > (((num) * 10)/(den))) ? \
 
2221     0 : ((((num) * 10)/(den)) - (10 * ((num)/(den)))))
 
2224  * Display a message to the console.
 
2226 #define ASC_PRINT(s) \
 
2228         printk("advansys: "); \
 
2232 #define ASC_PRINT1(s, a1) \
 
2234         printk("advansys: "); \
 
2235         printk((s), (a1)); \
 
2238 #define ASC_PRINT2(s, a1, a2) \
 
2240         printk("advansys: "); \
 
2241         printk((s), (a1), (a2)); \
 
2244 #define ASC_PRINT3(s, a1, a2, a3) \
 
2246         printk("advansys: "); \
 
2247         printk((s), (a1), (a2), (a3)); \
 
2250 #define ASC_PRINT4(s, a1, a2, a3, a4) \
 
2252         printk("advansys: "); \
 
2253         printk((s), (a1), (a2), (a3), (a4)); \
 
2256 #ifndef ADVANSYS_DEBUG
 
2258 #define ASC_DBG(lvl, s...)
 
2259 #define ASC_DBG_PRT_SCSI_HOST(lvl, s)
 
2260 #define ASC_DBG_PRT_ASC_SCSI_Q(lvl, scsiqp)
 
2261 #define ASC_DBG_PRT_ADV_SCSI_REQ_Q(lvl, scsiqp)
 
2262 #define ASC_DBG_PRT_ASC_QDONE_INFO(lvl, qdone)
 
2263 #define ADV_DBG_PRT_ADV_SCSI_REQ_Q(lvl, scsiqp)
 
2264 #define ASC_DBG_PRT_HEX(lvl, name, start, length)
 
2265 #define ASC_DBG_PRT_CDB(lvl, cdb, len)
 
2266 #define ASC_DBG_PRT_SENSE(lvl, sense, len)
 
2267 #define ASC_DBG_PRT_INQUIRY(lvl, inq, len)
 
2269 #else /* ADVANSYS_DEBUG */
 
2272  * Debugging Message Levels:
 
2274  * 1: High-Level Tracing
 
2275  * 2-N: Verbose Tracing
 
2278 #define ASC_DBG(lvl, format, arg...) {                                  \
 
2279         if (asc_dbglvl >= (lvl))                                        \
 
2280                 printk(KERN_DEBUG "%s: %s: " format, DRV_NAME,          \
 
2281                         __FUNCTION__ , ## arg);                         \
 
2284 #define ASC_DBG_PRT_SCSI_HOST(lvl, s) \
 
2286         if (asc_dbglvl >= (lvl)) { \
 
2287             asc_prt_scsi_host(s); \
 
2291 #define ASC_DBG_PRT_ASC_SCSI_Q(lvl, scsiqp) \
 
2293         if (asc_dbglvl >= (lvl)) { \
 
2294             asc_prt_asc_scsi_q(scsiqp); \
 
2298 #define ASC_DBG_PRT_ASC_QDONE_INFO(lvl, qdone) \
 
2300         if (asc_dbglvl >= (lvl)) { \
 
2301             asc_prt_asc_qdone_info(qdone); \
 
2305 #define ASC_DBG_PRT_ADV_SCSI_REQ_Q(lvl, scsiqp) \
 
2307         if (asc_dbglvl >= (lvl)) { \
 
2308             asc_prt_adv_scsi_req_q(scsiqp); \
 
2312 #define ASC_DBG_PRT_HEX(lvl, name, start, length) \
 
2314         if (asc_dbglvl >= (lvl)) { \
 
2315             asc_prt_hex((name), (start), (length)); \
 
2319 #define ASC_DBG_PRT_CDB(lvl, cdb, len) \
 
2320         ASC_DBG_PRT_HEX((lvl), "CDB", (uchar *) (cdb), (len));
 
2322 #define ASC_DBG_PRT_SENSE(lvl, sense, len) \
 
2323         ASC_DBG_PRT_HEX((lvl), "SENSE", (uchar *) (sense), (len));
 
2325 #define ASC_DBG_PRT_INQUIRY(lvl, inq, len) \
 
2326         ASC_DBG_PRT_HEX((lvl), "INQUIRY", (uchar *) (inq), (len));
 
2327 #endif /* ADVANSYS_DEBUG */
 
2329 #ifdef ADVANSYS_STATS
 
2331 /* Per board statistics structure */
 
2333         /* Driver Entrypoint Statistics */
 
2334         ADV_DCNT queuecommand;  /* # calls to advansys_queuecommand() */
 
2335         ADV_DCNT reset;         /* # calls to advansys_eh_bus_reset() */
 
2336         ADV_DCNT biosparam;     /* # calls to advansys_biosparam() */
 
2337         ADV_DCNT interrupt;     /* # advansys_interrupt() calls */
 
2338         ADV_DCNT callback;      /* # calls to asc/adv_isr_callback() */
 
2339         ADV_DCNT done;          /* # calls to request's scsi_done function */
 
2340         ADV_DCNT build_error;   /* # asc/adv_build_req() ASC_ERROR returns. */
 
2341         ADV_DCNT adv_build_noreq;       /* # adv_build_req() adv_req_t alloc. fail. */
 
2342         ADV_DCNT adv_build_nosg;        /* # adv_build_req() adv_sgblk_t alloc. fail. */
 
2343         /* AscExeScsiQueue()/AdvExeScsiQueue() Statistics */
 
2344         ADV_DCNT exe_noerror;   /* # ASC_NOERROR returns. */
 
2345         ADV_DCNT exe_busy;      /* # ASC_BUSY returns. */
 
2346         ADV_DCNT exe_error;     /* # ASC_ERROR returns. */
 
2347         ADV_DCNT exe_unknown;   /* # unknown returns. */
 
2348         /* Data Transfer Statistics */
 
2349         ADV_DCNT xfer_cnt;      /* # I/O requests received */
 
2350         ADV_DCNT xfer_elem;     /* # scatter-gather elements */
 
2351         ADV_DCNT xfer_sect;     /* # 512-byte blocks */
 
2353 #endif /* ADVANSYS_STATS */
 
2356  * Structure allocated for each board.
 
2358  * This structure is allocated by scsi_host_alloc() at the end
 
2359  * of the 'Scsi_Host' structure starting at the 'hostdata'
 
2360  * field. It is guaranteed to be allocated from DMA-able memory.
 
2364         uint flags;             /* Board flags */
 
2367                 ASC_DVC_VAR asc_dvc_var;        /* Narrow board */
 
2368                 ADV_DVC_VAR adv_dvc_var;        /* Wide board */
 
2371                 ASC_DVC_CFG asc_dvc_cfg;        /* Narrow board */
 
2372                 ADV_DVC_CFG adv_dvc_cfg;        /* Wide board */
 
2374         ushort asc_n_io_port;   /* Number I/O ports. */
 
2375         ADV_SCSI_BIT_ID_TYPE init_tidmask;      /* Target init./valid mask */
 
2376         ushort reqcnt[ADV_MAX_TID + 1]; /* Starvation request count */
 
2377         ADV_SCSI_BIT_ID_TYPE queue_full;        /* Queue full mask */
 
2378         ushort queue_full_cnt[ADV_MAX_TID + 1]; /* Queue full count */
 
2380                 ASCEEP_CONFIG asc_eep;  /* Narrow EEPROM config. */
 
2381                 ADVEEP_3550_CONFIG adv_3550_eep;        /* 3550 EEPROM config. */
 
2382                 ADVEEP_38C0800_CONFIG adv_38C0800_eep;  /* 38C0800 EEPROM config. */
 
2383                 ADVEEP_38C1600_CONFIG adv_38C1600_eep;  /* 38C1600 EEPROM config. */
 
2385         ulong last_reset;       /* Saved last reset time */
 
2386         /* /proc/scsi/advansys/[0...] */
 
2387         char *prtbuf;           /* /proc print buffer */
 
2388 #ifdef ADVANSYS_STATS
 
2389         struct asc_stats asc_stats;     /* Board statistics */
 
2390 #endif                          /* ADVANSYS_STATS */
 
2392          * The following fields are used only for Narrow Boards.
 
2394         uchar sdtr_data[ASC_MAX_TID + 1];       /* SDTR information */
 
2396          * The following fields are used only for Wide Boards.
 
2398         void __iomem *ioremap_addr;     /* I/O Memory remap address. */
 
2399         ushort ioport;          /* I/O Port address. */
 
2400         adv_req_t *adv_reqp;    /* Request structures. */
 
2401         adv_sgblk_t *adv_sgblkp;        /* Scatter-gather structures. */
 
2402         ushort bios_signature;  /* BIOS Signature. */
 
2403         ushort bios_version;    /* BIOS Version. */
 
2404         ushort bios_codeseg;    /* BIOS Code Segment. */
 
2405         ushort bios_codelen;    /* BIOS Code Segment Length. */
 
2408 #define asc_dvc_to_board(asc_dvc) container_of(asc_dvc, struct asc_board, \
 
2409                                                         dvc_var.asc_dvc_var)
 
2410 #define adv_dvc_to_board(adv_dvc) container_of(adv_dvc, struct asc_board, \
 
2411                                                         dvc_var.adv_dvc_var)
 
2412 #define adv_dvc_to_pdev(adv_dvc) to_pci_dev(adv_dvc_to_board(adv_dvc)->dev)
 
2414 #ifdef ADVANSYS_DEBUG
 
2415 static int asc_dbglvl = 3;
 
2418  * asc_prt_asc_dvc_var()
 
2420 static void asc_prt_asc_dvc_var(ASC_DVC_VAR *h)
 
2422         printk("ASC_DVC_VAR at addr 0x%lx\n", (ulong)h);
 
2424         printk(" iop_base 0x%x, err_code 0x%x, dvc_cntl 0x%x, bug_fix_cntl "
 
2425                "%d,\n", h->iop_base, h->err_code, h->dvc_cntl, h->bug_fix_cntl);
 
2427         printk(" bus_type %d, init_sdtr 0x%x,\n", h->bus_type,
 
2428                 (unsigned)h->init_sdtr);
 
2430         printk(" sdtr_done 0x%x, use_tagged_qng 0x%x, unit_not_ready 0x%x, "
 
2431                "chip_no 0x%x,\n", (unsigned)h->sdtr_done,
 
2432                (unsigned)h->use_tagged_qng, (unsigned)h->unit_not_ready,
 
2433                (unsigned)h->chip_no);
 
2435         printk(" queue_full_or_busy 0x%x, start_motor 0x%x, scsi_reset_wait "
 
2436                "%u,\n", (unsigned)h->queue_full_or_busy,
 
2437                (unsigned)h->start_motor, (unsigned)h->scsi_reset_wait);
 
2439         printk(" is_in_int %u, max_total_qng %u, cur_total_qng %u, "
 
2440                "in_critical_cnt %u,\n", (unsigned)h->is_in_int,
 
2441                (unsigned)h->max_total_qng, (unsigned)h->cur_total_qng,
 
2442                (unsigned)h->in_critical_cnt);
 
2444         printk(" last_q_shortage %u, init_state 0x%x, no_scam 0x%x, "
 
2445                "pci_fix_asyn_xfer 0x%x,\n", (unsigned)h->last_q_shortage,
 
2446                (unsigned)h->init_state, (unsigned)h->no_scam,
 
2447                (unsigned)h->pci_fix_asyn_xfer);
 
2449         printk(" cfg 0x%lx\n", (ulong)h->cfg);
 
2453  * asc_prt_asc_dvc_cfg()
 
2455 static void asc_prt_asc_dvc_cfg(ASC_DVC_CFG *h)
 
2457         printk("ASC_DVC_CFG at addr 0x%lx\n", (ulong)h);
 
2459         printk(" can_tagged_qng 0x%x, cmd_qng_enabled 0x%x,\n",
 
2460                h->can_tagged_qng, h->cmd_qng_enabled);
 
2461         printk(" disc_enable 0x%x, sdtr_enable 0x%x,\n",
 
2462                h->disc_enable, h->sdtr_enable);
 
2464         printk(" chip_scsi_id %d, isa_dma_speed %d, isa_dma_channel %d, "
 
2465                 "chip_version %d,\n", h->chip_scsi_id, h->isa_dma_speed,
 
2466                 h->isa_dma_channel, h->chip_version);
 
2468         printk(" mcode_date 0x%x, mcode_version %d\n",
 
2469                 h->mcode_date, h->mcode_version);
 
2473  * asc_prt_adv_dvc_var()
 
2475  * Display an ADV_DVC_VAR structure.
 
2477 static void asc_prt_adv_dvc_var(ADV_DVC_VAR *h)
 
2479         printk(" ADV_DVC_VAR at addr 0x%lx\n", (ulong)h);
 
2481         printk("  iop_base 0x%lx, err_code 0x%x, ultra_able 0x%x\n",
 
2482                (ulong)h->iop_base, h->err_code, (unsigned)h->ultra_able);
 
2484         printk("  sdtr_able 0x%x, wdtr_able 0x%x\n",
 
2485                (unsigned)h->sdtr_able, (unsigned)h->wdtr_able);
 
2487         printk("  start_motor 0x%x, scsi_reset_wait 0x%x\n",
 
2488                (unsigned)h->start_motor, (unsigned)h->scsi_reset_wait);
 
2490         printk("  max_host_qng %u, max_dvc_qng %u, carr_freelist 0x%lxn\n",
 
2491                (unsigned)h->max_host_qng, (unsigned)h->max_dvc_qng,
 
2492                (ulong)h->carr_freelist);
 
2494         printk("  icq_sp 0x%lx, irq_sp 0x%lx\n",
 
2495                (ulong)h->icq_sp, (ulong)h->irq_sp);
 
2497         printk("  no_scam 0x%x, tagqng_able 0x%x\n",
 
2498                (unsigned)h->no_scam, (unsigned)h->tagqng_able);
 
2500         printk("  chip_scsi_id 0x%x, cfg 0x%lx\n",
 
2501                (unsigned)h->chip_scsi_id, (ulong)h->cfg);
 
2505  * asc_prt_adv_dvc_cfg()
 
2507  * Display an ADV_DVC_CFG structure.
 
2509 static void asc_prt_adv_dvc_cfg(ADV_DVC_CFG *h)
 
2511         printk(" ADV_DVC_CFG at addr 0x%lx\n", (ulong)h);
 
2513         printk("  disc_enable 0x%x, termination 0x%x\n",
 
2514                h->disc_enable, h->termination);
 
2516         printk("  chip_version 0x%x, mcode_date 0x%x\n",
 
2517                h->chip_version, h->mcode_date);
 
2519         printk("  mcode_version 0x%x, control_flag 0x%x\n",
 
2520                h->mcode_version, h->control_flag);
 
2524  * asc_prt_scsi_host()
 
2526 static void asc_prt_scsi_host(struct Scsi_Host *s)
 
2528         struct asc_board *boardp = shost_priv(s);
 
2530         printk("Scsi_Host at addr 0x%p, device %s\n", s, boardp->dev->bus_id);
 
2531         printk(" host_busy %u, host_no %d, last_reset %d,\n",
 
2532                s->host_busy, s->host_no, (unsigned)s->last_reset);
 
2534         printk(" base 0x%lx, io_port 0x%lx, irq %d,\n",
 
2535                (ulong)s->base, (ulong)s->io_port, boardp->irq);
 
2537         printk(" dma_channel %d, this_id %d, can_queue %d,\n",
 
2538                s->dma_channel, s->this_id, s->can_queue);
 
2540         printk(" cmd_per_lun %d, sg_tablesize %d, unchecked_isa_dma %d\n",
 
2541                s->cmd_per_lun, s->sg_tablesize, s->unchecked_isa_dma);
 
2543         if (ASC_NARROW_BOARD(boardp)) {
 
2544                 asc_prt_asc_dvc_var(&boardp->dvc_var.asc_dvc_var);
 
2545                 asc_prt_asc_dvc_cfg(&boardp->dvc_cfg.asc_dvc_cfg);
 
2547                 asc_prt_adv_dvc_var(&boardp->dvc_var.adv_dvc_var);
 
2548                 asc_prt_adv_dvc_cfg(&boardp->dvc_cfg.adv_dvc_cfg);
 
2555  * Print hexadecimal output in 4 byte groupings 32 bytes
 
2556  * or 8 double-words per line.
 
2558 static void asc_prt_hex(char *f, uchar *s, int l)
 
2565         printk("%s: (%d bytes)\n", f, l);
 
2567         for (i = 0; i < l; i += 32) {
 
2569                 /* Display a maximum of 8 double-words per line. */
 
2570                 if ((k = (l - i) / 4) >= 8) {
 
2577                 for (j = 0; j < k; j++) {
 
2578                         printk(" %2.2X%2.2X%2.2X%2.2X",
 
2579                                (unsigned)s[i + (j * 4)],
 
2580                                (unsigned)s[i + (j * 4) + 1],
 
2581                                (unsigned)s[i + (j * 4) + 2],
 
2582                                (unsigned)s[i + (j * 4) + 3]);
 
2590                         printk(" %2.2X", (unsigned)s[i + (j * 4)]);
 
2593                         printk(" %2.2X%2.2X",
 
2594                                (unsigned)s[i + (j * 4)],
 
2595                                (unsigned)s[i + (j * 4) + 1]);
 
2598                         printk(" %2.2X%2.2X%2.2X",
 
2599                                (unsigned)s[i + (j * 4) + 1],
 
2600                                (unsigned)s[i + (j * 4) + 2],
 
2601                                (unsigned)s[i + (j * 4) + 3]);
 
2610  * asc_prt_asc_scsi_q()
 
2612 static void asc_prt_asc_scsi_q(ASC_SCSI_Q *q)
 
2617         printk("ASC_SCSI_Q at addr 0x%lx\n", (ulong)q);
 
2620             (" target_ix 0x%x, target_lun %u, srb_ptr 0x%lx, tag_code 0x%x,\n",
 
2621              q->q2.target_ix, q->q1.target_lun, (ulong)q->q2.srb_ptr,
 
2625             (" data_addr 0x%lx, data_cnt %lu, sense_addr 0x%lx, sense_len %u,\n",
 
2626              (ulong)le32_to_cpu(q->q1.data_addr),
 
2627              (ulong)le32_to_cpu(q->q1.data_cnt),
 
2628              (ulong)le32_to_cpu(q->q1.sense_addr), q->q1.sense_len);
 
2630         printk(" cdbptr 0x%lx, cdb_len %u, sg_head 0x%lx, sg_queue_cnt %u\n",
 
2631                (ulong)q->cdbptr, q->q2.cdb_len,
 
2632                (ulong)q->sg_head, q->q1.sg_queue_cnt);
 
2636                 printk("ASC_SG_HEAD at addr 0x%lx\n", (ulong)sgp);
 
2637                 printk(" entry_cnt %u, queue_cnt %u\n", sgp->entry_cnt,
 
2639                 for (i = 0; i < sgp->entry_cnt; i++) {
 
2640                         printk(" [%u]: addr 0x%lx, bytes %lu\n",
 
2641                                i, (ulong)le32_to_cpu(sgp->sg_list[i].addr),
 
2642                                (ulong)le32_to_cpu(sgp->sg_list[i].bytes));
 
2649  * asc_prt_asc_qdone_info()
 
2651 static void asc_prt_asc_qdone_info(ASC_QDONE_INFO *q)
 
2653         printk("ASC_QDONE_INFO at addr 0x%lx\n", (ulong)q);
 
2654         printk(" srb_ptr 0x%lx, target_ix %u, cdb_len %u, tag_code %u,\n",
 
2655                (ulong)q->d2.srb_ptr, q->d2.target_ix, q->d2.cdb_len,
 
2658             (" done_stat 0x%x, host_stat 0x%x, scsi_stat 0x%x, scsi_msg 0x%x\n",
 
2659              q->d3.done_stat, q->d3.host_stat, q->d3.scsi_stat, q->d3.scsi_msg);
 
2663  * asc_prt_adv_sgblock()
 
2665  * Display an ADV_SG_BLOCK structure.
 
2667 static void asc_prt_adv_sgblock(int sgblockno, ADV_SG_BLOCK *b)
 
2671         printk(" ASC_SG_BLOCK at addr 0x%lx (sgblockno %d)\n",
 
2672                (ulong)b, sgblockno);
 
2673         printk("  sg_cnt %u, sg_ptr 0x%lx\n",
 
2674                b->sg_cnt, (ulong)le32_to_cpu(b->sg_ptr));
 
2675         BUG_ON(b->sg_cnt > NO_OF_SG_PER_BLOCK);
 
2677                 BUG_ON(b->sg_cnt != NO_OF_SG_PER_BLOCK);
 
2678         for (i = 0; i < b->sg_cnt; i++) {
 
2679                 printk("  [%u]: sg_addr 0x%lx, sg_count 0x%lx\n",
 
2680                        i, (ulong)b->sg_list[i].sg_addr,
 
2681                        (ulong)b->sg_list[i].sg_count);
 
2686  * asc_prt_adv_scsi_req_q()
 
2688  * Display an ADV_SCSI_REQ_Q structure.
 
2690 static void asc_prt_adv_scsi_req_q(ADV_SCSI_REQ_Q *q)
 
2693         struct asc_sg_block *sg_ptr;
 
2695         printk("ADV_SCSI_REQ_Q at addr 0x%lx\n", (ulong)q);
 
2697         printk("  target_id %u, target_lun %u, srb_ptr 0x%lx, a_flag 0x%x\n",
 
2698                q->target_id, q->target_lun, (ulong)q->srb_ptr, q->a_flag);
 
2700         printk("  cntl 0x%x, data_addr 0x%lx, vdata_addr 0x%lx\n",
 
2701                q->cntl, (ulong)le32_to_cpu(q->data_addr), (ulong)q->vdata_addr);
 
2703         printk("  data_cnt %lu, sense_addr 0x%lx, sense_len %u,\n",
 
2704                (ulong)le32_to_cpu(q->data_cnt),
 
2705                (ulong)le32_to_cpu(q->sense_addr), q->sense_len);
 
2708             ("  cdb_len %u, done_status 0x%x, host_status 0x%x, scsi_status 0x%x\n",
 
2709              q->cdb_len, q->done_status, q->host_status, q->scsi_status);
 
2711         printk("  sg_working_ix 0x%x, target_cmd %u\n",
 
2712                q->sg_working_ix, q->target_cmd);
 
2714         printk("  scsiq_rptr 0x%lx, sg_real_addr 0x%lx, sg_list_ptr 0x%lx\n",
 
2715                (ulong)le32_to_cpu(q->scsiq_rptr),
 
2716                (ulong)le32_to_cpu(q->sg_real_addr), (ulong)q->sg_list_ptr);
 
2718         /* Display the request's ADV_SG_BLOCK structures. */
 
2719         if (q->sg_list_ptr != NULL) {
 
2723                          * 'sg_ptr' is a physical address. Convert it to a virtual
 
2724                          * address by indexing 'sg_blk_cnt' into the virtual address
 
2725                          * array 'sg_list_ptr'.
 
2727                          * XXX - Assumes all SG physical blocks are virtually contiguous.
 
2730                             &(((ADV_SG_BLOCK *)(q->sg_list_ptr))[sg_blk_cnt]);
 
2731                         asc_prt_adv_sgblock(sg_blk_cnt, sg_ptr);
 
2732                         if (sg_ptr->sg_ptr == 0) {
 
2739 #endif /* ADVANSYS_DEBUG */
 
2742  * The advansys chip/microcode contains a 32-bit identifier for each command
 
2743  * known as the 'srb'.  I don't know what it stands for.  The driver used
 
2744  * to encode the scsi_cmnd pointer by calling virt_to_bus and retrieve it
 
2745  * with bus_to_virt.  Now the driver keeps a per-host map of integers to
 
2746  * pointers.  It auto-expands when full, unless it can't allocate memory.
 
2747  * Note that an srb of 0 is treated specially by the chip/firmware, hence
 
2748  * the return of i+1 in this routine, and the corresponding subtraction in
 
2749  * the inverse routine.
 
2752 static u32 advansys_ptr_to_srb(struct asc_dvc_var *asc_dvc, void *ptr)
 
2757         for (i = 0; i < asc_dvc->ptr_map_count; i++) {
 
2758                 if (!asc_dvc->ptr_map[i])
 
2762         if (asc_dvc->ptr_map_count == 0)
 
2763                 asc_dvc->ptr_map_count = 1;
 
2765                 asc_dvc->ptr_map_count *= 2;
 
2767         new_ptr = krealloc(asc_dvc->ptr_map,
 
2768                         asc_dvc->ptr_map_count * sizeof(void *), GFP_ATOMIC);
 
2771         asc_dvc->ptr_map = new_ptr;
 
2773         ASC_DBG(3, "Putting ptr %p into array offset %d\n", ptr, i);
 
2774         asc_dvc->ptr_map[i] = ptr;
 
2778 static void * advansys_srb_to_ptr(struct asc_dvc_var *asc_dvc, u32 srb)
 
2783         if (srb >= asc_dvc->ptr_map_count) {
 
2784                 printk("advansys: bad SRB %u, max %u\n", srb,
 
2785                                                         asc_dvc->ptr_map_count);
 
2788         ptr = asc_dvc->ptr_map[srb];
 
2789         asc_dvc->ptr_map[srb] = NULL;
 
2790         ASC_DBG(3, "Returning ptr %p from array offset %d\n", ptr, srb);
 
2797  * Return suitable for printing on the console with the argument
 
2798  * adapter's configuration information.
 
2800  * Note: The information line should not exceed ASC_INFO_SIZE bytes,
 
2801  * otherwise the static 'info' array will be overrun.
 
2803 static const char *advansys_info(struct Scsi_Host *shost)
 
2805         static char info[ASC_INFO_SIZE];
 
2806         struct asc_board *boardp = shost_priv(shost);
 
2807         ASC_DVC_VAR *asc_dvc_varp;
 
2808         ADV_DVC_VAR *adv_dvc_varp;
 
2810         char *widename = NULL;
 
2812         if (ASC_NARROW_BOARD(boardp)) {
 
2813                 asc_dvc_varp = &boardp->dvc_var.asc_dvc_var;
 
2814                 ASC_DBG(1, "begin\n");
 
2815                 if (asc_dvc_varp->bus_type & ASC_IS_ISA) {
 
2816                         if ((asc_dvc_varp->bus_type & ASC_IS_ISAPNP) ==
 
2818                                 busname = "ISA PnP";
 
2823                                 "AdvanSys SCSI %s: %s: IO 0x%lX-0x%lX, IRQ 0x%X, DMA 0x%X",
 
2824                                 ASC_VERSION, busname,
 
2825                                 (ulong)shost->io_port,
 
2826                                 (ulong)shost->io_port + ASC_IOADR_GAP - 1,
 
2827                                 boardp->irq, shost->dma_channel);
 
2829                         if (asc_dvc_varp->bus_type & ASC_IS_VL) {
 
2831                         } else if (asc_dvc_varp->bus_type & ASC_IS_EISA) {
 
2833                         } else if (asc_dvc_varp->bus_type & ASC_IS_PCI) {
 
2834                                 if ((asc_dvc_varp->bus_type & ASC_IS_PCI_ULTRA)
 
2835                                     == ASC_IS_PCI_ULTRA) {
 
2836                                         busname = "PCI Ultra";
 
2842                                 shost_printk(KERN_ERR, shost, "unknown bus "
 
2843                                         "type %d\n", asc_dvc_varp->bus_type);
 
2846                                 "AdvanSys SCSI %s: %s: IO 0x%lX-0x%lX, IRQ 0x%X",
 
2847                                 ASC_VERSION, busname, (ulong)shost->io_port,
 
2848                                 (ulong)shost->io_port + ASC_IOADR_GAP - 1,
 
2853                  * Wide Adapter Information
 
2855                  * Memory-mapped I/O is used instead of I/O space to access
 
2856                  * the adapter, but display the I/O Port range. The Memory
 
2857                  * I/O address is displayed through the driver /proc file.
 
2859                 adv_dvc_varp = &boardp->dvc_var.adv_dvc_var;
 
2860                 if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
2861                         widename = "Ultra-Wide";
 
2862                 } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
2863                         widename = "Ultra2-Wide";
 
2865                         widename = "Ultra3-Wide";
 
2868                         "AdvanSys SCSI %s: PCI %s: PCIMEM 0x%lX-0x%lX, IRQ 0x%X",
 
2869                         ASC_VERSION, widename, (ulong)adv_dvc_varp->iop_base,
 
2870                         (ulong)adv_dvc_varp->iop_base + boardp->asc_n_io_port - 1, boardp->irq);
 
2872         BUG_ON(strlen(info) >= ASC_INFO_SIZE);
 
2873         ASC_DBG(1, "end\n");
 
2877 #ifdef CONFIG_PROC_FS
 
2881  * If 'cp' is NULL print to the console, otherwise print to a buffer.
 
2883  * Return 0 if printing to the console, otherwise return the number of
 
2884  * bytes written to the buffer.
 
2886  * Note: If any single line is greater than ASC_PRTLINE_SIZE bytes the stack
 
2887  * will be corrupted. 's[]' is defined to be ASC_PRTLINE_SIZE bytes.
 
2889 static int asc_prt_line(char *buf, int buflen, char *fmt, ...)
 
2893         char s[ASC_PRTLINE_SIZE];
 
2895         va_start(args, fmt);
 
2896         ret = vsprintf(s, fmt, args);
 
2897         BUG_ON(ret >= ASC_PRTLINE_SIZE);
 
2902                 ret = min(buflen, ret);
 
2903                 memcpy(buf, s, ret);
 
2910  * asc_prt_board_devices()
 
2912  * Print driver information for devices attached to the board.
 
2914  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
2915  * cf. asc_prt_line().
 
2917  * Return the number of characters copied into 'cp'. No more than
 
2918  * 'cplen' characters will be copied to 'cp'.
 
2920 static int asc_prt_board_devices(struct Scsi_Host *shost, char *cp, int cplen)
 
2922         struct asc_board *boardp = shost_priv(shost);
 
2932         len = asc_prt_line(cp, leftlen,
 
2933                            "\nDevice Information for AdvanSys SCSI Host %d:\n",
 
2937         if (ASC_NARROW_BOARD(boardp)) {
 
2938                 chip_scsi_id = boardp->dvc_cfg.asc_dvc_cfg.chip_scsi_id;
 
2940                 chip_scsi_id = boardp->dvc_var.adv_dvc_var.chip_scsi_id;
 
2943         len = asc_prt_line(cp, leftlen, "Target IDs Detected:");
 
2945         for (i = 0; i <= ADV_MAX_TID; i++) {
 
2946                 if (boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) {
 
2947                         len = asc_prt_line(cp, leftlen, " %X,", i);
 
2951         len = asc_prt_line(cp, leftlen, " (%X=Host Adapter)\n", chip_scsi_id);
 
2958  * Display Wide Board BIOS Information.
 
2960 static int asc_prt_adv_bios(struct Scsi_Host *shost, char *cp, int cplen)
 
2962         struct asc_board *boardp = shost_priv(shost);
 
2966         ushort major, minor, letter;
 
2971         len = asc_prt_line(cp, leftlen, "\nROM BIOS Version: ");
 
2975          * If the BIOS saved a valid signature, then fill in
 
2976          * the BIOS code segment base address.
 
2978         if (boardp->bios_signature != 0x55AA) {
 
2979                 len = asc_prt_line(cp, leftlen, "Disabled or Pre-3.1\n");
 
2981                 len = asc_prt_line(cp, leftlen,
 
2982                                    "BIOS either disabled or Pre-3.1. If it is pre-3.1, then a newer version\n");
 
2984                 len = asc_prt_line(cp, leftlen,
 
2985                                    "can be found at the ConnectCom FTP site: ftp://ftp.connectcom.net/pub\n");
 
2988                 major = (boardp->bios_version >> 12) & 0xF;
 
2989                 minor = (boardp->bios_version >> 8) & 0xF;
 
2990                 letter = (boardp->bios_version & 0xFF);
 
2992                 len = asc_prt_line(cp, leftlen, "%d.%d%c\n",
 
2994                                    letter >= 26 ? '?' : letter + 'A');
 
2998                  * Current available ROM BIOS release is 3.1I for UW
 
2999                  * and 3.2I for U2W. This code doesn't differentiate
 
3000                  * UW and U2W boards.
 
3002                 if (major < 3 || (major <= 3 && minor < 1) ||
 
3003                     (major <= 3 && minor <= 1 && letter < ('I' - 'A'))) {
 
3004                         len = asc_prt_line(cp, leftlen,
 
3005                                            "Newer version of ROM BIOS is available at the ConnectCom FTP site:\n");
 
3007                         len = asc_prt_line(cp, leftlen,
 
3008                                            "ftp://ftp.connectcom.net/pub\n");
 
3017  * Add serial number to information bar if signature AAh
 
3018  * is found in at bit 15-9 (7 bits) of word 1.
 
3020  * Serial Number consists fo 12 alpha-numeric digits.
 
3022  *       1 - Product type (A,B,C,D..)  Word0: 15-13 (3 bits)
 
3023  *       2 - MFG Location (A,B,C,D..)  Word0: 12-10 (3 bits)
 
3024  *     3-4 - Product ID (0-99)         Word0: 9-0 (10 bits)
 
3025  *       5 - Product revision (A-J)    Word0:  "         "
 
3027  *           Signature                 Word1: 15-9 (7 bits)
 
3028  *       6 - Year (0-9)                Word1: 8-6 (3 bits) & Word2: 15 (1 bit)
 
3029  *     7-8 - Week of the year (1-52)   Word1: 5-0 (6 bits)
 
3031  *    9-12 - Serial Number (A001-Z999) Word2: 14-0 (15 bits)
 
3033  * Note 1: Only production cards will have a serial number.
 
3035  * Note 2: Signature is most significant 7 bits (0xFE).
 
3037  * Returns ASC_TRUE if serial number found, otherwise returns ASC_FALSE.
 
3039 static int asc_get_eeprom_string(ushort *serialnum, uchar *cp)
 
3043         if ((serialnum[1] & 0xFE00) != ((ushort)0xAA << 8)) {
 
3047                  * First word - 6 digits.
 
3051                 /* Product type - 1st digit. */
 
3052                 if ((*cp = 'A' + ((w & 0xE000) >> 13)) == 'H') {
 
3053                         /* Product type is P=Prototype */
 
3058                 /* Manufacturing location - 2nd digit. */
 
3059                 *cp++ = 'A' + ((w & 0x1C00) >> 10);
 
3061                 /* Product ID - 3rd, 4th digits. */
 
3063                 *cp++ = '0' + (num / 100);
 
3065                 *cp++ = '0' + (num / 10);
 
3067                 /* Product revision - 5th digit. */
 
3068                 *cp++ = 'A' + (num % 10);
 
3078                  * If bit 15 of third word is set, then the
 
3079                  * last digit of the year is greater than 7.
 
3081                 if (serialnum[2] & 0x8000) {
 
3082                         *cp++ = '8' + ((w & 0x1C0) >> 6);
 
3084                         *cp++ = '0' + ((w & 0x1C0) >> 6);
 
3087                 /* Week of year - 7th, 8th digits. */
 
3089                 *cp++ = '0' + num / 10;
 
3096                 w = serialnum[2] & 0x7FFF;
 
3098                 /* Serial number - 9th digit. */
 
3099                 *cp++ = 'A' + (w / 1000);
 
3101                 /* 10th, 11th, 12th digits. */
 
3103                 *cp++ = '0' + num / 100;
 
3105                 *cp++ = '0' + num / 10;
 
3109                 *cp = '\0';     /* Null Terminate the string. */
 
3115  * asc_prt_asc_board_eeprom()
 
3117  * Print board EEPROM configuration.
 
3119  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
3120  * cf. asc_prt_line().
 
3122  * Return the number of characters copied into 'cp'. No more than
 
3123  * 'cplen' characters will be copied to 'cp'.
 
3125 static int asc_prt_asc_board_eeprom(struct Scsi_Host *shost, char *cp, int cplen)
 
3127         struct asc_board *boardp = shost_priv(shost);
 
3128         ASC_DVC_VAR *asc_dvc_varp;
 
3135         int isa_dma_speed[] = { 10, 8, 7, 6, 5, 4, 3, 2 };
 
3136 #endif /* CONFIG_ISA */
 
3137         uchar serialstr[13];
 
3139         asc_dvc_varp = &boardp->dvc_var.asc_dvc_var;
 
3140         ep = &boardp->eep_config.asc_eep;
 
3145         len = asc_prt_line(cp, leftlen,
 
3146                            "\nEEPROM Settings for AdvanSys SCSI Host %d:\n",
 
3150         if (asc_get_eeprom_string((ushort *)&ep->adapter_info[0], serialstr)
 
3153                     asc_prt_line(cp, leftlen, " Serial Number: %s\n",
 
3157                 if (ep->adapter_info[5] == 0xBB) {
 
3158                         len = asc_prt_line(cp, leftlen,
 
3159                                            " Default Settings Used for EEPROM-less Adapter.\n");
 
3162                         len = asc_prt_line(cp, leftlen,
 
3163                                            " Serial Number Signature Not Present.\n");
 
3168         len = asc_prt_line(cp, leftlen,
 
3169                            " Host SCSI ID: %u, Host Queue Size: %u, Device Queue Size: %u\n",
 
3170                            ASC_EEP_GET_CHIP_ID(ep), ep->max_total_qng,
 
3174         len = asc_prt_line(cp, leftlen,
 
3175                            " cntl 0x%x, no_scam 0x%x\n", ep->cntl, ep->no_scam);
 
3178         len = asc_prt_line(cp, leftlen, " Target ID:           ");
 
3180         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3181                 len = asc_prt_line(cp, leftlen, " %d", i);
 
3184         len = asc_prt_line(cp, leftlen, "\n");
 
3187         len = asc_prt_line(cp, leftlen, " Disconnects:         ");
 
3189         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3190                 len = asc_prt_line(cp, leftlen, " %c",
 
3192                                     disc_enable & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3196         len = asc_prt_line(cp, leftlen, "\n");
 
3199         len = asc_prt_line(cp, leftlen, " Command Queuing:     ");
 
3201         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3202                 len = asc_prt_line(cp, leftlen, " %c",
 
3204                                     use_cmd_qng & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3208         len = asc_prt_line(cp, leftlen, "\n");
 
3211         len = asc_prt_line(cp, leftlen, " Start Motor:         ");
 
3213         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3214                 len = asc_prt_line(cp, leftlen, " %c",
 
3216                                     start_motor & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3220         len = asc_prt_line(cp, leftlen, "\n");
 
3223         len = asc_prt_line(cp, leftlen, " Synchronous Transfer:");
 
3225         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3226                 len = asc_prt_line(cp, leftlen, " %c",
 
3228                                     init_sdtr & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3232         len = asc_prt_line(cp, leftlen, "\n");
 
3236         if (asc_dvc_varp->bus_type & ASC_IS_ISA) {
 
3237                 len = asc_prt_line(cp, leftlen,
 
3238                                    " Host ISA DMA speed:   %d MB/S\n",
 
3239                                    isa_dma_speed[ASC_EEP_GET_DMA_SPD(ep)]);
 
3242 #endif /* CONFIG_ISA */
 
3248  * asc_prt_adv_board_eeprom()
 
3250  * Print board EEPROM configuration.
 
3252  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
3253  * cf. asc_prt_line().
 
3255  * Return the number of characters copied into 'cp'. No more than
 
3256  * 'cplen' characters will be copied to 'cp'.
 
3258 static int asc_prt_adv_board_eeprom(struct Scsi_Host *shost, char *cp, int cplen)
 
3260         struct asc_board *boardp = shost_priv(shost);
 
3261         ADV_DVC_VAR *adv_dvc_varp;
 
3267         uchar serialstr[13];
 
3268         ADVEEP_3550_CONFIG *ep_3550 = NULL;
 
3269         ADVEEP_38C0800_CONFIG *ep_38C0800 = NULL;
 
3270         ADVEEP_38C1600_CONFIG *ep_38C1600 = NULL;
 
3273         ushort sdtr_speed = 0;
 
3275         adv_dvc_varp = &boardp->dvc_var.adv_dvc_var;
 
3276         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3277                 ep_3550 = &boardp->eep_config.adv_3550_eep;
 
3278         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3279                 ep_38C0800 = &boardp->eep_config.adv_38C0800_eep;
 
3281                 ep_38C1600 = &boardp->eep_config.adv_38C1600_eep;
 
3287         len = asc_prt_line(cp, leftlen,
 
3288                            "\nEEPROM Settings for AdvanSys SCSI Host %d:\n",
 
3292         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3293                 wordp = &ep_3550->serial_number_word1;
 
3294         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3295                 wordp = &ep_38C0800->serial_number_word1;
 
3297                 wordp = &ep_38C1600->serial_number_word1;
 
3300         if (asc_get_eeprom_string(wordp, serialstr) == ASC_TRUE) {
 
3302                     asc_prt_line(cp, leftlen, " Serial Number: %s\n",
 
3306                 len = asc_prt_line(cp, leftlen,
 
3307                                    " Serial Number Signature Not Present.\n");
 
3311         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3312                 len = asc_prt_line(cp, leftlen,
 
3313                                    " Host SCSI ID: %u, Host Queue Size: %u, Device Queue Size: %u\n",
 
3314                                    ep_3550->adapter_scsi_id,
 
3315                                    ep_3550->max_host_qng, ep_3550->max_dvc_qng);
 
3317         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3318                 len = asc_prt_line(cp, leftlen,
 
3319                                    " Host SCSI ID: %u, Host Queue Size: %u, Device Queue Size: %u\n",
 
3320                                    ep_38C0800->adapter_scsi_id,
 
3321                                    ep_38C0800->max_host_qng,
 
3322                                    ep_38C0800->max_dvc_qng);
 
3325                 len = asc_prt_line(cp, leftlen,
 
3326                                    " Host SCSI ID: %u, Host Queue Size: %u, Device Queue Size: %u\n",
 
3327                                    ep_38C1600->adapter_scsi_id,
 
3328                                    ep_38C1600->max_host_qng,
 
3329                                    ep_38C1600->max_dvc_qng);
 
3332         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3333                 word = ep_3550->termination;
 
3334         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3335                 word = ep_38C0800->termination_lvd;
 
3337                 word = ep_38C1600->termination_lvd;
 
3341                 termstr = "Low Off/High Off";
 
3344                 termstr = "Low Off/High On";
 
3347                 termstr = "Low On/High On";
 
3351                 termstr = "Automatic";
 
3355         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3356                 len = asc_prt_line(cp, leftlen,
 
3357                                    " termination: %u (%s), bios_ctrl: 0x%x\n",
 
3358                                    ep_3550->termination, termstr,
 
3359                                    ep_3550->bios_ctrl);
 
3361         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3362                 len = asc_prt_line(cp, leftlen,
 
3363                                    " termination: %u (%s), bios_ctrl: 0x%x\n",
 
3364                                    ep_38C0800->termination_lvd, termstr,
 
3365                                    ep_38C0800->bios_ctrl);
 
3368                 len = asc_prt_line(cp, leftlen,
 
3369                                    " termination: %u (%s), bios_ctrl: 0x%x\n",
 
3370                                    ep_38C1600->termination_lvd, termstr,
 
3371                                    ep_38C1600->bios_ctrl);
 
3375         len = asc_prt_line(cp, leftlen, " Target ID:           ");
 
3377         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3378                 len = asc_prt_line(cp, leftlen, " %X", i);
 
3381         len = asc_prt_line(cp, leftlen, "\n");
 
3384         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3385                 word = ep_3550->disc_enable;
 
3386         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3387                 word = ep_38C0800->disc_enable;
 
3389                 word = ep_38C1600->disc_enable;
 
3391         len = asc_prt_line(cp, leftlen, " Disconnects:         ");
 
3393         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3394                 len = asc_prt_line(cp, leftlen, " %c",
 
3395                                    (word & ADV_TID_TO_TIDMASK(i)) ? 'Y' : 'N');
 
3398         len = asc_prt_line(cp, leftlen, "\n");
 
3401         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3402                 word = ep_3550->tagqng_able;
 
3403         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3404                 word = ep_38C0800->tagqng_able;
 
3406                 word = ep_38C1600->tagqng_able;
 
3408         len = asc_prt_line(cp, leftlen, " Command Queuing:     ");
 
3410         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3411                 len = asc_prt_line(cp, leftlen, " %c",
 
3412                                    (word & ADV_TID_TO_TIDMASK(i)) ? 'Y' : 'N');
 
3415         len = asc_prt_line(cp, leftlen, "\n");
 
3418         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3419                 word = ep_3550->start_motor;
 
3420         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3421                 word = ep_38C0800->start_motor;
 
3423                 word = ep_38C1600->start_motor;
 
3425         len = asc_prt_line(cp, leftlen, " Start Motor:         ");
 
3427         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3428                 len = asc_prt_line(cp, leftlen, " %c",
 
3429                                    (word & ADV_TID_TO_TIDMASK(i)) ? 'Y' : 'N');
 
3432         len = asc_prt_line(cp, leftlen, "\n");
 
3435         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3436                 len = asc_prt_line(cp, leftlen, " Synchronous Transfer:");
 
3438                 for (i = 0; i <= ADV_MAX_TID; i++) {
 
3439                         len = asc_prt_line(cp, leftlen, " %c",
 
3441                                             sdtr_able & ADV_TID_TO_TIDMASK(i)) ?
 
3445                 len = asc_prt_line(cp, leftlen, "\n");
 
3449         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3450                 len = asc_prt_line(cp, leftlen, " Ultra Transfer:      ");
 
3452                 for (i = 0; i <= ADV_MAX_TID; i++) {
 
3453                         len = asc_prt_line(cp, leftlen, " %c",
 
3455                                             ultra_able & ADV_TID_TO_TIDMASK(i))
 
3459                 len = asc_prt_line(cp, leftlen, "\n");
 
3463         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
3464                 word = ep_3550->wdtr_able;
 
3465         } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
3466                 word = ep_38C0800->wdtr_able;
 
3468                 word = ep_38C1600->wdtr_able;
 
3470         len = asc_prt_line(cp, leftlen, " Wide Transfer:       ");
 
3472         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3473                 len = asc_prt_line(cp, leftlen, " %c",
 
3474                                    (word & ADV_TID_TO_TIDMASK(i)) ? 'Y' : 'N');
 
3477         len = asc_prt_line(cp, leftlen, "\n");
 
3480         if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800 ||
 
3481             adv_dvc_varp->chip_type == ADV_CHIP_ASC38C1600) {
 
3482                 len = asc_prt_line(cp, leftlen,
 
3483                                    " Synchronous Transfer Speed (Mhz):\n  ");
 
3485                 for (i = 0; i <= ADV_MAX_TID; i++) {
 
3489                                 sdtr_speed = adv_dvc_varp->sdtr_speed1;
 
3490                         } else if (i == 4) {
 
3491                                 sdtr_speed = adv_dvc_varp->sdtr_speed2;
 
3492                         } else if (i == 8) {
 
3493                                 sdtr_speed = adv_dvc_varp->sdtr_speed3;
 
3494                         } else if (i == 12) {
 
3495                                 sdtr_speed = adv_dvc_varp->sdtr_speed4;
 
3497                         switch (sdtr_speed & ADV_MAX_TID) {
 
3520                         len = asc_prt_line(cp, leftlen, "%X:%s ", i, speed_str);
 
3523                                 len = asc_prt_line(cp, leftlen, "\n  ");
 
3528                 len = asc_prt_line(cp, leftlen, "\n");
 
3536  * asc_prt_driver_conf()
 
3538  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
3539  * cf. asc_prt_line().
 
3541  * Return the number of characters copied into 'cp'. No more than
 
3542  * 'cplen' characters will be copied to 'cp'.
 
3544 static int asc_prt_driver_conf(struct Scsi_Host *shost, char *cp, int cplen)
 
3546         struct asc_board *boardp = shost_priv(shost);
 
3555         len = asc_prt_line(cp, leftlen,
 
3556                            "\nLinux Driver Configuration and Information for AdvanSys SCSI Host %d:\n",
 
3560         len = asc_prt_line(cp, leftlen,
 
3561                            " host_busy %u, last_reset %u, max_id %u, max_lun %u, max_channel %u\n",
 
3562                            shost->host_busy, shost->last_reset, shost->max_id,
 
3563                            shost->max_lun, shost->max_channel);
 
3566         len = asc_prt_line(cp, leftlen,
 
3567                            " unique_id %d, can_queue %d, this_id %d, sg_tablesize %u, cmd_per_lun %u\n",
 
3568                            shost->unique_id, shost->can_queue, shost->this_id,
 
3569                            shost->sg_tablesize, shost->cmd_per_lun);
 
3572         len = asc_prt_line(cp, leftlen,
 
3573                            " unchecked_isa_dma %d, use_clustering %d\n",
 
3574                            shost->unchecked_isa_dma, shost->use_clustering);
 
3577         len = asc_prt_line(cp, leftlen,
 
3578                            " flags 0x%x, last_reset 0x%x, jiffies 0x%x, asc_n_io_port 0x%x\n",
 
3579                            boardp->flags, boardp->last_reset, jiffies,
 
3580                            boardp->asc_n_io_port);
 
3583         len = asc_prt_line(cp, leftlen, " io_port 0x%x\n", shost->io_port);
 
3586         if (ASC_NARROW_BOARD(boardp)) {
 
3587                 chip_scsi_id = boardp->dvc_cfg.asc_dvc_cfg.chip_scsi_id;
 
3589                 chip_scsi_id = boardp->dvc_var.adv_dvc_var.chip_scsi_id;
 
3596  * asc_prt_asc_board_info()
 
3598  * Print dynamic board configuration information.
 
3600  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
3601  * cf. asc_prt_line().
 
3603  * Return the number of characters copied into 'cp'. No more than
 
3604  * 'cplen' characters will be copied to 'cp'.
 
3606 static int asc_prt_asc_board_info(struct Scsi_Host *shost, char *cp, int cplen)
 
3608         struct asc_board *boardp = shost_priv(shost);
 
3616         int renegotiate = 0;
 
3618         v = &boardp->dvc_var.asc_dvc_var;
 
3619         c = &boardp->dvc_cfg.asc_dvc_cfg;
 
3620         chip_scsi_id = c->chip_scsi_id;
 
3625         len = asc_prt_line(cp, leftlen,
 
3626                            "\nAsc Library Configuration and Statistics for AdvanSys SCSI Host %d:\n",
 
3630         len = asc_prt_line(cp, leftlen, " chip_version %u, mcode_date 0x%x, "
 
3631                            "mcode_version 0x%x, err_code %u\n",
 
3632                            c->chip_version, c->mcode_date, c->mcode_version,
 
3636         /* Current number of commands waiting for the host. */
 
3637         len = asc_prt_line(cp, leftlen,
 
3638                            " Total Command Pending: %d\n", v->cur_total_qng);
 
3641         len = asc_prt_line(cp, leftlen, " Command Queuing:");
 
3643         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3644                 if ((chip_scsi_id == i) ||
 
3645                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3648                 len = asc_prt_line(cp, leftlen, " %X:%c",
 
3651                                     use_tagged_qng & ADV_TID_TO_TIDMASK(i)) ?
 
3655         len = asc_prt_line(cp, leftlen, "\n");
 
3658         /* Current number of commands waiting for a device. */
 
3659         len = asc_prt_line(cp, leftlen, " Command Queue Pending:");
 
3661         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3662                 if ((chip_scsi_id == i) ||
 
3663                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3666                 len = asc_prt_line(cp, leftlen, " %X:%u", i, v->cur_dvc_qng[i]);
 
3669         len = asc_prt_line(cp, leftlen, "\n");
 
3672         /* Current limit on number of commands that can be sent to a device. */
 
3673         len = asc_prt_line(cp, leftlen, " Command Queue Limit:");
 
3675         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3676                 if ((chip_scsi_id == i) ||
 
3677                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3680                 len = asc_prt_line(cp, leftlen, " %X:%u", i, v->max_dvc_qng[i]);
 
3683         len = asc_prt_line(cp, leftlen, "\n");
 
3686         /* Indicate whether the device has returned queue full status. */
 
3687         len = asc_prt_line(cp, leftlen, " Command Queue Full:");
 
3689         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3690                 if ((chip_scsi_id == i) ||
 
3691                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3694                 if (boardp->queue_full & ADV_TID_TO_TIDMASK(i)) {
 
3695                         len = asc_prt_line(cp, leftlen, " %X:Y-%d",
 
3696                                            i, boardp->queue_full_cnt[i]);
 
3698                         len = asc_prt_line(cp, leftlen, " %X:N", i);
 
3702         len = asc_prt_line(cp, leftlen, "\n");
 
3705         len = asc_prt_line(cp, leftlen, " Synchronous Transfer:");
 
3707         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3708                 if ((chip_scsi_id == i) ||
 
3709                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3712                 len = asc_prt_line(cp, leftlen, " %X:%c",
 
3715                                     sdtr_done & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3719         len = asc_prt_line(cp, leftlen, "\n");
 
3722         for (i = 0; i <= ASC_MAX_TID; i++) {
 
3723                 uchar syn_period_ix;
 
3725                 if ((chip_scsi_id == i) ||
 
3726                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0) ||
 
3727                     ((v->init_sdtr & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3731                 len = asc_prt_line(cp, leftlen, "  %X:", i);
 
3734                 if ((boardp->sdtr_data[i] & ASC_SYN_MAX_OFFSET) == 0) {
 
3735                         len = asc_prt_line(cp, leftlen, " Asynchronous");
 
3739                             (boardp->sdtr_data[i] >> 4) & (v->max_sdtr_index -
 
3742                         len = asc_prt_line(cp, leftlen,
 
3743                                            " Transfer Period Factor: %d (%d.%d Mhz),",
 
3744                                            v->sdtr_period_tbl[syn_period_ix],
 
3746                                            v->sdtr_period_tbl[syn_period_ix],
 
3753                         len = asc_prt_line(cp, leftlen, " REQ/ACK Offset: %d",
 
3755                                            sdtr_data[i] & ASC_SYN_MAX_OFFSET);
 
3759                 if ((v->sdtr_done & ADV_TID_TO_TIDMASK(i)) == 0) {
 
3760                         len = asc_prt_line(cp, leftlen, "*\n");
 
3763                         len = asc_prt_line(cp, leftlen, "\n");
 
3769                 len = asc_prt_line(cp, leftlen,
 
3770                                    " * = Re-negotiation pending before next command.\n");
 
3778  * asc_prt_adv_board_info()
 
3780  * Print dynamic board configuration information.
 
3782  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
3783  * cf. asc_prt_line().
 
3785  * Return the number of characters copied into 'cp'. No more than
 
3786  * 'cplen' characters will be copied to 'cp'.
 
3788 static int asc_prt_adv_board_info(struct Scsi_Host *shost, char *cp, int cplen)
 
3790         struct asc_board *boardp = shost_priv(shost);
 
3797         AdvPortAddr iop_base;
 
3798         ushort chip_scsi_id;
 
3802         ushort sdtr_able, wdtr_able;
 
3803         ushort wdtr_done, sdtr_done;
 
3805         int renegotiate = 0;
 
3807         v = &boardp->dvc_var.adv_dvc_var;
 
3808         c = &boardp->dvc_cfg.adv_dvc_cfg;
 
3809         iop_base = v->iop_base;
 
3810         chip_scsi_id = v->chip_scsi_id;
 
3815         len = asc_prt_line(cp, leftlen,
 
3816                            "\nAdv Library Configuration and Statistics for AdvanSys SCSI Host %d:\n",
 
3820         len = asc_prt_line(cp, leftlen,
 
3821                            " iop_base 0x%lx, cable_detect: %X, err_code %u\n",
 
3823                            AdvReadWordRegister(iop_base,
 
3824                                                IOPW_SCSI_CFG1) & CABLE_DETECT,
 
3828         len = asc_prt_line(cp, leftlen, " chip_version %u, mcode_date 0x%x, "
 
3829                            "mcode_version 0x%x\n", c->chip_version,
 
3830                            c->mcode_date, c->mcode_version);
 
3833         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
3834         len = asc_prt_line(cp, leftlen, " Queuing Enabled:");
 
3836         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3837                 if ((chip_scsi_id == i) ||
 
3838                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3842                 len = asc_prt_line(cp, leftlen, " %X:%c",
 
3844                                    (tagqng_able & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3848         len = asc_prt_line(cp, leftlen, "\n");
 
3851         len = asc_prt_line(cp, leftlen, " Queue Limit:");
 
3853         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3854                 if ((chip_scsi_id == i) ||
 
3855                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3859                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + i,
 
3862                 len = asc_prt_line(cp, leftlen, " %X:%d", i, lrambyte);
 
3865         len = asc_prt_line(cp, leftlen, "\n");
 
3868         len = asc_prt_line(cp, leftlen, " Command Pending:");
 
3870         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3871                 if ((chip_scsi_id == i) ||
 
3872                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3876                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_QUEUED_CMD + i,
 
3879                 len = asc_prt_line(cp, leftlen, " %X:%d", i, lrambyte);
 
3882         len = asc_prt_line(cp, leftlen, "\n");
 
3885         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
3886         len = asc_prt_line(cp, leftlen, " Wide Enabled:");
 
3888         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3889                 if ((chip_scsi_id == i) ||
 
3890                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3894                 len = asc_prt_line(cp, leftlen, " %X:%c",
 
3896                                    (wdtr_able & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3900         len = asc_prt_line(cp, leftlen, "\n");
 
3903         AdvReadWordLram(iop_base, ASC_MC_WDTR_DONE, wdtr_done);
 
3904         len = asc_prt_line(cp, leftlen, " Transfer Bit Width:");
 
3906         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3907                 if ((chip_scsi_id == i) ||
 
3908                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3912                 AdvReadWordLram(iop_base,
 
3913                                 ASC_MC_DEVICE_HSHK_CFG_TABLE + (2 * i),
 
3916                 len = asc_prt_line(cp, leftlen, " %X:%d",
 
3917                                    i, (lramword & 0x8000) ? 16 : 8);
 
3920                 if ((wdtr_able & ADV_TID_TO_TIDMASK(i)) &&
 
3921                     (wdtr_done & ADV_TID_TO_TIDMASK(i)) == 0) {
 
3922                         len = asc_prt_line(cp, leftlen, "*");
 
3927         len = asc_prt_line(cp, leftlen, "\n");
 
3930         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
3931         len = asc_prt_line(cp, leftlen, " Synchronous Enabled:");
 
3933         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3934                 if ((chip_scsi_id == i) ||
 
3935                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3939                 len = asc_prt_line(cp, leftlen, " %X:%c",
 
3941                                    (sdtr_able & ADV_TID_TO_TIDMASK(i)) ? 'Y' :
 
3945         len = asc_prt_line(cp, leftlen, "\n");
 
3948         AdvReadWordLram(iop_base, ASC_MC_SDTR_DONE, sdtr_done);
 
3949         for (i = 0; i <= ADV_MAX_TID; i++) {
 
3951                 AdvReadWordLram(iop_base,
 
3952                                 ASC_MC_DEVICE_HSHK_CFG_TABLE + (2 * i),
 
3954                 lramword &= ~0x8000;
 
3956                 if ((chip_scsi_id == i) ||
 
3957                     ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(i)) == 0) ||
 
3958                     ((sdtr_able & ADV_TID_TO_TIDMASK(i)) == 0)) {
 
3962                 len = asc_prt_line(cp, leftlen, "  %X:", i);
 
3965                 if ((lramword & 0x1F) == 0) {   /* Check for REQ/ACK Offset 0. */
 
3966                         len = asc_prt_line(cp, leftlen, " Asynchronous");
 
3970                             asc_prt_line(cp, leftlen,
 
3971                                          " Transfer Period Factor: ");
 
3974                         if ((lramword & 0x1F00) == 0x1100) {    /* 80 Mhz */
 
3976                                     asc_prt_line(cp, leftlen, "9 (80.0 Mhz),");
 
3978                         } else if ((lramword & 0x1F00) == 0x1000) {     /* 40 Mhz */
 
3980                                     asc_prt_line(cp, leftlen, "10 (40.0 Mhz),");
 
3982                         } else {        /* 20 Mhz or below. */
 
3984                                 period = (((lramword >> 8) * 25) + 50) / 4;
 
3986                                 if (period == 0) {      /* Should never happen. */
 
3988                                             asc_prt_line(cp, leftlen,
 
3992                                         len = asc_prt_line(cp, leftlen,
 
3994                                                            period, 250 / period,
 
4001                         len = asc_prt_line(cp, leftlen, " REQ/ACK Offset: %d",
 
4006                 if ((sdtr_done & ADV_TID_TO_TIDMASK(i)) == 0) {
 
4007                         len = asc_prt_line(cp, leftlen, "*\n");
 
4010                         len = asc_prt_line(cp, leftlen, "\n");
 
4016                 len = asc_prt_line(cp, leftlen,
 
4017                                    " * = Re-negotiation pending before next command.\n");
 
4027  * Copy proc information to a read buffer taking into account the current
 
4028  * read offset in the file and the remaining space in the read buffer.
 
4031 asc_proc_copy(off_t advoffset, off_t offset, char *curbuf, int leftlen,
 
4032               char *cp, int cplen)
 
4036         ASC_DBG(2, "offset %d, advoffset %d, cplen %d\n",
 
4037                  (unsigned)offset, (unsigned)advoffset, cplen);
 
4038         if (offset <= advoffset) {
 
4039                 /* Read offset below current offset, copy everything. */
 
4040                 cnt = min(cplen, leftlen);
 
4041                 ASC_DBG(2, "curbuf 0x%lx, cp 0x%lx, cnt %d\n",
 
4042                          (ulong)curbuf, (ulong)cp, cnt);
 
4043                 memcpy(curbuf, cp, cnt);
 
4044         } else if (offset < advoffset + cplen) {
 
4045                 /* Read offset within current range, partial copy. */
 
4046                 cnt = (advoffset + cplen) - offset;
 
4047                 cp = (cp + cplen) - cnt;
 
4048                 cnt = min(cnt, leftlen);
 
4049                 ASC_DBG(2, "curbuf 0x%lx, cp 0x%lx, cnt %d\n",
 
4050                          (ulong)curbuf, (ulong)cp, cnt);
 
4051                 memcpy(curbuf, cp, cnt);
 
4056 #ifdef ADVANSYS_STATS
 
4058  * asc_prt_board_stats()
 
4060  * Note: no single line should be greater than ASC_PRTLINE_SIZE,
 
4061  * cf. asc_prt_line().
 
4063  * Return the number of characters copied into 'cp'. No more than
 
4064  * 'cplen' characters will be copied to 'cp'.
 
4066 static int asc_prt_board_stats(struct Scsi_Host *shost, char *cp, int cplen)
 
4068         struct asc_board *boardp = shost_priv(shost);
 
4069         struct asc_stats *s = &boardp->asc_stats;
 
4071         int leftlen = cplen;
 
4072         int len, totlen = 0;
 
4074         len = asc_prt_line(cp, leftlen,
 
4075                            "\nLinux Driver Statistics for AdvanSys SCSI Host %d:\n",
 
4079         len = asc_prt_line(cp, leftlen,
 
4080                            " queuecommand %lu, reset %lu, biosparam %lu, interrupt %lu\n",
 
4081                            s->queuecommand, s->reset, s->biosparam,
 
4085         len = asc_prt_line(cp, leftlen,
 
4086                            " callback %lu, done %lu, build_error %lu, build_noreq %lu, build_nosg %lu\n",
 
4087                            s->callback, s->done, s->build_error,
 
4088                            s->adv_build_noreq, s->adv_build_nosg);
 
4091         len = asc_prt_line(cp, leftlen,
 
4092                            " exe_noerror %lu, exe_busy %lu, exe_error %lu, exe_unknown %lu\n",
 
4093                            s->exe_noerror, s->exe_busy, s->exe_error,
 
4098          * Display data transfer statistics.
 
4100         if (s->xfer_cnt > 0) {
 
4101                 len = asc_prt_line(cp, leftlen, " xfer_cnt %lu, xfer_elem %lu, ",
 
4102                                    s->xfer_cnt, s->xfer_elem);
 
4105                 len = asc_prt_line(cp, leftlen, "xfer_bytes %lu.%01lu kb\n",
 
4106                                    s->xfer_sect / 2, ASC_TENTHS(s->xfer_sect, 2));
 
4109                 /* Scatter gather transfer statistics */
 
4110                 len = asc_prt_line(cp, leftlen, " avg_num_elem %lu.%01lu, ",
 
4111                                    s->xfer_elem / s->xfer_cnt,
 
4112                                    ASC_TENTHS(s->xfer_elem, s->xfer_cnt));
 
4115                 len = asc_prt_line(cp, leftlen, "avg_elem_size %lu.%01lu kb, ",
 
4116                                    (s->xfer_sect / 2) / s->xfer_elem,
 
4117                                    ASC_TENTHS((s->xfer_sect / 2), s->xfer_elem));
 
4120                 len = asc_prt_line(cp, leftlen, "avg_xfer_size %lu.%01lu kb\n",
 
4121                                    (s->xfer_sect / 2) / s->xfer_cnt,
 
4122                                    ASC_TENTHS((s->xfer_sect / 2), s->xfer_cnt));
 
4128 #endif /* ADVANSYS_STATS */
 
4131  * advansys_proc_info() - /proc/scsi/advansys/{0,1,2,3,...}
 
4133  * *buffer: I/O buffer
 
4134  * **start: if inout == FALSE pointer into buffer where user read should start
 
4135  * offset: current offset into a /proc/scsi/advansys/[0...] file
 
4136  * length: length of buffer
 
4137  * hostno: Scsi_Host host_no
 
4138  * inout: TRUE - user is writing; FALSE - user is reading
 
4140  * Return the number of bytes read from or written to a
 
4141  * /proc/scsi/advansys/[0...] file.
 
4143  * Note: This function uses the per board buffer 'prtbuf' which is
 
4144  * allocated when the board is initialized in advansys_detect(). The
 
4145  * buffer is ASC_PRTBUF_SIZE bytes. The function asc_proc_copy() is
 
4146  * used to write to the buffer. The way asc_proc_copy() is written
 
4147  * if 'prtbuf' is too small it will not be overwritten. Instead the
 
4148  * user just won't get all the available statistics.
 
4151 advansys_proc_info(struct Scsi_Host *shost, char *buffer, char **start,
 
4152                    off_t offset, int length, int inout)
 
4154         struct asc_board *boardp = shost_priv(shost);
 
4163         ASC_DBG(1, "begin\n");
 
4166          * User write not supported.
 
4172          * User read of /proc/scsi/advansys/[0...] file.
 
4175         /* Copy read data starting at the beginning of the buffer. */
 
4183          * Get board configuration information.
 
4185          * advansys_info() returns the board string from its own static buffer.
 
4187         cp = (char *)advansys_info(shost);
 
4190         /* Copy board information. */
 
4191         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4195                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4202          * Display Wide Board BIOS Information.
 
4204         if (!ASC_NARROW_BOARD(boardp)) {
 
4205                 cp = boardp->prtbuf;
 
4206                 cplen = asc_prt_adv_bios(shost, cp, ASC_PRTBUF_SIZE);
 
4207                 BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4208                 cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp,
 
4213                         ASC_DBG(1, "totcnt %d\n", totcnt);
 
4221          * Display driver information for each device attached to the board.
 
4223         cp = boardp->prtbuf;
 
4224         cplen = asc_prt_board_devices(shost, cp, ASC_PRTBUF_SIZE);
 
4225         BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4226         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4230                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4237          * Display EEPROM configuration for the board.
 
4239         cp = boardp->prtbuf;
 
4240         if (ASC_NARROW_BOARD(boardp)) {
 
4241                 cplen = asc_prt_asc_board_eeprom(shost, cp, ASC_PRTBUF_SIZE);
 
4243                 cplen = asc_prt_adv_board_eeprom(shost, cp, ASC_PRTBUF_SIZE);
 
4245         BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4246         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4250                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4257          * Display driver configuration and information for the board.
 
4259         cp = boardp->prtbuf;
 
4260         cplen = asc_prt_driver_conf(shost, cp, ASC_PRTBUF_SIZE);
 
4261         BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4262         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4266                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4272 #ifdef ADVANSYS_STATS
 
4274          * Display driver statistics for the board.
 
4276         cp = boardp->prtbuf;
 
4277         cplen = asc_prt_board_stats(shost, cp, ASC_PRTBUF_SIZE);
 
4278         BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4279         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4283                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4288 #endif /* ADVANSYS_STATS */
 
4291          * Display Asc Library dynamic configuration information
 
4294         cp = boardp->prtbuf;
 
4295         if (ASC_NARROW_BOARD(boardp)) {
 
4296                 cplen = asc_prt_asc_board_info(shost, cp, ASC_PRTBUF_SIZE);
 
4298                 cplen = asc_prt_adv_board_info(shost, cp, ASC_PRTBUF_SIZE);
 
4300         BUG_ON(cplen >= ASC_PRTBUF_SIZE);
 
4301         cnt = asc_proc_copy(advoffset, offset, curbuf, leftlen, cp, cplen);
 
4305                 ASC_DBG(1, "totcnt %d\n", totcnt);
 
4311         ASC_DBG(1, "totcnt %d\n", totcnt);
 
4315 #endif /* CONFIG_PROC_FS */
 
4317 static void asc_scsi_done(struct scsi_cmnd *scp)
 
4319         scsi_dma_unmap(scp);
 
4320         ASC_STATS(scp->device->host, done);
 
4321         scp->scsi_done(scp);
 
4324 static void AscSetBank(PortAddr iop_base, uchar bank)
 
4328         val = AscGetChipControl(iop_base) &
 
4330              (CC_SINGLE_STEP | CC_TEST | CC_DIAG | CC_SCSI_RESET |
 
4334         } else if (bank == 2) {
 
4335                 val |= CC_DIAG | CC_BANK_ONE;
 
4337                 val &= ~CC_BANK_ONE;
 
4339         AscSetChipControl(iop_base, val);
 
4342 static void AscSetChipIH(PortAddr iop_base, ushort ins_code)
 
4344         AscSetBank(iop_base, 1);
 
4345         AscWriteChipIH(iop_base, ins_code);
 
4346         AscSetBank(iop_base, 0);
 
4349 static int AscStartChip(PortAddr iop_base)
 
4351         AscSetChipControl(iop_base, 0);
 
4352         if ((AscGetChipStatus(iop_base) & CSW_HALTED) != 0) {
 
4358 static int AscStopChip(PortAddr iop_base)
 
4363             AscGetChipControl(iop_base) &
 
4364             (~(CC_SINGLE_STEP | CC_TEST | CC_DIAG));
 
4365         AscSetChipControl(iop_base, (uchar)(cc_val | CC_HALT));
 
4366         AscSetChipIH(iop_base, INS_HALT);
 
4367         AscSetChipIH(iop_base, INS_RFLAG_WTM);
 
4368         if ((AscGetChipStatus(iop_base) & CSW_HALTED) == 0) {
 
4374 static int AscIsChipHalted(PortAddr iop_base)
 
4376         if ((AscGetChipStatus(iop_base) & CSW_HALTED) != 0) {
 
4377                 if ((AscGetChipControl(iop_base) & CC_HALT) != 0) {
 
4384 static int AscResetChipAndScsiBus(ASC_DVC_VAR *asc_dvc)
 
4389         iop_base = asc_dvc->iop_base;
 
4390         while ((AscGetChipStatus(iop_base) & CSW_SCSI_RESET_ACTIVE)
 
4394         AscStopChip(iop_base);
 
4395         AscSetChipControl(iop_base, CC_CHIP_RESET | CC_SCSI_RESET | CC_HALT);
 
4397         AscSetChipIH(iop_base, INS_RFLAG_WTM);
 
4398         AscSetChipIH(iop_base, INS_HALT);
 
4399         AscSetChipControl(iop_base, CC_CHIP_RESET | CC_HALT);
 
4400         AscSetChipControl(iop_base, CC_HALT);
 
4402         AscSetChipStatus(iop_base, CIW_CLR_SCSI_RESET_INT);
 
4403         AscSetChipStatus(iop_base, 0);
 
4404         return (AscIsChipHalted(iop_base));
 
4407 static int AscFindSignature(PortAddr iop_base)
 
4411         ASC_DBG(1, "AscGetChipSignatureByte(0x%x) 0x%x\n",
 
4412                  iop_base, AscGetChipSignatureByte(iop_base));
 
4413         if (AscGetChipSignatureByte(iop_base) == (uchar)ASC_1000_ID1B) {
 
4414                 ASC_DBG(1, "AscGetChipSignatureWord(0x%x) 0x%x\n",
 
4415                          iop_base, AscGetChipSignatureWord(iop_base));
 
4416                 sig_word = AscGetChipSignatureWord(iop_base);
 
4417                 if ((sig_word == (ushort)ASC_1000_ID0W) ||
 
4418                     (sig_word == (ushort)ASC_1000_ID0W_FIX)) {
 
4425 static void AscEnableInterrupt(PortAddr iop_base)
 
4429         cfg = AscGetChipCfgLsw(iop_base);
 
4430         AscSetChipCfgLsw(iop_base, cfg | ASC_CFG0_HOST_INT_ON);
 
4433 static void AscDisableInterrupt(PortAddr iop_base)
 
4437         cfg = AscGetChipCfgLsw(iop_base);
 
4438         AscSetChipCfgLsw(iop_base, cfg & (~ASC_CFG0_HOST_INT_ON));
 
4441 static uchar AscReadLramByte(PortAddr iop_base, ushort addr)
 
4443         unsigned char byte_data;
 
4444         unsigned short word_data;
 
4446         if (isodd_word(addr)) {
 
4447                 AscSetChipLramAddr(iop_base, addr - 1);
 
4448                 word_data = AscGetChipLramData(iop_base);
 
4449                 byte_data = (word_data >> 8) & 0xFF;
 
4451                 AscSetChipLramAddr(iop_base, addr);
 
4452                 word_data = AscGetChipLramData(iop_base);
 
4453                 byte_data = word_data & 0xFF;
 
4458 static ushort AscReadLramWord(PortAddr iop_base, ushort addr)
 
4462         AscSetChipLramAddr(iop_base, addr);
 
4463         word_data = AscGetChipLramData(iop_base);
 
4467 #if CC_VERY_LONG_SG_LIST
 
4468 static ASC_DCNT AscReadLramDWord(PortAddr iop_base, ushort addr)
 
4470         ushort val_low, val_high;
 
4471         ASC_DCNT dword_data;
 
4473         AscSetChipLramAddr(iop_base, addr);
 
4474         val_low = AscGetChipLramData(iop_base);
 
4475         val_high = AscGetChipLramData(iop_base);
 
4476         dword_data = ((ASC_DCNT) val_high << 16) | (ASC_DCNT) val_low;
 
4477         return (dword_data);
 
4479 #endif /* CC_VERY_LONG_SG_LIST */
 
4482 AscMemWordSetLram(PortAddr iop_base, ushort s_addr, ushort set_wval, int words)
 
4486         AscSetChipLramAddr(iop_base, s_addr);
 
4487         for (i = 0; i < words; i++) {
 
4488                 AscSetChipLramData(iop_base, set_wval);
 
4492 static void AscWriteLramWord(PortAddr iop_base, ushort addr, ushort word_val)
 
4494         AscSetChipLramAddr(iop_base, addr);
 
4495         AscSetChipLramData(iop_base, word_val);
 
4498 static void AscWriteLramByte(PortAddr iop_base, ushort addr, uchar byte_val)
 
4502         if (isodd_word(addr)) {
 
4504                 word_data = AscReadLramWord(iop_base, addr);
 
4505                 word_data &= 0x00FF;
 
4506                 word_data |= (((ushort)byte_val << 8) & 0xFF00);
 
4508                 word_data = AscReadLramWord(iop_base, addr);
 
4509                 word_data &= 0xFF00;
 
4510                 word_data |= ((ushort)byte_val & 0x00FF);
 
4512         AscWriteLramWord(iop_base, addr, word_data);
 
4516  * Copy 2 bytes to LRAM.
 
4518  * The source data is assumed to be in little-endian order in memory
 
4519  * and is maintained in little-endian order when written to LRAM.
 
4522 AscMemWordCopyPtrToLram(PortAddr iop_base,
 
4523                         ushort s_addr, uchar *s_buffer, int words)
 
4527         AscSetChipLramAddr(iop_base, s_addr);
 
4528         for (i = 0; i < 2 * words; i += 2) {
 
4530                  * On a little-endian system the second argument below
 
4531                  * produces a little-endian ushort which is written to
 
4532                  * LRAM in little-endian order. On a big-endian system
 
4533                  * the second argument produces a big-endian ushort which
 
4534                  * is "transparently" byte-swapped by outpw() and written
 
4535                  * in little-endian order to LRAM.
 
4537                 outpw(iop_base + IOP_RAM_DATA,
 
4538                       ((ushort)s_buffer[i + 1] << 8) | s_buffer[i]);
 
4543  * Copy 4 bytes to LRAM.
 
4545  * The source data is assumed to be in little-endian order in memory
 
4546  * and is maintained in little-endian order when writen to LRAM.
 
4549 AscMemDWordCopyPtrToLram(PortAddr iop_base,
 
4550                          ushort s_addr, uchar *s_buffer, int dwords)
 
4554         AscSetChipLramAddr(iop_base, s_addr);
 
4555         for (i = 0; i < 4 * dwords; i += 4) {
 
4556                 outpw(iop_base + IOP_RAM_DATA, ((ushort)s_buffer[i + 1] << 8) | s_buffer[i]);   /* LSW */
 
4557                 outpw(iop_base + IOP_RAM_DATA, ((ushort)s_buffer[i + 3] << 8) | s_buffer[i + 2]);       /* MSW */
 
4562  * Copy 2 bytes from LRAM.
 
4564  * The source data is assumed to be in little-endian order in LRAM
 
4565  * and is maintained in little-endian order when written to memory.
 
4568 AscMemWordCopyPtrFromLram(PortAddr iop_base,
 
4569                           ushort s_addr, uchar *d_buffer, int words)
 
4574         AscSetChipLramAddr(iop_base, s_addr);
 
4575         for (i = 0; i < 2 * words; i += 2) {
 
4576                 word = inpw(iop_base + IOP_RAM_DATA);
 
4577                 d_buffer[i] = word & 0xff;
 
4578                 d_buffer[i + 1] = (word >> 8) & 0xff;
 
4582 static ASC_DCNT AscMemSumLramWord(PortAddr iop_base, ushort s_addr, int words)
 
4588         for (i = 0; i < words; i++, s_addr += 2) {
 
4589                 sum += AscReadLramWord(iop_base, s_addr);
 
4594 static ushort AscInitLram(ASC_DVC_VAR *asc_dvc)
 
4601         iop_base = asc_dvc->iop_base;
 
4603         AscMemWordSetLram(iop_base, ASC_QADR_BEG, 0,
 
4604                           (ushort)(((int)(asc_dvc->max_total_qng + 2 + 1) *
 
4606         i = ASC_MIN_ACTIVE_QNO;
 
4607         s_addr = ASC_QADR_BEG + ASC_QBLK_SIZE;
 
4608         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_FWD),
 
4610         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_BWD),
 
4611                          (uchar)(asc_dvc->max_total_qng));
 
4612         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_QNO),
 
4615         s_addr += ASC_QBLK_SIZE;
 
4616         for (; i < asc_dvc->max_total_qng; i++, s_addr += ASC_QBLK_SIZE) {
 
4617                 AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_FWD),
 
4619                 AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_BWD),
 
4621                 AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_QNO),
 
4624         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_FWD),
 
4625                          (uchar)ASC_QLINK_END);
 
4626         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_BWD),
 
4627                          (uchar)(asc_dvc->max_total_qng - 1));
 
4628         AscWriteLramByte(iop_base, (ushort)(s_addr + ASC_SCSIQ_B_QNO),
 
4629                          (uchar)asc_dvc->max_total_qng);
 
4631         s_addr += ASC_QBLK_SIZE;
 
4632         for (; i <= (uchar)(asc_dvc->max_total_qng + 3);
 
4633              i++, s_addr += ASC_QBLK_SIZE) {
 
4634                 AscWriteLramByte(iop_base,
 
4635                                  (ushort)(s_addr + (ushort)ASC_SCSIQ_B_FWD), i);
 
4636                 AscWriteLramByte(iop_base,
 
4637                                  (ushort)(s_addr + (ushort)ASC_SCSIQ_B_BWD), i);
 
4638                 AscWriteLramByte(iop_base,
 
4639                                  (ushort)(s_addr + (ushort)ASC_SCSIQ_B_QNO), i);
 
4645 AscLoadMicroCode(PortAddr iop_base,
 
4646                  ushort s_addr, uchar *mcode_buf, ushort mcode_size)
 
4649         ushort mcode_word_size;
 
4650         ushort mcode_chksum;
 
4652         /* Write the microcode buffer starting at LRAM address 0. */
 
4653         mcode_word_size = (ushort)(mcode_size >> 1);
 
4654         AscMemWordSetLram(iop_base, s_addr, 0, mcode_word_size);
 
4655         AscMemWordCopyPtrToLram(iop_base, s_addr, mcode_buf, mcode_word_size);
 
4657         chksum = AscMemSumLramWord(iop_base, s_addr, mcode_word_size);
 
4658         ASC_DBG(1, "chksum 0x%lx\n", (ulong)chksum);
 
4659         mcode_chksum = (ushort)AscMemSumLramWord(iop_base,
 
4660                                                  (ushort)ASC_CODE_SEC_BEG,
 
4661                                                  (ushort)((mcode_size -
 
4665         ASC_DBG(1, "mcode_chksum 0x%lx\n", (ulong)mcode_chksum);
 
4666         AscWriteLramWord(iop_base, ASCV_MCODE_CHKSUM_W, mcode_chksum);
 
4667         AscWriteLramWord(iop_base, ASCV_MCODE_SIZE_W, mcode_size);
 
4671 /* Microcode buffer is kept after initialization for error recovery. */
 
4672 static uchar _asc_mcode_buf[] = {
 
4673         0x01, 0x03, 0x01, 0x19, 0x0F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4674         0x00, 0x00, 0x00, 0x00, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F,
 
4675         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4676         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4677         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4678         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC3, 0x12, 0x0D, 0x05,
 
4679         0x01, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4680         0xFF, 0x80, 0xFF, 0xFF, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4681         0x00, 0x00, 0x00, 0x23, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0x00, 0xFF,
 
4682         0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00,
 
4683         0x00, 0x00, 0xE4, 0x88, 0x00, 0x00, 0x00, 0x00, 0x80, 0x73, 0x48, 0x04,
 
4684         0x36, 0x00, 0x00, 0xA2, 0xC2, 0x00, 0x80, 0x73, 0x03, 0x23, 0x36, 0x40,
 
4685         0xB6, 0x00, 0x36, 0x00, 0x05, 0xD6, 0x0C, 0xD2, 0x12, 0xDA, 0x00, 0xA2,
 
4686         0xC2, 0x00, 0x92, 0x80, 0x1E, 0x98, 0x50, 0x00, 0xF5, 0x00, 0x48, 0x98,
 
4687         0xDF, 0x23, 0x36, 0x60, 0xB6, 0x00, 0x92, 0x80, 0x4F, 0x00, 0xF5, 0x00,
 
4688         0x48, 0x98, 0xEF, 0x23, 0x36, 0x60, 0xB6, 0x00, 0x92, 0x80, 0x80, 0x62,
 
4689         0x92, 0x80, 0x00, 0x46, 0x15, 0xEE, 0x13, 0xEA, 0x02, 0x01, 0x09, 0xD8,
 
4690         0xCD, 0x04, 0x4D, 0x00, 0x00, 0xA3, 0xD6, 0x00, 0xA6, 0x97, 0x7F, 0x23,
 
4691         0x04, 0x61, 0x84, 0x01, 0xE6, 0x84, 0xD2, 0xC1, 0x80, 0x73, 0xCD, 0x04,
 
4692         0x4D, 0x00, 0x00, 0xA3, 0xDA, 0x01, 0xA6, 0x97, 0xC6, 0x81, 0xC2, 0x88,
 
4693         0x80, 0x73, 0x80, 0x77, 0x00, 0x01, 0x01, 0xA1, 0xFE, 0x00, 0x4F, 0x00,
 
4694         0x84, 0x97, 0x07, 0xA6, 0x08, 0x01, 0x00, 0x33, 0x03, 0x00, 0xC2, 0x88,
 
4695         0x03, 0x03, 0x01, 0xDE, 0xC2, 0x88, 0xCE, 0x00, 0x69, 0x60, 0xCE, 0x00,
 
4696         0x02, 0x03, 0x4A, 0x60, 0x00, 0xA2, 0x78, 0x01, 0x80, 0x63, 0x07, 0xA6,
 
4697         0x24, 0x01, 0x78, 0x81, 0x03, 0x03, 0x80, 0x63, 0xE2, 0x00, 0x07, 0xA6,
 
4698         0x34, 0x01, 0x00, 0x33, 0x04, 0x00, 0xC2, 0x88, 0x03, 0x07, 0x02, 0x01,
 
4699         0x04, 0xCA, 0x0D, 0x23, 0x68, 0x98, 0x4D, 0x04, 0x04, 0x85, 0x05, 0xD8,
 
4700         0x0D, 0x23, 0x68, 0x98, 0xCD, 0x04, 0x15, 0x23, 0xF8, 0x88, 0xFB, 0x23,
 
4701         0x02, 0x61, 0x82, 0x01, 0x80, 0x63, 0x02, 0x03, 0x06, 0xA3, 0x62, 0x01,
 
4702         0x00, 0x33, 0x0A, 0x00, 0xC2, 0x88, 0x4E, 0x00, 0x07, 0xA3, 0x6E, 0x01,
 
4703         0x00, 0x33, 0x0B, 0x00, 0xC2, 0x88, 0xCD, 0x04, 0x36, 0x2D, 0x00, 0x33,
 
4704         0x1A, 0x00, 0xC2, 0x88, 0x50, 0x04, 0x88, 0x81, 0x06, 0xAB, 0x82, 0x01,
 
4705         0x88, 0x81, 0x4E, 0x00, 0x07, 0xA3, 0x92, 0x01, 0x50, 0x00, 0x00, 0xA3,
 
4706         0x3C, 0x01, 0x00, 0x05, 0x7C, 0x81, 0x46, 0x97, 0x02, 0x01, 0x05, 0xC6,
 
4707         0x04, 0x23, 0xA0, 0x01, 0x15, 0x23, 0xA1, 0x01, 0xBE, 0x81, 0xFD, 0x23,
 
4708         0x02, 0x61, 0x82, 0x01, 0x0A, 0xDA, 0x4A, 0x00, 0x06, 0x61, 0x00, 0xA0,
 
4709         0xB4, 0x01, 0x80, 0x63, 0xCD, 0x04, 0x36, 0x2D, 0x00, 0x33, 0x1B, 0x00,
 
4710         0xC2, 0x88, 0x06, 0x23, 0x68, 0x98, 0xCD, 0x04, 0xE6, 0x84, 0x06, 0x01,
 
4711         0x00, 0xA2, 0xD4, 0x01, 0x57, 0x60, 0x00, 0xA0, 0xDA, 0x01, 0xE6, 0x84,
 
4712         0x80, 0x23, 0xA0, 0x01, 0xE6, 0x84, 0x80, 0x73, 0x4B, 0x00, 0x06, 0x61,
 
4713         0x00, 0xA2, 0x00, 0x02, 0x04, 0x01, 0x0C, 0xDE, 0x02, 0x01, 0x03, 0xCC,
 
4714         0x4F, 0x00, 0x84, 0x97, 0xFC, 0x81, 0x08, 0x23, 0x02, 0x41, 0x82, 0x01,
 
4715         0x4F, 0x00, 0x62, 0x97, 0x48, 0x04, 0x84, 0x80, 0xF0, 0x97, 0x00, 0x46,
 
4716         0x56, 0x00, 0x03, 0xC0, 0x01, 0x23, 0xE8, 0x00, 0x81, 0x73, 0x06, 0x29,
 
4717         0x03, 0x42, 0x06, 0xE2, 0x03, 0xEE, 0x6B, 0xEB, 0x11, 0x23, 0xF8, 0x88,
 
4718         0x04, 0x98, 0xF0, 0x80, 0x80, 0x73, 0x80, 0x77, 0x07, 0xA4, 0x2A, 0x02,
 
4719         0x7C, 0x95, 0x06, 0xA6, 0x34, 0x02, 0x03, 0xA6, 0x4C, 0x04, 0x46, 0x82,
 
4720         0x04, 0x01, 0x03, 0xD8, 0xB4, 0x98, 0x6A, 0x96, 0x46, 0x82, 0xFE, 0x95,
 
4721         0x80, 0x67, 0x83, 0x03, 0x80, 0x63, 0xB6, 0x2D, 0x02, 0xA6, 0x6C, 0x02,
 
4722         0x07, 0xA6, 0x5A, 0x02, 0x06, 0xA6, 0x5E, 0x02, 0x03, 0xA6, 0x62, 0x02,
 
4723         0xC2, 0x88, 0x7C, 0x95, 0x48, 0x82, 0x60, 0x96, 0x48, 0x82, 0x04, 0x23,
 
4724         0xA0, 0x01, 0x14, 0x23, 0xA1, 0x01, 0x3C, 0x84, 0x04, 0x01, 0x0C, 0xDC,
 
4725         0xE0, 0x23, 0x25, 0x61, 0xEF, 0x00, 0x14, 0x01, 0x4F, 0x04, 0xA8, 0x01,
 
4726         0x6F, 0x00, 0xA5, 0x01, 0x03, 0x23, 0xA4, 0x01, 0x06, 0x23, 0x9C, 0x01,
 
4727         0x24, 0x2B, 0x1C, 0x01, 0x02, 0xA6, 0xAA, 0x02, 0x07, 0xA6, 0x5A, 0x02,
 
4728         0x06, 0xA6, 0x5E, 0x02, 0x03, 0xA6, 0x20, 0x04, 0x01, 0xA6, 0xB4, 0x02,
 
4729         0x00, 0xA6, 0xB4, 0x02, 0x00, 0x33, 0x12, 0x00, 0xC2, 0x88, 0x00, 0x0E,
 
4730         0x80, 0x63, 0x00, 0x43, 0x00, 0xA0, 0x8C, 0x02, 0x4D, 0x04, 0x04, 0x01,
 
4731         0x0B, 0xDC, 0xE7, 0x23, 0x04, 0x61, 0x84, 0x01, 0x10, 0x31, 0x12, 0x35,
 
4732         0x14, 0x01, 0xEC, 0x00, 0x6C, 0x38, 0x00, 0x3F, 0x00, 0x00, 0xEA, 0x82,
 
4733         0x18, 0x23, 0x04, 0x61, 0x18, 0xA0, 0xE2, 0x02, 0x04, 0x01, 0xA2, 0xC8,
 
4734         0x00, 0x33, 0x1F, 0x00, 0xC2, 0x88, 0x08, 0x31, 0x0A, 0x35, 0x0C, 0x39,
 
4735         0x0E, 0x3D, 0x7E, 0x98, 0xB6, 0x2D, 0x01, 0xA6, 0x14, 0x03, 0x00, 0xA6,
 
4736         0x14, 0x03, 0x07, 0xA6, 0x0C, 0x03, 0x06, 0xA6, 0x10, 0x03, 0x03, 0xA6,
 
4737         0x20, 0x04, 0x02, 0xA6, 0x6C, 0x02, 0x00, 0x33, 0x33, 0x00, 0xC2, 0x88,
 
4738         0x7C, 0x95, 0xEE, 0x82, 0x60, 0x96, 0xEE, 0x82, 0x82, 0x98, 0x80, 0x42,
 
4739         0x7E, 0x98, 0x64, 0xE4, 0x04, 0x01, 0x2D, 0xC8, 0x31, 0x05, 0x07, 0x01,
 
4740         0x00, 0xA2, 0x54, 0x03, 0x00, 0x43, 0x87, 0x01, 0x05, 0x05, 0x86, 0x98,
 
4741         0x7E, 0x98, 0x00, 0xA6, 0x16, 0x03, 0x07, 0xA6, 0x4C, 0x03, 0x03, 0xA6,
 
4742         0x3C, 0x04, 0x06, 0xA6, 0x50, 0x03, 0x01, 0xA6, 0x16, 0x03, 0x00, 0x33,
 
4743         0x25, 0x00, 0xC2, 0x88, 0x7C, 0x95, 0x32, 0x83, 0x60, 0x96, 0x32, 0x83,
 
4744         0x04, 0x01, 0x10, 0xCE, 0x07, 0xC8, 0x05, 0x05, 0xEB, 0x04, 0x00, 0x33,
 
4745         0x00, 0x20, 0xC0, 0x20, 0x81, 0x62, 0x72, 0x83, 0x00, 0x01, 0x05, 0x05,
 
4746         0xFF, 0xA2, 0x7A, 0x03, 0xB1, 0x01, 0x08, 0x23, 0xB2, 0x01, 0x2E, 0x83,
 
4747         0x05, 0x05, 0x15, 0x01, 0x00, 0xA2, 0x9A, 0x03, 0xEC, 0x00, 0x6E, 0x00,
 
4748         0x95, 0x01, 0x6C, 0x38, 0x00, 0x3F, 0x00, 0x00, 0x01, 0xA6, 0x96, 0x03,
 
4749         0x00, 0xA6, 0x96, 0x03, 0x10, 0x84, 0x80, 0x42, 0x7E, 0x98, 0x01, 0xA6,
 
4750         0xA4, 0x03, 0x00, 0xA6, 0xBC, 0x03, 0x10, 0x84, 0xA8, 0x98, 0x80, 0x42,
 
4751         0x01, 0xA6, 0xA4, 0x03, 0x07, 0xA6, 0xB2, 0x03, 0xD4, 0x83, 0x7C, 0x95,
 
4752         0xA8, 0x83, 0x00, 0x33, 0x2F, 0x00, 0xC2, 0x88, 0xA8, 0x98, 0x80, 0x42,
 
4753         0x00, 0xA6, 0xBC, 0x03, 0x07, 0xA6, 0xCA, 0x03, 0xD4, 0x83, 0x7C, 0x95,
 
4754         0xC0, 0x83, 0x00, 0x33, 0x26, 0x00, 0xC2, 0x88, 0x38, 0x2B, 0x80, 0x32,
 
4755         0x80, 0x36, 0x04, 0x23, 0xA0, 0x01, 0x12, 0x23, 0xA1, 0x01, 0x10, 0x84,
 
4756         0x07, 0xF0, 0x06, 0xA4, 0xF4, 0x03, 0x80, 0x6B, 0x80, 0x67, 0x05, 0x23,
 
4757         0x83, 0x03, 0x80, 0x63, 0x03, 0xA6, 0x0E, 0x04, 0x07, 0xA6, 0x06, 0x04,
 
4758         0x06, 0xA6, 0x0A, 0x04, 0x00, 0x33, 0x17, 0x00, 0xC2, 0x88, 0x7C, 0x95,
 
4759         0xF4, 0x83, 0x60, 0x96, 0xF4, 0x83, 0x20, 0x84, 0x07, 0xF0, 0x06, 0xA4,
 
4760         0x20, 0x04, 0x80, 0x6B, 0x80, 0x67, 0x05, 0x23, 0x83, 0x03, 0x80, 0x63,
 
4761         0xB6, 0x2D, 0x03, 0xA6, 0x3C, 0x04, 0x07, 0xA6, 0x34, 0x04, 0x06, 0xA6,
 
4762         0x38, 0x04, 0x00, 0x33, 0x30, 0x00, 0xC2, 0x88, 0x7C, 0x95, 0x20, 0x84,
 
4763         0x60, 0x96, 0x20, 0x84, 0x1D, 0x01, 0x06, 0xCC, 0x00, 0x33, 0x00, 0x84,
 
4764         0xC0, 0x20, 0x00, 0x23, 0xEA, 0x00, 0x81, 0x62, 0xA2, 0x0D, 0x80, 0x63,
 
4765         0x07, 0xA6, 0x5A, 0x04, 0x00, 0x33, 0x18, 0x00, 0xC2, 0x88, 0x03, 0x03,
 
4766         0x80, 0x63, 0xA3, 0x01, 0x07, 0xA4, 0x64, 0x04, 0x23, 0x01, 0x00, 0xA2,
 
4767         0x86, 0x04, 0x0A, 0xA0, 0x76, 0x04, 0xE0, 0x00, 0x00, 0x33, 0x1D, 0x00,
 
4768         0xC2, 0x88, 0x0B, 0xA0, 0x82, 0x04, 0xE0, 0x00, 0x00, 0x33, 0x1E, 0x00,
 
4769         0xC2, 0x88, 0x42, 0x23, 0xF8, 0x88, 0x00, 0x23, 0x22, 0xA3, 0xE6, 0x04,
 
4770         0x08, 0x23, 0x22, 0xA3, 0xA2, 0x04, 0x28, 0x23, 0x22, 0xA3, 0xAE, 0x04,
 
4771         0x02, 0x23, 0x22, 0xA3, 0xC4, 0x04, 0x42, 0x23, 0xF8, 0x88, 0x4A, 0x00,
 
4772         0x06, 0x61, 0x00, 0xA0, 0xAE, 0x04, 0x45, 0x23, 0xF8, 0x88, 0x04, 0x98,
 
4773         0x00, 0xA2, 0xC0, 0x04, 0xB4, 0x98, 0x00, 0x33, 0x00, 0x82, 0xC0, 0x20,
 
4774         0x81, 0x62, 0xE8, 0x81, 0x47, 0x23, 0xF8, 0x88, 0x04, 0x01, 0x0B, 0xDE,
 
4775         0x04, 0x98, 0xB4, 0x98, 0x00, 0x33, 0x00, 0x81, 0xC0, 0x20, 0x81, 0x62,
 
4776         0x14, 0x01, 0x00, 0xA0, 0x00, 0x02, 0x43, 0x23, 0xF8, 0x88, 0x04, 0x23,
 
4777         0xA0, 0x01, 0x44, 0x23, 0xA1, 0x01, 0x80, 0x73, 0x4D, 0x00, 0x03, 0xA3,
 
4778         0xF4, 0x04, 0x00, 0x33, 0x27, 0x00, 0xC2, 0x88, 0x04, 0x01, 0x04, 0xDC,
 
4779         0x02, 0x23, 0xA2, 0x01, 0x04, 0x23, 0xA0, 0x01, 0x04, 0x98, 0x26, 0x95,
 
4780         0x4B, 0x00, 0xF6, 0x00, 0x4F, 0x04, 0x4F, 0x00, 0x00, 0xA3, 0x22, 0x05,
 
4781         0x00, 0x05, 0x76, 0x00, 0x06, 0x61, 0x00, 0xA2, 0x1C, 0x05, 0x0A, 0x85,
 
4782         0x46, 0x97, 0xCD, 0x04, 0x24, 0x85, 0x48, 0x04, 0x84, 0x80, 0x02, 0x01,
 
4783         0x03, 0xDA, 0x80, 0x23, 0x82, 0x01, 0x34, 0x85, 0x02, 0x23, 0xA0, 0x01,
 
4784         0x4A, 0x00, 0x06, 0x61, 0x00, 0xA2, 0x40, 0x05, 0x1D, 0x01, 0x04, 0xD6,
 
4785         0xFF, 0x23, 0x86, 0x41, 0x4B, 0x60, 0xCB, 0x00, 0xFF, 0x23, 0x80, 0x01,
 
4786         0x49, 0x00, 0x81, 0x01, 0x04, 0x01, 0x02, 0xC8, 0x30, 0x01, 0x80, 0x01,
 
4787         0xF7, 0x04, 0x03, 0x01, 0x49, 0x04, 0x80, 0x01, 0xC9, 0x00, 0x00, 0x05,
 
4788         0x00, 0x01, 0xFF, 0xA0, 0x60, 0x05, 0x77, 0x04, 0x01, 0x23, 0xEA, 0x00,
 
4789         0x5D, 0x00, 0xFE, 0xC7, 0x00, 0x62, 0x00, 0x23, 0xEA, 0x00, 0x00, 0x63,
 
4790         0x07, 0xA4, 0xF8, 0x05, 0x03, 0x03, 0x02, 0xA0, 0x8E, 0x05, 0xF4, 0x85,
 
4791         0x00, 0x33, 0x2D, 0x00, 0xC2, 0x88, 0x04, 0xA0, 0xB8, 0x05, 0x80, 0x63,
 
4792         0x00, 0x23, 0xDF, 0x00, 0x4A, 0x00, 0x06, 0x61, 0x00, 0xA2, 0xA4, 0x05,
 
4793         0x1D, 0x01, 0x06, 0xD6, 0x02, 0x23, 0x02, 0x41, 0x82, 0x01, 0x50, 0x00,
 
4794         0x62, 0x97, 0x04, 0x85, 0x04, 0x23, 0x02, 0x41, 0x82, 0x01, 0x04, 0x85,
 
4795         0x08, 0xA0, 0xBE, 0x05, 0xF4, 0x85, 0x03, 0xA0, 0xC4, 0x05, 0xF4, 0x85,
 
4796         0x01, 0xA0, 0xCE, 0x05, 0x88, 0x00, 0x80, 0x63, 0xCC, 0x86, 0x07, 0xA0,
 
4797         0xEE, 0x05, 0x5F, 0x00, 0x00, 0x2B, 0xDF, 0x08, 0x00, 0xA2, 0xE6, 0x05,
 
4798         0x80, 0x67, 0x80, 0x63, 0x01, 0xA2, 0x7A, 0x06, 0x7C, 0x85, 0x06, 0x23,
 
4799         0x68, 0x98, 0x48, 0x23, 0xF8, 0x88, 0x07, 0x23, 0x80, 0x00, 0x06, 0x87,
 
4800         0x80, 0x63, 0x7C, 0x85, 0x00, 0x23, 0xDF, 0x00, 0x00, 0x63, 0x4A, 0x00,
 
4801         0x06, 0x61, 0x00, 0xA2, 0x36, 0x06, 0x1D, 0x01, 0x16, 0xD4, 0xC0, 0x23,
 
4802         0x07, 0x41, 0x83, 0x03, 0x80, 0x63, 0x06, 0xA6, 0x1C, 0x06, 0x00, 0x33,
 
4803         0x37, 0x00, 0xC2, 0x88, 0x1D, 0x01, 0x01, 0xD6, 0x20, 0x23, 0x63, 0x60,
 
4804         0x83, 0x03, 0x80, 0x63, 0x02, 0x23, 0xDF, 0x00, 0x07, 0xA6, 0x7C, 0x05,
 
4805         0xEF, 0x04, 0x6F, 0x00, 0x00, 0x63, 0x4B, 0x00, 0x06, 0x41, 0xCB, 0x00,
 
4806         0x52, 0x00, 0x06, 0x61, 0x00, 0xA2, 0x4E, 0x06, 0x1D, 0x01, 0x03, 0xCA,
 
4807         0xC0, 0x23, 0x07, 0x41, 0x00, 0x63, 0x1D, 0x01, 0x04, 0xCC, 0x00, 0x33,
 
4808         0x00, 0x83, 0xC0, 0x20, 0x81, 0x62, 0x80, 0x23, 0x07, 0x41, 0x00, 0x63,
 
4809         0x80, 0x67, 0x08, 0x23, 0x83, 0x03, 0x80, 0x63, 0x00, 0x63, 0x01, 0x23,
 
4810         0xDF, 0x00, 0x06, 0xA6, 0x84, 0x06, 0x07, 0xA6, 0x7C, 0x05, 0x80, 0x67,
 
4811         0x80, 0x63, 0x00, 0x33, 0x00, 0x40, 0xC0, 0x20, 0x81, 0x62, 0x00, 0x63,
 
4812         0x00, 0x00, 0xFE, 0x95, 0x83, 0x03, 0x80, 0x63, 0x06, 0xA6, 0x94, 0x06,
 
4813         0x07, 0xA6, 0x7C, 0x05, 0x00, 0x00, 0x01, 0xA0, 0x14, 0x07, 0x00, 0x2B,
 
4814         0x40, 0x0E, 0x80, 0x63, 0x01, 0x00, 0x06, 0xA6, 0xAA, 0x06, 0x07, 0xA6,
 
4815         0x7C, 0x05, 0x40, 0x0E, 0x80, 0x63, 0x00, 0x43, 0x00, 0xA0, 0xA2, 0x06,
 
4816         0x06, 0xA6, 0xBC, 0x06, 0x07, 0xA6, 0x7C, 0x05, 0x80, 0x67, 0x40, 0x0E,
 
4817         0x80, 0x63, 0x07, 0xA6, 0x7C, 0x05, 0x00, 0x23, 0xDF, 0x00, 0x00, 0x63,
 
4818         0x07, 0xA6, 0xD6, 0x06, 0x00, 0x33, 0x2A, 0x00, 0xC2, 0x88, 0x03, 0x03,
 
4819         0x80, 0x63, 0x89, 0x00, 0x0A, 0x2B, 0x07, 0xA6, 0xE8, 0x06, 0x00, 0x33,
 
4820         0x29, 0x00, 0xC2, 0x88, 0x00, 0x43, 0x00, 0xA2, 0xF4, 0x06, 0xC0, 0x0E,
 
4821         0x80, 0x63, 0xDE, 0x86, 0xC0, 0x0E, 0x00, 0x33, 0x00, 0x80, 0xC0, 0x20,
 
4822         0x81, 0x62, 0x04, 0x01, 0x02, 0xDA, 0x80, 0x63, 0x7C, 0x85, 0x80, 0x7B,
 
4823         0x80, 0x63, 0x06, 0xA6, 0x8C, 0x06, 0x00, 0x33, 0x2C, 0x00, 0xC2, 0x88,
 
4824         0x0C, 0xA2, 0x2E, 0x07, 0xFE, 0x95, 0x83, 0x03, 0x80, 0x63, 0x06, 0xA6,
 
4825         0x2C, 0x07, 0x07, 0xA6, 0x7C, 0x05, 0x00, 0x33, 0x3D, 0x00, 0xC2, 0x88,
 
4826         0x00, 0x00, 0x80, 0x67, 0x83, 0x03, 0x80, 0x63, 0x0C, 0xA0, 0x44, 0x07,
 
4827         0x07, 0xA6, 0x7C, 0x05, 0xBF, 0x23, 0x04, 0x61, 0x84, 0x01, 0xE6, 0x84,
 
4828         0x00, 0x63, 0xF0, 0x04, 0x01, 0x01, 0xF1, 0x00, 0x00, 0x01, 0xF2, 0x00,
 
4829         0x01, 0x05, 0x80, 0x01, 0x72, 0x04, 0x71, 0x00, 0x81, 0x01, 0x70, 0x04,
 
4830         0x80, 0x05, 0x81, 0x05, 0x00, 0x63, 0xF0, 0x04, 0xF2, 0x00, 0x72, 0x04,
 
4831         0x01, 0x01, 0xF1, 0x00, 0x70, 0x00, 0x81, 0x01, 0x70, 0x04, 0x71, 0x00,
 
4832         0x81, 0x01, 0x72, 0x00, 0x80, 0x01, 0x71, 0x04, 0x70, 0x00, 0x80, 0x01,
 
4833         0x70, 0x04, 0x00, 0x63, 0xF0, 0x04, 0xF2, 0x00, 0x72, 0x04, 0x00, 0x01,
 
4834         0xF1, 0x00, 0x70, 0x00, 0x80, 0x01, 0x70, 0x04, 0x71, 0x00, 0x80, 0x01,
 
4835         0x72, 0x00, 0x81, 0x01, 0x71, 0x04, 0x70, 0x00, 0x81, 0x01, 0x70, 0x04,
 
4836         0x00, 0x63, 0x00, 0x23, 0xB3, 0x01, 0x83, 0x05, 0xA3, 0x01, 0xA2, 0x01,
 
4837         0xA1, 0x01, 0x01, 0x23, 0xA0, 0x01, 0x00, 0x01, 0xC8, 0x00, 0x03, 0xA1,
 
4838         0xC4, 0x07, 0x00, 0x33, 0x07, 0x00, 0xC2, 0x88, 0x80, 0x05, 0x81, 0x05,
 
4839         0x04, 0x01, 0x11, 0xC8, 0x48, 0x00, 0xB0, 0x01, 0xB1, 0x01, 0x08, 0x23,
 
4840         0xB2, 0x01, 0x05, 0x01, 0x48, 0x04, 0x00, 0x43, 0x00, 0xA2, 0xE4, 0x07,
 
4841         0x00, 0x05, 0xDA, 0x87, 0x00, 0x01, 0xC8, 0x00, 0xFF, 0x23, 0x80, 0x01,
 
4842         0x05, 0x05, 0x00, 0x63, 0xF7, 0x04, 0x1A, 0x09, 0xF6, 0x08, 0x6E, 0x04,
 
4843         0x00, 0x02, 0x80, 0x43, 0x76, 0x08, 0x80, 0x02, 0x77, 0x04, 0x00, 0x63,
 
4844         0xF7, 0x04, 0x1A, 0x09, 0xF6, 0x08, 0x6E, 0x04, 0x00, 0x02, 0x00, 0xA0,
 
4845         0x14, 0x08, 0x16, 0x88, 0x00, 0x43, 0x76, 0x08, 0x80, 0x02, 0x77, 0x04,
 
4846         0x00, 0x63, 0xF3, 0x04, 0x00, 0x23, 0xF4, 0x00, 0x74, 0x00, 0x80, 0x43,
 
4847         0xF4, 0x00, 0xCF, 0x40, 0x00, 0xA2, 0x44, 0x08, 0x74, 0x04, 0x02, 0x01,
 
4848         0xF7, 0xC9, 0xF6, 0xD9, 0x00, 0x01, 0x01, 0xA1, 0x24, 0x08, 0x04, 0x98,
 
4849         0x26, 0x95, 0x24, 0x88, 0x73, 0x04, 0x00, 0x63, 0xF3, 0x04, 0x75, 0x04,
 
4850         0x5A, 0x88, 0x02, 0x01, 0x04, 0xD8, 0x46, 0x97, 0x04, 0x98, 0x26, 0x95,
 
4851         0x4A, 0x88, 0x75, 0x00, 0x00, 0xA3, 0x64, 0x08, 0x00, 0x05, 0x4E, 0x88,
 
4852         0x73, 0x04, 0x00, 0x63, 0x80, 0x7B, 0x80, 0x63, 0x06, 0xA6, 0x76, 0x08,
 
4853         0x00, 0x33, 0x3E, 0x00, 0xC2, 0x88, 0x80, 0x67, 0x83, 0x03, 0x80, 0x63,
 
4854         0x00, 0x63, 0x38, 0x2B, 0x9C, 0x88, 0x38, 0x2B, 0x92, 0x88, 0x32, 0x09,
 
4855         0x31, 0x05, 0x92, 0x98, 0x05, 0x05, 0xB2, 0x09, 0x00, 0x63, 0x00, 0x32,
 
4856         0x00, 0x36, 0x00, 0x3A, 0x00, 0x3E, 0x00, 0x63, 0x80, 0x32, 0x80, 0x36,
 
4857         0x80, 0x3A, 0x80, 0x3E, 0xB4, 0x3D, 0x00, 0x63, 0x38, 0x2B, 0x40, 0x32,
 
4858         0x40, 0x36, 0x40, 0x3A, 0x40, 0x3E, 0x00, 0x63, 0x5A, 0x20, 0xC9, 0x40,
 
4859         0x00, 0xA0, 0xB4, 0x08, 0x5D, 0x00, 0xFE, 0xC3, 0x00, 0x63, 0x80, 0x73,
 
4860         0xE6, 0x20, 0x02, 0x23, 0xE8, 0x00, 0x82, 0x73, 0xFF, 0xFD, 0x80, 0x73,
 
4861         0x13, 0x23, 0xF8, 0x88, 0x66, 0x20, 0xC0, 0x20, 0x04, 0x23, 0xA0, 0x01,
 
4862         0xA1, 0x23, 0xA1, 0x01, 0x81, 0x62, 0xE2, 0x88, 0x80, 0x73, 0x80, 0x77,
 
4863         0x68, 0x00, 0x00, 0xA2, 0x80, 0x00, 0x03, 0xC2, 0xF1, 0xC7, 0x41, 0x23,
 
4864         0xF8, 0x88, 0x11, 0x23, 0xA1, 0x01, 0x04, 0x23, 0xA0, 0x01, 0xE6, 0x84,
 
4867 static unsigned short _asc_mcode_size = sizeof(_asc_mcode_buf);
 
4868 static ADV_DCNT _asc_mcode_chksum = 0x012C453FUL;
 
4870 /* Microcode buffer is kept after initialization for error recovery. */
 
4871 static unsigned char _adv_asc3550_buf[] = {
 
4872         0x00, 0x00, 0x00, 0xf2, 0x00, 0xf0, 0x00, 0x16, 0x18, 0xe4, 0x00, 0xfc,
 
4873         0x01, 0x00, 0x48, 0xe4, 0xbe, 0x18, 0x18, 0x80, 0x03, 0xf6, 0x02, 0x00,
 
4874         0x00, 0xfa, 0xff, 0xff, 0x28, 0x0e, 0x9e, 0xe7, 0xff, 0x00, 0x82, 0xe7,
 
4875         0x00, 0xea, 0x00, 0xf6, 0x01, 0xe6, 0x09, 0xe7, 0x55, 0xf0, 0x01, 0xf6,
 
4876         0x01, 0xfa, 0x08, 0x00, 0x03, 0x00, 0x04, 0x00, 0x18, 0xf4, 0x10, 0x00,
 
4877         0x00, 0xec, 0x85, 0xf0, 0xbc, 0x00, 0xd5, 0xf0, 0x8e, 0x0c, 0x38, 0x54,
 
4878         0x00, 0xe6, 0x1e, 0xf0, 0x86, 0xf0, 0xb4, 0x00, 0x98, 0x57, 0xd0, 0x01,
 
4879         0x0c, 0x1c, 0x3e, 0x1c, 0x0c, 0x00, 0xbb, 0x00, 0xaa, 0x18, 0x02, 0x80,
 
4880         0x32, 0xf0, 0x01, 0xfc, 0x88, 0x0c, 0xc6, 0x12, 0x02, 0x13, 0x18, 0x40,
 
4881         0x00, 0x57, 0x01, 0xea, 0x3c, 0x00, 0x6c, 0x01, 0x6e, 0x01, 0x04, 0x12,
 
4882         0x3e, 0x57, 0x00, 0x80, 0x03, 0xe6, 0xb6, 0x00, 0xc0, 0x00, 0x01, 0x01,
 
4883         0x3e, 0x01, 0xda, 0x0f, 0x22, 0x10, 0x08, 0x12, 0x02, 0x4a, 0xb9, 0x54,
 
4884         0x03, 0x58, 0x1b, 0x80, 0x30, 0xe4, 0x4b, 0xe4, 0x20, 0x00, 0x32, 0x00,
 
4885         0x3e, 0x00, 0x80, 0x00, 0x24, 0x01, 0x3c, 0x01, 0x68, 0x01, 0x6a, 0x01,
 
4886         0x70, 0x01, 0x72, 0x01, 0x74, 0x01, 0x76, 0x01, 0x78, 0x01, 0x62, 0x0a,
 
4887         0x92, 0x0c, 0x2c, 0x10, 0x2e, 0x10, 0x06, 0x13, 0x4c, 0x1c, 0xbb, 0x55,
 
4888         0x3c, 0x56, 0x04, 0x80, 0x4a, 0xe4, 0x02, 0xee, 0x5b, 0xf0, 0xb1, 0xf0,
 
4889         0x03, 0xf7, 0x06, 0xf7, 0x03, 0xfc, 0x0f, 0x00, 0x40, 0x00, 0xbe, 0x00,
 
4890         0x00, 0x01, 0xb0, 0x08, 0x30, 0x13, 0x64, 0x15, 0x32, 0x1c, 0x38, 0x1c,
 
4891         0x4e, 0x1c, 0x10, 0x44, 0x02, 0x48, 0x00, 0x4c, 0x04, 0xea, 0x5d, 0xf0,
 
4892         0x04, 0xf6, 0x02, 0xfc, 0x05, 0x00, 0x34, 0x00, 0x36, 0x00, 0x98, 0x00,
 
4893         0xcc, 0x00, 0x20, 0x01, 0x4e, 0x01, 0x4e, 0x0b, 0x1e, 0x0e, 0x0c, 0x10,
 
4894         0x0a, 0x12, 0x04, 0x13, 0x40, 0x13, 0x30, 0x1c, 0x00, 0x4e, 0xbd, 0x56,
 
4895         0x06, 0x83, 0x00, 0xdc, 0x05, 0xf0, 0x09, 0xf0, 0x59, 0xf0, 0xa7, 0xf0,
 
4896         0xb8, 0xf0, 0x0e, 0xf7, 0x06, 0x00, 0x19, 0x00, 0x33, 0x00, 0x9b, 0x00,
 
4897         0xa4, 0x00, 0xb5, 0x00, 0xba, 0x00, 0xd0, 0x00, 0xe1, 0x00, 0xe7, 0x00,
 
4898         0xde, 0x03, 0x56, 0x0a, 0x14, 0x0e, 0x02, 0x10, 0x04, 0x10, 0x0a, 0x10,
 
4899         0x36, 0x10, 0x0a, 0x13, 0x12, 0x13, 0x52, 0x13, 0x10, 0x15, 0x14, 0x15,
 
4900         0xac, 0x16, 0x20, 0x1c, 0x34, 0x1c, 0x36, 0x1c, 0x08, 0x44, 0x38, 0x44,
 
4901         0x91, 0x44, 0x0a, 0x45, 0x48, 0x46, 0x01, 0x48, 0x68, 0x54, 0x83, 0x55,
 
4902         0xb0, 0x57, 0x01, 0x58, 0x83, 0x59, 0x05, 0xe6, 0x0b, 0xf0, 0x0c, 0xf0,
 
4903         0x5c, 0xf0, 0x4b, 0xf4, 0x04, 0xf8, 0x05, 0xf8, 0x02, 0xfa, 0x03, 0xfa,
 
4904         0x04, 0xfc, 0x05, 0xfc, 0x07, 0x00, 0x0a, 0x00, 0x0d, 0x00, 0x1c, 0x00,
 
4905         0x9e, 0x00, 0xa8, 0x00, 0xaa, 0x00, 0xb9, 0x00, 0xe0, 0x00, 0x22, 0x01,
 
4906         0x26, 0x01, 0x79, 0x01, 0x7a, 0x01, 0xc0, 0x01, 0xc2, 0x01, 0x7c, 0x02,
 
4907         0x5a, 0x03, 0xea, 0x04, 0xe8, 0x07, 0x68, 0x08, 0x69, 0x08, 0xba, 0x08,
 
4908         0xe9, 0x09, 0x06, 0x0b, 0x3a, 0x0e, 0x00, 0x10, 0x1a, 0x10, 0xed, 0x10,
 
4909         0xf1, 0x10, 0x06, 0x12, 0x0c, 0x13, 0x16, 0x13, 0x1e, 0x13, 0x82, 0x13,
 
4910         0x42, 0x14, 0xd6, 0x14, 0x8a, 0x15, 0xc6, 0x17, 0xd2, 0x17, 0x6b, 0x18,
 
4911         0x12, 0x1c, 0x46, 0x1c, 0x9c, 0x32, 0x00, 0x40, 0x0e, 0x47, 0x48, 0x47,
 
4912         0x41, 0x48, 0x89, 0x48, 0x80, 0x4c, 0x00, 0x54, 0x44, 0x55, 0xe5, 0x55,
 
4913         0x14, 0x56, 0x77, 0x57, 0xbf, 0x57, 0x40, 0x5c, 0x06, 0x80, 0x08, 0x90,
 
4914         0x03, 0xa1, 0xfe, 0x9c, 0xf0, 0x29, 0x02, 0xfe, 0xb8, 0x0c, 0xff, 0x10,
 
4915         0x00, 0x00, 0xd0, 0xfe, 0xcc, 0x18, 0x00, 0xcf, 0xfe, 0x80, 0x01, 0xff,
 
4916         0x03, 0x00, 0x00, 0xfe, 0x93, 0x15, 0xfe, 0x0f, 0x05, 0xff, 0x38, 0x00,
 
4917         0x00, 0xfe, 0x57, 0x24, 0x00, 0xfe, 0x48, 0x00, 0x4f, 0xff, 0x04, 0x00,
 
4918         0x00, 0x10, 0xff, 0x09, 0x00, 0x00, 0xff, 0x08, 0x01, 0x01, 0xff, 0x08,
 
4919         0xff, 0xff, 0xff, 0x27, 0x00, 0x00, 0xff, 0x10, 0xff, 0xff, 0xff, 0x0f,
 
4920         0x00, 0x00, 0xfe, 0x78, 0x56, 0xfe, 0x34, 0x12, 0xff, 0x21, 0x00, 0x00,
 
4921         0xfe, 0x04, 0xf7, 0xcf, 0x2a, 0x67, 0x0b, 0x01, 0xfe, 0xce, 0x0e, 0xfe,
 
4922         0x04, 0xf7, 0xcf, 0x67, 0x0b, 0x3c, 0x2a, 0xfe, 0x3d, 0xf0, 0xfe, 0x02,
 
4923         0x02, 0xfe, 0x20, 0xf0, 0x9c, 0xfe, 0x91, 0xf0, 0xfe, 0xf0, 0x01, 0xfe,
 
4924         0x90, 0xf0, 0xfe, 0xf0, 0x01, 0xfe, 0x8f, 0xf0, 0x9c, 0x05, 0x51, 0x3b,
 
4925         0x02, 0xfe, 0xd4, 0x0c, 0x01, 0xfe, 0x44, 0x0d, 0xfe, 0xdd, 0x12, 0xfe,
 
4926         0xfc, 0x10, 0xfe, 0x28, 0x1c, 0x05, 0xfe, 0xa6, 0x00, 0xfe, 0xd3, 0x12,
 
4927         0x47, 0x18, 0xfe, 0xa6, 0x00, 0xb5, 0xfe, 0x48, 0xf0, 0xfe, 0x86, 0x02,
 
4928         0xfe, 0x49, 0xf0, 0xfe, 0xa0, 0x02, 0xfe, 0x4a, 0xf0, 0xfe, 0xbe, 0x02,
 
4929         0xfe, 0x46, 0xf0, 0xfe, 0x50, 0x02, 0xfe, 0x47, 0xf0, 0xfe, 0x56, 0x02,
 
4930         0xfe, 0x43, 0xf0, 0xfe, 0x44, 0x02, 0xfe, 0x44, 0xf0, 0xfe, 0x48, 0x02,
 
4931         0xfe, 0x45, 0xf0, 0xfe, 0x4c, 0x02, 0x17, 0x0b, 0xa0, 0x17, 0x06, 0x18,
 
4932         0x96, 0x02, 0x29, 0xfe, 0x00, 0x1c, 0xde, 0xfe, 0x02, 0x1c, 0xdd, 0xfe,
 
4933         0x1e, 0x1c, 0xfe, 0xe9, 0x10, 0x01, 0xfe, 0x20, 0x17, 0xfe, 0xe7, 0x10,
 
4934         0xfe, 0x06, 0xfc, 0xc7, 0x0a, 0x6b, 0x01, 0x9e, 0x02, 0x29, 0x14, 0x4d,
 
4935         0x37, 0x97, 0x01, 0xfe, 0x64, 0x0f, 0x0a, 0x6b, 0x01, 0x82, 0xfe, 0xbd,
 
4936         0x10, 0x0a, 0x6b, 0x01, 0x82, 0xfe, 0xad, 0x10, 0xfe, 0x16, 0x1c, 0xfe,
 
4937         0x58, 0x1c, 0x17, 0x06, 0x18, 0x96, 0x2a, 0x25, 0x29, 0xfe, 0x3d, 0xf0,
 
4938         0xfe, 0x02, 0x02, 0x21, 0xfe, 0x94, 0x02, 0xfe, 0x5a, 0x1c, 0xea, 0xfe,
 
4939         0x14, 0x1c, 0x14, 0xfe, 0x30, 0x00, 0x37, 0x97, 0x01, 0xfe, 0x54, 0x0f,
 
4940         0x17, 0x06, 0x18, 0x96, 0x02, 0xd0, 0x1e, 0x20, 0x07, 0x10, 0x34, 0xfe,
 
4941         0x69, 0x10, 0x17, 0x06, 0x18, 0x96, 0xfe, 0x04, 0xec, 0x20, 0x46, 0x3d,
 
4942         0x12, 0x20, 0xfe, 0x05, 0xf6, 0xc7, 0x01, 0xfe, 0x52, 0x16, 0x09, 0x4a,
 
4943         0x4c, 0x35, 0x11, 0x2d, 0x3c, 0x8a, 0x01, 0xe6, 0x02, 0x29, 0x0a, 0x40,
 
4944         0x01, 0x0e, 0x07, 0x00, 0x5d, 0x01, 0x6f, 0xfe, 0x18, 0x10, 0xfe, 0x41,
 
4945         0x58, 0x0a, 0x99, 0x01, 0x0e, 0xfe, 0xc8, 0x54, 0x64, 0xfe, 0x0c, 0x03,
 
4946         0x01, 0xe6, 0x02, 0x29, 0x2a, 0x46, 0xfe, 0x02, 0xe8, 0x27, 0xf8, 0xfe,
 
4947         0x9e, 0x43, 0xf7, 0xfe, 0x27, 0xf0, 0xfe, 0xdc, 0x01, 0xfe, 0x07, 0x4b,
 
4948         0xfe, 0x20, 0xf0, 0x9c, 0xfe, 0x40, 0x1c, 0x25, 0xd2, 0xfe, 0x26, 0xf0,
 
4949         0xfe, 0x56, 0x03, 0xfe, 0xa0, 0xf0, 0xfe, 0x44, 0x03, 0xfe, 0x11, 0xf0,
 
4950         0x9c, 0xfe, 0xef, 0x10, 0xfe, 0x9f, 0xf0, 0xfe, 0x64, 0x03, 0xeb, 0x0f,
 
4951         0xfe, 0x11, 0x00, 0x02, 0x5a, 0x2a, 0xfe, 0x48, 0x1c, 0xeb, 0x09, 0x04,
 
4952         0x1d, 0xfe, 0x18, 0x13, 0x23, 0x1e, 0x98, 0xac, 0x12, 0x98, 0x0a, 0x40,
 
4953         0x01, 0x0e, 0xac, 0x75, 0x01, 0xfe, 0xbc, 0x15, 0x11, 0xca, 0x25, 0xd2,
 
4954         0xfe, 0x01, 0xf0, 0xd2, 0xfe, 0x82, 0xf0, 0xfe, 0x92, 0x03, 0xec, 0x11,
 
4955         0xfe, 0xe4, 0x00, 0x65, 0xfe, 0xa4, 0x03, 0x25, 0x32, 0x1f, 0xfe, 0xb4,
 
4956         0x03, 0x01, 0x43, 0xfe, 0x06, 0xf0, 0xfe, 0xc4, 0x03, 0x8d, 0x81, 0xfe,
 
4957         0x0a, 0xf0, 0xfe, 0x7a, 0x06, 0x02, 0x22, 0x05, 0x6b, 0x28, 0x16, 0xfe,
 
4958         0xf6, 0x04, 0x14, 0x2c, 0x01, 0x33, 0x8f, 0xfe, 0x66, 0x02, 0x02, 0xd1,
 
4959         0xeb, 0x2a, 0x67, 0x1a, 0xfe, 0x67, 0x1b, 0xf8, 0xf7, 0xfe, 0x48, 0x1c,
 
4960         0x70, 0x01, 0x6e, 0x87, 0x0a, 0x40, 0x01, 0x0e, 0x07, 0x00, 0x16, 0xd3,
 
4961         0x0a, 0xca, 0x01, 0x0e, 0x74, 0x60, 0x59, 0x76, 0x27, 0x05, 0x6b, 0x28,
 
4962         0xfe, 0x10, 0x12, 0x14, 0x2c, 0x01, 0x33, 0x8f, 0xfe, 0x66, 0x02, 0x02,
 
4963         0xd1, 0xbc, 0x7d, 0xbd, 0x7f, 0x25, 0x22, 0x65, 0xfe, 0x3c, 0x04, 0x1f,
 
4964         0xfe, 0x38, 0x04, 0x68, 0xfe, 0xa0, 0x00, 0xfe, 0x9b, 0x57, 0xfe, 0x4e,
 
4965         0x12, 0x2b, 0xff, 0x02, 0x00, 0x10, 0x01, 0x08, 0x1f, 0xfe, 0xe0, 0x04,
 
4966         0x2b, 0x01, 0x08, 0x1f, 0x22, 0x30, 0x2e, 0xd5, 0xfe, 0x4c, 0x44, 0xfe,
 
4967         0x4c, 0x12, 0x60, 0xfe, 0x44, 0x48, 0x13, 0x2c, 0xfe, 0x4c, 0x54, 0x64,
 
4968         0xd3, 0x46, 0x76, 0x27, 0xfa, 0xef, 0xfe, 0x62, 0x13, 0x09, 0x04, 0x1d,
 
4969         0xfe, 0x2a, 0x13, 0x2f, 0x07, 0x7e, 0xa5, 0xfe, 0x20, 0x10, 0x13, 0x2c,
 
4970         0xfe, 0x4c, 0x54, 0x64, 0xd3, 0xfa, 0xef, 0x86, 0x09, 0x04, 0x1d, 0xfe,
 
4971         0x08, 0x13, 0x2f, 0x07, 0x7e, 0x6e, 0x09, 0x04, 0x1d, 0xfe, 0x1c, 0x12,
 
4972         0x14, 0x92, 0x09, 0x04, 0x06, 0x3b, 0x14, 0xc4, 0x01, 0x33, 0x8f, 0xfe,
 
4973         0x70, 0x0c, 0x02, 0x22, 0x2b, 0x11, 0xfe, 0xe6, 0x00, 0xfe, 0x1c, 0x90,
 
4974         0xf9, 0x03, 0x14, 0x92, 0x01, 0x33, 0x02, 0x29, 0xfe, 0x42, 0x5b, 0x67,
 
4975         0x1a, 0xfe, 0x46, 0x59, 0xf8, 0xf7, 0xfe, 0x87, 0x80, 0xfe, 0x31, 0xe4,
 
4976         0x4f, 0x09, 0x04, 0x0b, 0xfe, 0x78, 0x13, 0xfe, 0x20, 0x80, 0x07, 0x1a,
 
4977         0xfe, 0x70, 0x12, 0x49, 0x04, 0x06, 0xfe, 0x60, 0x13, 0x05, 0xfe, 0xa2,
 
4978         0x00, 0x28, 0x16, 0xfe, 0x80, 0x05, 0xfe, 0x31, 0xe4, 0x6a, 0x49, 0x04,
 
4979         0x0b, 0xfe, 0x4a, 0x13, 0x05, 0xfe, 0xa0, 0x00, 0x28, 0xfe, 0x42, 0x12,
 
4980         0x5e, 0x01, 0x08, 0x25, 0x32, 0xf1, 0x01, 0x08, 0x26, 0xfe, 0x98, 0x05,
 
4981         0x11, 0xfe, 0xe3, 0x00, 0x23, 0x49, 0xfe, 0x4a, 0xf0, 0xfe, 0x6a, 0x05,
 
4982         0xfe, 0x49, 0xf0, 0xfe, 0x64, 0x05, 0x83, 0x24, 0xfe, 0x21, 0x00, 0xa1,
 
4983         0x24, 0xfe, 0x22, 0x00, 0xa0, 0x24, 0x4c, 0xfe, 0x09, 0x48, 0x01, 0x08,
 
4984         0x26, 0xfe, 0x98, 0x05, 0xfe, 0xe2, 0x08, 0x49, 0x04, 0xc5, 0x3b, 0x01,
 
4985         0x86, 0x24, 0x06, 0x12, 0xcc, 0x37, 0xfe, 0x27, 0x01, 0x09, 0x04, 0x1d,
 
4986         0xfe, 0x22, 0x12, 0x47, 0x01, 0xa7, 0x14, 0x92, 0x09, 0x04, 0x06, 0x3b,
 
4987         0x14, 0xc4, 0x01, 0x33, 0x8f, 0xfe, 0x70, 0x0c, 0x02, 0x22, 0x05, 0xfe,
 
4988         0x9c, 0x00, 0x28, 0xfe, 0x3e, 0x12, 0x05, 0x50, 0x28, 0xfe, 0x36, 0x13,
 
4989         0x47, 0x01, 0xa7, 0x26, 0xfe, 0x08, 0x06, 0x0a, 0x06, 0x49, 0x04, 0x19,
 
4990         0xfe, 0x02, 0x12, 0x5f, 0x01, 0xfe, 0xaa, 0x14, 0x1f, 0xfe, 0xfe, 0x05,
 
4991         0x11, 0x9a, 0x01, 0x43, 0x11, 0xfe, 0xe5, 0x00, 0x05, 0x50, 0xb4, 0x0c,
 
4992         0x50, 0x05, 0xc6, 0x28, 0xfe, 0x62, 0x12, 0x05, 0x3f, 0x28, 0xfe, 0x5a,
 
4993         0x13, 0x01, 0xfe, 0x14, 0x18, 0x01, 0xfe, 0x66, 0x18, 0xfe, 0x43, 0x48,
 
4994         0xb7, 0x19, 0x13, 0x6c, 0xff, 0x02, 0x00, 0x57, 0x48, 0x8b, 0x1c, 0x3d,
 
4995         0x85, 0xb7, 0x69, 0x47, 0x01, 0xa7, 0x26, 0xfe, 0x72, 0x06, 0x49, 0x04,
 
4996         0x1b, 0xdf, 0x89, 0x0a, 0x4d, 0x01, 0xfe, 0xd8, 0x14, 0x1f, 0xfe, 0x68,
 
4997         0x06, 0x11, 0x9a, 0x01, 0x43, 0x11, 0xfe, 0xe5, 0x00, 0x05, 0x3f, 0xb4,
 
4998         0x0c, 0x3f, 0x17, 0x06, 0x01, 0xa7, 0xec, 0x72, 0x70, 0x01, 0x6e, 0x87,
 
4999         0x11, 0xfe, 0xe2, 0x00, 0x01, 0x08, 0x25, 0x32, 0xfe, 0x0a, 0xf0, 0xfe,
 
5000         0xa6, 0x06, 0x8c, 0xfe, 0x5c, 0x07, 0xfe, 0x06, 0xf0, 0xfe, 0x64, 0x07,
 
5001         0x8d, 0x81, 0x02, 0x22, 0x09, 0x04, 0x0b, 0xfe, 0x2e, 0x12, 0x15, 0x1a,
 
5002         0x01, 0x08, 0x15, 0x00, 0x01, 0x08, 0x15, 0x00, 0x01, 0x08, 0x15, 0x00,
 
5003         0x01, 0x08, 0xfe, 0x99, 0xa4, 0x01, 0x08, 0x15, 0x00, 0x02, 0xfe, 0x32,
 
5004         0x08, 0x61, 0x04, 0x1b, 0xfe, 0x38, 0x12, 0x09, 0x04, 0x1b, 0x6e, 0x15,
 
5005         0xfe, 0x1b, 0x00, 0x01, 0x08, 0x15, 0x00, 0x01, 0x08, 0x15, 0x00, 0x01,
 
5006         0x08, 0x15, 0x00, 0x01, 0x08, 0x15, 0x06, 0x01, 0x08, 0x15, 0x00, 0x02,
 
5007         0xd9, 0x66, 0x4c, 0xfe, 0x3a, 0x55, 0x5f, 0xfe, 0x9a, 0x81, 0x4b, 0x1d,
 
5008         0xba, 0xfe, 0x32, 0x07, 0x0a, 0x1d, 0xfe, 0x09, 0x6f, 0xaf, 0xfe, 0xca,
 
5009         0x45, 0xfe, 0x32, 0x12, 0x62, 0x2c, 0x85, 0x66, 0x7b, 0x01, 0x08, 0x25,
 
5010         0x32, 0xfe, 0x0a, 0xf0, 0xfe, 0x32, 0x07, 0x8d, 0x81, 0x8c, 0xfe, 0x5c,
 
5011         0x07, 0x02, 0x22, 0x01, 0x43, 0x02, 0xfe, 0x8a, 0x06, 0x15, 0x19, 0x02,
 
5012         0xfe, 0x8a, 0x06, 0xfe, 0x9c, 0xf7, 0xd4, 0xfe, 0x2c, 0x90, 0xfe, 0xae,
 
5013         0x90, 0x77, 0xfe, 0xca, 0x07, 0x0c, 0x54, 0x18, 0x55, 0x09, 0x4a, 0x6a,
 
5014         0x35, 0x1e, 0x20, 0x07, 0x10, 0xfe, 0x0e, 0x12, 0x74, 0xfe, 0x80, 0x80,
 
5015         0x37, 0x20, 0x63, 0x27, 0xfe, 0x06, 0x10, 0xfe, 0x83, 0xe7, 0xc4, 0xa1,
 
5016         0xfe, 0x03, 0x40, 0x09, 0x4a, 0x4f, 0x35, 0x01, 0xa8, 0xad, 0xfe, 0x1f,
 
5017         0x40, 0x12, 0x58, 0x01, 0xa5, 0xfe, 0x08, 0x50, 0xfe, 0x8a, 0x50, 0xfe,
 
5018         0x44, 0x51, 0xfe, 0xc6, 0x51, 0x83, 0xfb, 0xfe, 0x8a, 0x90, 0x0c, 0x52,
 
5019         0x18, 0x53, 0xfe, 0x0c, 0x90, 0xfe, 0x8e, 0x90, 0xfe, 0x40, 0x50, 0xfe,
 
5020         0xc2, 0x50, 0x0c, 0x39, 0x18, 0x3a, 0xfe, 0x4a, 0x10, 0x09, 0x04, 0x6a,
 
5021         0xfe, 0x2a, 0x12, 0xfe, 0x2c, 0x90, 0xfe, 0xae, 0x90, 0x0c, 0x54, 0x18,
 
5022         0x55, 0x09, 0x04, 0x4f, 0x85, 0x01, 0xa8, 0xfe, 0x1f, 0x80, 0x12, 0x58,
 
5023         0xfe, 0x44, 0x90, 0xfe, 0xc6, 0x90, 0x0c, 0x56, 0x18, 0x57, 0xfb, 0xfe,
 
5024         0x8a, 0x90, 0x0c, 0x52, 0x18, 0x53, 0xfe, 0x40, 0x90, 0xfe, 0xc2, 0x90,
 
5025         0x0c, 0x39, 0x18, 0x3a, 0x0c, 0x38, 0x18, 0x4e, 0x09, 0x4a, 0x19, 0x35,
 
5026         0x2a, 0x13, 0xfe, 0x4e, 0x11, 0x65, 0xfe, 0x48, 0x08, 0xfe, 0x9e, 0xf0,
 
5027         0xfe, 0x5c, 0x08, 0xb1, 0x16, 0x32, 0x2a, 0x73, 0xdd, 0xb8, 0xfe, 0x80,
 
5028         0x08, 0xb9, 0xfe, 0x9e, 0x08, 0x8c, 0xfe, 0x74, 0x08, 0xfe, 0x06, 0xf0,
 
5029         0xfe, 0x7a, 0x08, 0x8d, 0x81, 0x02, 0x22, 0x01, 0x43, 0xfe, 0xc9, 0x10,
 
5030         0x15, 0x19, 0xfe, 0xc9, 0x10, 0x61, 0x04, 0x06, 0xfe, 0x10, 0x12, 0x61,
 
5031         0x04, 0x0b, 0x45, 0x09, 0x04, 0x0b, 0xfe, 0x68, 0x12, 0xfe, 0x2e, 0x1c,
 
5032         0x02, 0xfe, 0x24, 0x0a, 0x61, 0x04, 0x06, 0x45, 0x61, 0x04, 0x0b, 0xfe,
 
5033         0x52, 0x12, 0xfe, 0x2c, 0x1c, 0xfe, 0xaa, 0xf0, 0xfe, 0x1e, 0x09, 0xfe,
 
5034         0xac, 0xf0, 0xfe, 0xbe, 0x08, 0xfe, 0x8a, 0x10, 0xaa, 0xfe, 0xf3, 0x10,
 
5035         0xfe, 0xad, 0xf0, 0xfe, 0xca, 0x08, 0x02, 0xfe, 0x24, 0x0a, 0xab, 0xfe,
 
5036         0xe7, 0x10, 0xfe, 0x2b, 0xf0, 0x9d, 0xe9, 0x1c, 0xfe, 0x00, 0xfe, 0xfe,
 
5037         0x1c, 0x12, 0xb5, 0xfe, 0xd2, 0xf0, 0x9d, 0xfe, 0x76, 0x18, 0x1c, 0x1a,
 
5038         0x16, 0x9d, 0x05, 0xcb, 0x1c, 0x06, 0x16, 0x9d, 0xb8, 0x6d, 0xb9, 0x6d,
 
5039         0xaa, 0xab, 0xfe, 0xb1, 0x10, 0x70, 0x5e, 0x2b, 0x14, 0x92, 0x01, 0x33,
 
5040         0x0f, 0xfe, 0x35, 0x00, 0xfe, 0x01, 0xf0, 0x5a, 0x0f, 0x7c, 0x02, 0x5a,
 
5041         0xfe, 0x74, 0x18, 0x1c, 0xfe, 0x00, 0xf8, 0x16, 0x6d, 0x67, 0x1b, 0x01,
 
5042         0xfe, 0x44, 0x0d, 0x3b, 0x01, 0xe6, 0x1e, 0x27, 0x74, 0x67, 0x1a, 0x02,
 
5043         0x6d, 0x09, 0x04, 0x0b, 0x21, 0xfe, 0x06, 0x0a, 0x09, 0x04, 0x6a, 0xfe,
 
5044         0x82, 0x12, 0x09, 0x04, 0x19, 0xfe, 0x66, 0x13, 0x1e, 0x58, 0xac, 0xfc,
 
5045         0xfe, 0x83, 0x80, 0xfe, 0xc8, 0x44, 0xfe, 0x2e, 0x13, 0xfe, 0x04, 0x91,
 
5046         0xfe, 0x86, 0x91, 0x63, 0x27, 0xfe, 0x40, 0x59, 0xfe, 0xc1, 0x59, 0x77,
 
5047         0xd7, 0x05, 0x54, 0x31, 0x55, 0x0c, 0x7b, 0x18, 0x7c, 0xbe, 0x54, 0xbf,
 
5048         0x55, 0x01, 0xa8, 0xad, 0x63, 0x27, 0x12, 0x58, 0xc0, 0x38, 0xc1, 0x4e,
 
5049         0x79, 0x56, 0x68, 0x57, 0xf4, 0xf5, 0xfe, 0x04, 0xfa, 0x38, 0xfe, 0x05,
 
5050         0xfa, 0x4e, 0x01, 0xa5, 0xa2, 0x23, 0x0c, 0x7b, 0x0c, 0x7c, 0x79, 0x56,
 
5051         0x68, 0x57, 0xfe, 0x12, 0x10, 0x09, 0x04, 0x19, 0x16, 0xd7, 0x79, 0x39,
 
5052         0x68, 0x3a, 0x09, 0x04, 0xfe, 0xf7, 0x00, 0x35, 0x05, 0x52, 0x31, 0x53,
 
5053         0xfe, 0x10, 0x58, 0xfe, 0x91, 0x58, 0xfe, 0x14, 0x59, 0xfe, 0x95, 0x59,
 
5054         0x02, 0x6d, 0x09, 0x04, 0x19, 0x16, 0xd7, 0x09, 0x04, 0xfe, 0xf7, 0x00,
 
5055         0x35, 0xfe, 0x3a, 0x55, 0xfe, 0x19, 0x81, 0x5f, 0xfe, 0x10, 0x90, 0xfe,
 
5056         0x92, 0x90, 0xfe, 0xd7, 0x10, 0x2f, 0x07, 0x9b, 0x16, 0xfe, 0xc6, 0x08,
 
5057         0x11, 0x9b, 0x09, 0x04, 0x0b, 0xfe, 0x14, 0x13, 0x05, 0x39, 0x31, 0x3a,
 
5058         0x77, 0xfe, 0xc6, 0x08, 0xfe, 0x0c, 0x58, 0xfe, 0x8d, 0x58, 0x02, 0x6d,
 
5059         0x23, 0x47, 0xfe, 0x19, 0x80, 0xde, 0x09, 0x04, 0x0b, 0xfe, 0x1a, 0x12,
 
5060         0xfe, 0x6c, 0x19, 0xfe, 0x19, 0x41, 0xe9, 0xb5, 0xfe, 0xd1, 0xf0, 0xd9,
 
5061         0x14, 0x7a, 0x01, 0x33, 0x0f, 0xfe, 0x44, 0x00, 0xfe, 0x8e, 0x10, 0xfe,
 
5062         0x6c, 0x19, 0xbe, 0x39, 0xfe, 0xed, 0x19, 0xbf, 0x3a, 0xfe, 0x0c, 0x51,
 
5063         0xfe, 0x8e, 0x51, 0xe9, 0x1c, 0xfe, 0x00, 0xff, 0x34, 0xfe, 0x74, 0x10,
 
5064         0xb5, 0xfe, 0xd2, 0xf0, 0xfe, 0xb2, 0x0a, 0xfe, 0x76, 0x18, 0x1c, 0x1a,
 
5065         0x84, 0x05, 0xcb, 0x1c, 0x06, 0xfe, 0x08, 0x13, 0x0f, 0xfe, 0x16, 0x00,
 
5066         0x02, 0x5a, 0xfe, 0xd1, 0xf0, 0xfe, 0xc4, 0x0a, 0x14, 0x7a, 0x01, 0x33,
 
5067         0x0f, 0xfe, 0x17, 0x00, 0xfe, 0x42, 0x10, 0xfe, 0xce, 0xf0, 0xfe, 0xca,
 
5068         0x0a, 0xfe, 0x3c, 0x10, 0xfe, 0xcd, 0xf0, 0xfe, 0xd6, 0x0a, 0x0f, 0xfe,
 
5069         0x22, 0x00, 0x02, 0x5a, 0xfe, 0xcb, 0xf0, 0xfe, 0xe2, 0x0a, 0x0f, 0xfe,
 
5070         0x24, 0x00, 0x02, 0x5a, 0xfe, 0xd0, 0xf0, 0xfe, 0xec, 0x0a, 0x0f, 0x93,
 
5071         0xdc, 0xfe, 0xcf, 0xf0, 0xfe, 0xf6, 0x0a, 0x0f, 0x4c, 0xfe, 0x10, 0x10,
 
5072         0xfe, 0xcc, 0xf0, 0xd9, 0x61, 0x04, 0x19, 0x3b, 0x0f, 0xfe, 0x12, 0x00,
 
5073         0x2a, 0x13, 0xfe, 0x4e, 0x11, 0x65, 0xfe, 0x0c, 0x0b, 0xfe, 0x9e, 0xf0,
 
5074         0xfe, 0x20, 0x0b, 0xb1, 0x16, 0x32, 0x2a, 0x73, 0xdd, 0xb8, 0x22, 0xb9,
 
5075         0x22, 0x2a, 0xec, 0x65, 0xfe, 0x2c, 0x0b, 0x25, 0x32, 0x8c, 0xfe, 0x48,
 
5076         0x0b, 0x8d, 0x81, 0xb8, 0xd4, 0xb9, 0xd4, 0x02, 0x22, 0x01, 0x43, 0xfe,
 
5077         0xdb, 0x10, 0x11, 0xfe, 0xe8, 0x00, 0xaa, 0xab, 0x70, 0xbc, 0x7d, 0xbd,
 
5078         0x7f, 0xfe, 0x89, 0xf0, 0x22, 0x30, 0x2e, 0xd8, 0xbc, 0x7d, 0xbd, 0x7f,
 
5079         0x01, 0x08, 0x1f, 0x22, 0x30, 0x2e, 0xd6, 0xb1, 0x45, 0x0f, 0xfe, 0x42,
 
5080         0x00, 0x02, 0x5a, 0x78, 0x06, 0xfe, 0x81, 0x49, 0x16, 0xfe, 0x38, 0x0c,
 
5081         0x09, 0x04, 0x0b, 0xfe, 0x44, 0x13, 0x0f, 0x00, 0x4b, 0x0b, 0xfe, 0x54,
 
5082         0x12, 0x4b, 0xfe, 0x28, 0x00, 0x21, 0xfe, 0xa6, 0x0c, 0x0a, 0x40, 0x01,
 
5083         0x0e, 0x07, 0x00, 0x5d, 0x3e, 0xfe, 0x28, 0x00, 0xfe, 0xe2, 0x10, 0x01,
 
5084         0xe7, 0x01, 0xe8, 0x0a, 0x99, 0x01, 0xfe, 0x32, 0x0e, 0x59, 0x11, 0x2d,
 
5085         0x01, 0x6f, 0x02, 0x29, 0x0f, 0xfe, 0x44, 0x00, 0x4b, 0x0b, 0xdf, 0x3e,
 
5086         0x0b, 0xfe, 0xb4, 0x10, 0x01, 0x86, 0x3e, 0x0b, 0xfe, 0xaa, 0x10, 0x01,
 
5087         0x86, 0xfe, 0x19, 0x82, 0xfe, 0x34, 0x46, 0xa3, 0x3e, 0x0b, 0x0f, 0xfe,
 
5088         0x43, 0x00, 0xfe, 0x96, 0x10, 0x09, 0x4a, 0x0b, 0x35, 0x01, 0xe7, 0x01,
 
5089         0xe8, 0x59, 0x11, 0x2d, 0x01, 0x6f, 0x67, 0x0b, 0x59, 0x3c, 0x8a, 0x02,
 
5090         0xfe, 0x2a, 0x03, 0x09, 0x04, 0x0b, 0x84, 0x3e, 0x0b, 0x0f, 0x00, 0xfe,
 
5091         0x5c, 0x10, 0x61, 0x04, 0x1b, 0xfe, 0x58, 0x12, 0x09, 0x04, 0x1b, 0xfe,
 
5092         0x50, 0x13, 0xfe, 0x1c, 0x1c, 0xfe, 0x9d, 0xf0, 0xfe, 0x5c, 0x0c, 0xfe,
 
5093         0x1c, 0x1c, 0xfe, 0x9d, 0xf0, 0xfe, 0x62, 0x0c, 0x09, 0x4a, 0x1b, 0x35,
 
5094         0xfe, 0xa9, 0x10, 0x0f, 0xfe, 0x15, 0x00, 0xfe, 0x04, 0xe6, 0x0b, 0x5f,
 
5095         0x5c, 0x0f, 0xfe, 0x13, 0x00, 0xfe, 0x10, 0x10, 0x0f, 0xfe, 0x47, 0x00,
 
5096         0xa1, 0x0f, 0xfe, 0x41, 0x00, 0xa0, 0x0f, 0xfe, 0x24, 0x00, 0x87, 0xaa,
 
5097         0xab, 0x70, 0x05, 0x6b, 0x28, 0x21, 0xd1, 0x5f, 0xfe, 0x04, 0xe6, 0x1b,
 
5098         0xfe, 0x9d, 0x41, 0xfe, 0x1c, 0x42, 0x59, 0x01, 0xda, 0x02, 0x29, 0xea,
 
5099         0x14, 0x0b, 0x37, 0x95, 0xa9, 0x14, 0xfe, 0x31, 0x00, 0x37, 0x97, 0x01,
 
5100         0xfe, 0x54, 0x0f, 0x02, 0xd0, 0x3c, 0xfe, 0x06, 0xec, 0xc9, 0xee, 0x3e,
 
5101         0x1d, 0xfe, 0xce, 0x45, 0x34, 0x3c, 0xfe, 0x06, 0xea, 0xc9, 0xfe, 0x47,
 
5102         0x4b, 0x89, 0xfe, 0x75, 0x57, 0x05, 0x51, 0xfe, 0x98, 0x56, 0xfe, 0x38,
 
5103         0x12, 0x0a, 0x42, 0x01, 0x0e, 0xfe, 0x44, 0x48, 0x46, 0x09, 0x04, 0x1d,
 
5104         0xfe, 0x1a, 0x13, 0x0a, 0x40, 0x01, 0x0e, 0x47, 0xfe, 0x41, 0x58, 0x0a,
 
5105         0x99, 0x01, 0x0e, 0xfe, 0x49, 0x54, 0x8e, 0xfe, 0x2a, 0x0d, 0x02, 0xfe,
 
5106         0x2a, 0x03, 0x0a, 0x51, 0xfe, 0xee, 0x14, 0xee, 0x3e, 0x1d, 0xfe, 0xce,
 
5107         0x45, 0x34, 0x3c, 0xfe, 0xce, 0x47, 0xfe, 0xad, 0x13, 0x02, 0x29, 0x1e,
 
5108         0x20, 0x07, 0x10, 0xfe, 0x9e, 0x12, 0x23, 0x12, 0x4d, 0x12, 0x94, 0x12,
 
5109         0xce, 0x1e, 0x2d, 0x47, 0x37, 0x2d, 0xb1, 0xe0, 0xfe, 0xbc, 0xf0, 0xfe,
 
5110         0xec, 0x0d, 0x13, 0x06, 0x12, 0x4d, 0x01, 0xfe, 0xe2, 0x15, 0x05, 0xfe,
 
5111         0x38, 0x01, 0x31, 0xfe, 0x3a, 0x01, 0x77, 0xfe, 0xf0, 0x0d, 0xfe, 0x02,
 
5112         0xec, 0xce, 0x62, 0x00, 0x5d, 0xfe, 0x04, 0xec, 0x20, 0x46, 0xfe, 0x05,
 
5113         0xf6, 0xfe, 0x34, 0x01, 0x01, 0xfe, 0x52, 0x16, 0xfb, 0xfe, 0x48, 0xf4,
 
5114         0x0d, 0xfe, 0x18, 0x13, 0xaf, 0xfe, 0x02, 0xea, 0xce, 0x62, 0x7a, 0xfe,
 
5115         0xc5, 0x13, 0x14, 0x1b, 0x37, 0x95, 0xa9, 0x5c, 0x05, 0xfe, 0x38, 0x01,
 
5116         0x1c, 0xfe, 0xf0, 0xff, 0x0c, 0xfe, 0x60, 0x01, 0x05, 0xfe, 0x3a, 0x01,
 
5117         0x0c, 0xfe, 0x62, 0x01, 0x3d, 0x12, 0x20, 0x24, 0x06, 0x12, 0x2d, 0x11,
 
5118         0x2d, 0x8a, 0x13, 0x06, 0x03, 0x23, 0x03, 0x1e, 0x4d, 0xfe, 0xf7, 0x12,
 
5119         0x1e, 0x94, 0xac, 0x12, 0x94, 0x07, 0x7a, 0xfe, 0x71, 0x13, 0xfe, 0x24,
 
5120         0x1c, 0x14, 0x1a, 0x37, 0x95, 0xa9, 0xfe, 0xd9, 0x10, 0xb6, 0xfe, 0x03,
 
5121         0xdc, 0xfe, 0x73, 0x57, 0xfe, 0x80, 0x5d, 0x03, 0xb6, 0xfe, 0x03, 0xdc,
 
5122         0xfe, 0x5b, 0x57, 0xfe, 0x80, 0x5d, 0x03, 0xfe, 0x03, 0x57, 0xb6, 0x23,
 
5123         0xfe, 0x00, 0xcc, 0x03, 0xfe, 0x03, 0x57, 0xb6, 0x75, 0x03, 0x09, 0x04,
 
5124         0x4c, 0xfe, 0x22, 0x13, 0xfe, 0x1c, 0x80, 0x07, 0x06, 0xfe, 0x1a, 0x13,
 
5125         0xfe, 0x1e, 0x80, 0xe1, 0xfe, 0x1d, 0x80, 0xa4, 0xfe, 0x0c, 0x90, 0xfe,
 
5126         0x0e, 0x13, 0xfe, 0x0e, 0x90, 0xa3, 0xfe, 0x3c, 0x90, 0xfe, 0x30, 0xf4,
 
5127         0x0b, 0xfe, 0x3c, 0x50, 0xa0, 0x01, 0xfe, 0x82, 0x16, 0x2f, 0x07, 0x2d,
 
5128         0xe0, 0x01, 0xfe, 0xbc, 0x15, 0x09, 0x04, 0x1d, 0x45, 0x01, 0xe7, 0x01,
 
5129         0xe8, 0x11, 0xfe, 0xe9, 0x00, 0x09, 0x04, 0x4c, 0xfe, 0x2c, 0x13, 0x01,
 
5130         0xfe, 0x14, 0x16, 0xfe, 0x1e, 0x1c, 0xfe, 0x14, 0x90, 0xfe, 0x96, 0x90,
 
5131         0x0c, 0xfe, 0x64, 0x01, 0x18, 0xfe, 0x66, 0x01, 0x09, 0x04, 0x4f, 0xfe,
 
5132         0x12, 0x12, 0xfe, 0x03, 0x80, 0x74, 0xfe, 0x01, 0xec, 0x20, 0xfe, 0x80,
 
5133         0x40, 0x12, 0x20, 0x63, 0x27, 0x11, 0xc8, 0x59, 0x1e, 0x20, 0xed, 0x76,
 
5134         0x20, 0x03, 0xfe, 0x08, 0x1c, 0x05, 0xfe, 0xac, 0x00, 0xfe, 0x06, 0x58,
 
5135         0x05, 0xfe, 0xae, 0x00, 0xfe, 0x07, 0x58, 0x05, 0xfe, 0xb0, 0x00, 0xfe,
 
5136         0x08, 0x58, 0x05, 0xfe, 0xb2, 0x00, 0xfe, 0x09, 0x58, 0xfe, 0x0a, 0x1c,
 
5137         0x24, 0x69, 0x12, 0xc9, 0x23, 0x0c, 0x50, 0x0c, 0x3f, 0x13, 0x40, 0x48,
 
5138         0x5f, 0x17, 0x1d, 0xfe, 0x90, 0x4d, 0xfe, 0x91, 0x54, 0x21, 0xfe, 0x08,
 
5139         0x0f, 0x3e, 0x10, 0x13, 0x42, 0x48, 0x17, 0x4c, 0xfe, 0x90, 0x4d, 0xfe,
 
5140         0x91, 0x54, 0x21, 0xfe, 0x1e, 0x0f, 0x24, 0x10, 0x12, 0x20, 0x78, 0x2c,
 
5141         0x46, 0x1e, 0x20, 0xed, 0x76, 0x20, 0x11, 0xc8, 0xf6, 0xfe, 0xd6, 0xf0,
 
5142         0xfe, 0x32, 0x0f, 0xea, 0x70, 0xfe, 0x14, 0x1c, 0xfe, 0x10, 0x1c, 0xfe,
 
5143         0x18, 0x1c, 0x03, 0x3c, 0xfe, 0x0c, 0x14, 0xee, 0xfe, 0x07, 0xe6, 0x1d,
 
5144         0xfe, 0xce, 0x47, 0xfe, 0xf5, 0x13, 0x03, 0x01, 0x86, 0x78, 0x2c, 0x46,
 
5145         0xfa, 0xef, 0xfe, 0x42, 0x13, 0x2f, 0x07, 0x2d, 0xfe, 0x34, 0x13, 0x0a,
 
5146         0x42, 0x01, 0x0e, 0xb0, 0xfe, 0x36, 0x12, 0xf0, 0xfe, 0x45, 0x48, 0x01,
 
5147         0xe3, 0xfe, 0x00, 0xcc, 0xb0, 0xfe, 0xf3, 0x13, 0x3d, 0x75, 0x07, 0x10,
 
5148         0xa3, 0x0a, 0x80, 0x01, 0x0e, 0xfe, 0x80, 0x5c, 0x01, 0x6f, 0xfe, 0x0e,
 
5149         0x10, 0x07, 0x7e, 0x45, 0xf6, 0xfe, 0xd6, 0xf0, 0xfe, 0x6c, 0x0f, 0x03,
 
5150         0xfe, 0x44, 0x58, 0x74, 0xfe, 0x01, 0xec, 0x97, 0xfe, 0x9e, 0x40, 0xfe,
 
5151         0x9d, 0xe7, 0x00, 0xfe, 0x9c, 0xe7, 0x1b, 0x76, 0x27, 0x01, 0xda, 0xfe,
 
5152         0xdd, 0x10, 0x2a, 0xbc, 0x7d, 0xbd, 0x7f, 0x30, 0x2e, 0xd5, 0x07, 0x1b,
 
5153         0xfe, 0x48, 0x12, 0x07, 0x0b, 0xfe, 0x56, 0x12, 0x07, 0x1a, 0xfe, 0x30,
 
5154         0x12, 0x07, 0xc2, 0x16, 0xfe, 0x3e, 0x11, 0x07, 0xfe, 0x23, 0x00, 0x16,
 
5155         0xfe, 0x4a, 0x11, 0x07, 0x06, 0x16, 0xfe, 0xa8, 0x11, 0x07, 0x19, 0xfe,
 
5156         0x12, 0x12, 0x07, 0x00, 0x16, 0x22, 0x14, 0xc2, 0x01, 0x33, 0x9f, 0x2b,
 
5157         0x01, 0x08, 0x8c, 0x43, 0x03, 0x2b, 0xfe, 0x62, 0x08, 0x0a, 0xca, 0x01,
 
5158         0xfe, 0x32, 0x0e, 0x11, 0x7e, 0x02, 0x29, 0x2b, 0x2f, 0x07, 0x9b, 0xfe,
 
5159         0xd9, 0x13, 0x79, 0x39, 0x68, 0x3a, 0x77, 0xfe, 0xfc, 0x10, 0x09, 0x04,
 
5160         0x6a, 0xfe, 0x72, 0x12, 0xc0, 0x38, 0xc1, 0x4e, 0xf4, 0xf5, 0x8e, 0xfe,
 
5161         0xc6, 0x10, 0x1e, 0x58, 0xfe, 0x26, 0x13, 0x05, 0x7b, 0x31, 0x7c, 0x77,
 
5162         0xfe, 0x82, 0x0c, 0x0c, 0x54, 0x18, 0x55, 0x23, 0x0c, 0x7b, 0x0c, 0x7c,
 
5163         0x01, 0xa8, 0x24, 0x69, 0x73, 0x12, 0x58, 0x01, 0xa5, 0xc0, 0x38, 0xc1,
 
5164         0x4e, 0xfe, 0x04, 0x55, 0xfe, 0xa5, 0x55, 0xfe, 0x04, 0xfa, 0x38, 0xfe,
 
5165         0x05, 0xfa, 0x4e, 0xfe, 0x91, 0x10, 0x05, 0x56, 0x31, 0x57, 0xfe, 0x40,
 
5166         0x56, 0xfe, 0xe1, 0x56, 0x0c, 0x56, 0x18, 0x57, 0x83, 0xc0, 0x38, 0xc1,
 
5167         0x4e, 0xf4, 0xf5, 0x05, 0x52, 0x31, 0x53, 0xfe, 0x00, 0x56, 0xfe, 0xa1,
 
5168         0x56, 0x0c, 0x52, 0x18, 0x53, 0x09, 0x04, 0x6a, 0xfe, 0x1e, 0x12, 0x1e,
 
5169         0x58, 0xfe, 0x1f, 0x40, 0x05, 0x54, 0x31, 0x55, 0xfe, 0x2c, 0x50, 0xfe,
 
5170         0xae, 0x50, 0x05, 0x56, 0x31, 0x57, 0xfe, 0x44, 0x50, 0xfe, 0xc6, 0x50,
 
5171         0x05, 0x52, 0x31, 0x53, 0xfe, 0x08, 0x50, 0xfe, 0x8a, 0x50, 0x05, 0x39,
 
5172         0x31, 0x3a, 0xfe, 0x40, 0x50, 0xfe, 0xc2, 0x50, 0x02, 0x5c, 0x24, 0x06,
 
5173         0x12, 0xcd, 0x02, 0x5b, 0x2b, 0x01, 0x08, 0x1f, 0x44, 0x30, 0x2e, 0xd5,
 
5174         0x07, 0x06, 0x21, 0x44, 0x2f, 0x07, 0x9b, 0x21, 0x5b, 0x01, 0x6e, 0x1c,
 
5175         0x3d, 0x16, 0x44, 0x09, 0x04, 0x0b, 0xe2, 0x79, 0x39, 0x68, 0x3a, 0xfe,
 
5176         0x0a, 0x55, 0x34, 0xfe, 0x8b, 0x55, 0xbe, 0x39, 0xbf, 0x3a, 0xfe, 0x0c,
 
5177         0x51, 0xfe, 0x8e, 0x51, 0x02, 0x5b, 0xfe, 0x19, 0x81, 0xaf, 0xfe, 0x19,
 
5178         0x41, 0x02, 0x5b, 0x2b, 0x01, 0x08, 0x25, 0x32, 0x1f, 0xa2, 0x30, 0x2e,
 
5179         0xd8, 0x4b, 0x1a, 0xfe, 0xa6, 0x12, 0x4b, 0x0b, 0x3b, 0x02, 0x44, 0x01,
 
5180         0x08, 0x25, 0x32, 0x1f, 0xa2, 0x30, 0x2e, 0xd6, 0x07, 0x1a, 0x21, 0x44,
 
5181         0x01, 0x08, 0x1f, 0xa2, 0x30, 0x2e, 0xfe, 0xe8, 0x09, 0xfe, 0xc2, 0x49,
 
5182         0x60, 0x05, 0xfe, 0x9c, 0x00, 0x28, 0x84, 0x49, 0x04, 0x19, 0x34, 0x9f,
 
5183         0xfe, 0xbb, 0x45, 0x4b, 0x00, 0x45, 0x3e, 0x06, 0x78, 0x3d, 0xfe, 0xda,
 
5184         0x14, 0x01, 0x6e, 0x87, 0xfe, 0x4b, 0x45, 0xe2, 0x2f, 0x07, 0x9a, 0xe1,
 
5185         0x05, 0xc6, 0x28, 0x84, 0x05, 0x3f, 0x28, 0x34, 0x5e, 0x02, 0x5b, 0xfe,
 
5186         0xc0, 0x5d, 0xfe, 0xf8, 0x14, 0xfe, 0x03, 0x17, 0x05, 0x50, 0xb4, 0x0c,
 
5187         0x50, 0x5e, 0x2b, 0x01, 0x08, 0x26, 0x5c, 0x01, 0xfe, 0xaa, 0x14, 0x02,
 
5188         0x5c, 0x01, 0x08, 0x25, 0x32, 0x1f, 0x44, 0x30, 0x2e, 0xd6, 0x07, 0x06,
 
5189         0x21, 0x44, 0x01, 0xfe, 0x8e, 0x13, 0xfe, 0x42, 0x58, 0xfe, 0x82, 0x14,
 
5190         0xfe, 0xa4, 0x14, 0x87, 0xfe, 0x4a, 0xf4, 0x0b, 0x16, 0x44, 0xfe, 0x4a,
 
5191         0xf4, 0x06, 0xfe, 0x0c, 0x12, 0x2f, 0x07, 0x9a, 0x85, 0x02, 0x5b, 0x05,
 
5192         0x3f, 0xb4, 0x0c, 0x3f, 0x5e, 0x2b, 0x01, 0x08, 0x26, 0x5c, 0x01, 0xfe,
 
5193         0xd8, 0x14, 0x02, 0x5c, 0x13, 0x06, 0x65, 0xfe, 0xca, 0x12, 0x26, 0xfe,
 
5194         0xe0, 0x12, 0x72, 0xf1, 0x01, 0x08, 0x23, 0x72, 0x03, 0x8f, 0xfe, 0xdc,
 
5195         0x12, 0x25, 0xfe, 0xdc, 0x12, 0x1f, 0xfe, 0xca, 0x12, 0x5e, 0x2b, 0x01,
 
5196         0x08, 0xfe, 0xd5, 0x10, 0x13, 0x6c, 0xff, 0x02, 0x00, 0x57, 0x48, 0x8b,
 
5197         0x1c, 0xfe, 0xff, 0x7f, 0xfe, 0x30, 0x56, 0xfe, 0x00, 0x5c, 0x03, 0x13,
 
5198         0x6c, 0xff, 0x02, 0x00, 0x57, 0x48, 0x8b, 0x1c, 0x3d, 0xfe, 0x30, 0x56,
 
5199         0xfe, 0x00, 0x5c, 0x03, 0x13, 0x6c, 0xff, 0x02, 0x00, 0x57, 0x48, 0x8b,
 
5200         0x03, 0x13, 0x6c, 0xff, 0x02, 0x00, 0x57, 0x48, 0x8b, 0xfe, 0x0b, 0x58,
 
5201         0x03, 0x0a, 0x50, 0x01, 0x82, 0x0a, 0x3f, 0x01, 0x82, 0x03, 0xfc, 0x1c,
 
5202         0x10, 0xff, 0x03, 0x00, 0x54, 0xfe, 0x00, 0xf4, 0x19, 0x48, 0xfe, 0x00,
 
5203         0x7d, 0xfe, 0x01, 0x7d, 0xfe, 0x02, 0x7d, 0xfe, 0x03, 0x7c, 0x63, 0x27,
 
5204         0x0c, 0x52, 0x18, 0x53, 0xbe, 0x56, 0xbf, 0x57, 0x03, 0xfe, 0x62, 0x08,
 
5205         0xfe, 0x82, 0x4a, 0xfe, 0xe1, 0x1a, 0xfe, 0x83, 0x5a, 0x74, 0x03, 0x01,
 
5206         0xfe, 0x14, 0x18, 0xfe, 0x42, 0x48, 0x5f, 0x60, 0x89, 0x01, 0x08, 0x1f,
 
5207         0xfe, 0xa2, 0x14, 0x30, 0x2e, 0xd8, 0x01, 0x08, 0x1f, 0xfe, 0xa2, 0x14,
 
5208         0x30, 0x2e, 0xfe, 0xe8, 0x0a, 0xfe, 0xc1, 0x59, 0x05, 0xc6, 0x28, 0xfe,
 
5209         0xcc, 0x12, 0x49, 0x04, 0x1b, 0xfe, 0xc4, 0x13, 0x23, 0x62, 0x1b, 0xe2,
 
5210         0x4b, 0xc3, 0x64, 0xfe, 0xe8, 0x13, 0x3b, 0x13, 0x06, 0x17, 0xc3, 0x78,
 
5211         0xdb, 0xfe, 0x78, 0x10, 0xff, 0x02, 0x83, 0x55, 0xa1, 0xff, 0x02, 0x83,
 
5212         0x55, 0x62, 0x1a, 0xa4, 0xbb, 0xfe, 0x30, 0x00, 0x8e, 0xe4, 0x17, 0x2c,
 
5213         0x13, 0x06, 0xfe, 0x56, 0x10, 0x62, 0x0b, 0xe1, 0xbb, 0xfe, 0x64, 0x00,
 
5214         0x8e, 0xe4, 0x0a, 0xfe, 0x64, 0x00, 0x17, 0x93, 0x13, 0x06, 0xfe, 0x28,
 
5215         0x10, 0x62, 0x06, 0xfe, 0x60, 0x13, 0xbb, 0xfe, 0xc8, 0x00, 0x8e, 0xe4,
 
5216         0x0a, 0xfe, 0xc8, 0x00, 0x17, 0x4d, 0x13, 0x06, 0x83, 0xbb, 0xfe, 0x90,
 
5217         0x01, 0xba, 0xfe, 0x4e, 0x14, 0x89, 0xfe, 0x12, 0x10, 0xfe, 0x43, 0xf4,
 
5218         0x94, 0xfe, 0x56, 0xf0, 0xfe, 0x60, 0x14, 0xfe, 0x04, 0xf4, 0x6c, 0xfe,
 
5219         0x43, 0xf4, 0x93, 0xfe, 0xf3, 0x10, 0xf9, 0x01, 0xfe, 0x22, 0x13, 0x1c,
 
5220         0x3d, 0xfe, 0x10, 0x13, 0xfe, 0x00, 0x17, 0xfe, 0x4d, 0xe4, 0x69, 0xba,
 
5221         0xfe, 0x9c, 0x14, 0xb7, 0x69, 0xfe, 0x1c, 0x10, 0xfe, 0x00, 0x17, 0xfe,
 
5222         0x4d, 0xe4, 0x19, 0xba, 0xfe, 0x9c, 0x14, 0xb7, 0x19, 0x83, 0x60, 0x23,
 
5223         0xfe, 0x4d, 0xf4, 0x00, 0xdf, 0x89, 0x13, 0x06, 0xfe, 0xb4, 0x56, 0xfe,
 
5224         0xc3, 0x58, 0x03, 0x60, 0x13, 0x0b, 0x03, 0x15, 0x06, 0x01, 0x08, 0x26,
 
5225         0xe5, 0x15, 0x0b, 0x01, 0x08, 0x26, 0xe5, 0x15, 0x1a, 0x01, 0x08, 0x26,
 
5226         0xe5, 0x72, 0xfe, 0x89, 0x49, 0x01, 0x08, 0x03, 0x15, 0x06, 0x01, 0x08,
 
5227         0x26, 0xa6, 0x15, 0x1a, 0x01, 0x08, 0x26, 0xa6, 0x15, 0x06, 0x01, 0x08,
 
5228         0x26, 0xa6, 0xfe, 0x89, 0x49, 0x01, 0x08, 0x26, 0xa6, 0x72, 0xfe, 0x89,
 
5229         0x4a, 0x01, 0x08, 0x03, 0x60, 0x03, 0x1e, 0xcc, 0x07, 0x06, 0xfe, 0x44,
 
5230         0x13, 0xad, 0x12, 0xcc, 0xfe, 0x49, 0xf4, 0x00, 0x3b, 0x72, 0x9f, 0x5e,
 
5231         0xfe, 0x01, 0xec, 0xfe, 0x27, 0x01, 0xf1, 0x01, 0x08, 0x2f, 0x07, 0xfe,
 
5232         0xe3, 0x00, 0xfe, 0x20, 0x13, 0x1f, 0xfe, 0x5a, 0x15, 0x23, 0x12, 0xcd,
 
5233         0x01, 0x43, 0x1e, 0xcd, 0x07, 0x06, 0x45, 0x09, 0x4a, 0x06, 0x35, 0x03,
 
5234         0x0a, 0x42, 0x01, 0x0e, 0xed, 0x88, 0x07, 0x10, 0xa4, 0x0a, 0x80, 0x01,
 
5235         0x0e, 0x88, 0x0a, 0x51, 0x01, 0x9e, 0x03, 0x0a, 0x80, 0x01, 0x0e, 0x88,
 
5236         0xfe, 0x80, 0xe7, 0x10, 0x07, 0x10, 0x84, 0xfe, 0x45, 0x58, 0x01, 0xe3,
 
5237         0x88, 0x03, 0x0a, 0x42, 0x01, 0x0e, 0x88, 0x0a, 0x51, 0x01, 0x9e, 0x03,
 
5238         0x0a, 0x42, 0x01, 0x0e, 0xfe, 0x80, 0x80, 0xf2, 0xfe, 0x49, 0xe4, 0x10,
 
5239         0xa4, 0x0a, 0x80, 0x01, 0x0e, 0xf2, 0x0a, 0x51, 0x01, 0x82, 0x03, 0x17,
 
5240         0x10, 0x71, 0x66, 0xfe, 0x60, 0x01, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde,
 
5241         0xfe, 0x24, 0x1c, 0xfe, 0x1d, 0xf7, 0x1d, 0x90, 0xfe, 0xf6, 0x15, 0x01,
 
5242         0xfe, 0xfc, 0x16, 0xe0, 0x91, 0x1d, 0x66, 0xfe, 0x2c, 0x01, 0xfe, 0x2f,
 
5243         0x19, 0x03, 0xae, 0x21, 0xfe, 0xe6, 0x15, 0xfe, 0xda, 0x10, 0x17, 0x10,
 
5244         0x71, 0x05, 0xfe, 0x64, 0x01, 0xfe, 0x00, 0xf4, 0x19, 0xfe, 0x18, 0x58,
 
5245         0x05, 0xfe, 0x66, 0x01, 0xfe, 0x19, 0x58, 0x91, 0x19, 0xfe, 0x3c, 0x90,
 
5246         0xfe, 0x30, 0xf4, 0x06, 0xfe, 0x3c, 0x50, 0x66, 0xfe, 0x38, 0x00, 0xfe,
 
5247         0x0f, 0x79, 0xfe, 0x1c, 0xf7, 0x19, 0x90, 0xfe, 0x40, 0x16, 0xfe, 0xb6,
 
5248         0x14, 0x34, 0x03, 0xae, 0x21, 0xfe, 0x18, 0x16, 0xfe, 0x9c, 0x10, 0x17,
 
5249         0x10, 0x71, 0xfe, 0x83, 0x5a, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde, 0xfe,
 
5250         0x1d, 0xf7, 0x38, 0x90, 0xfe, 0x62, 0x16, 0xfe, 0x94, 0x14, 0xfe, 0x10,
 
5251         0x13, 0x91, 0x38, 0x66, 0x1b, 0xfe, 0xaf, 0x19, 0xfe, 0x98, 0xe7, 0x00,
 
5252         0x03, 0xae, 0x21, 0xfe, 0x56, 0x16, 0xfe, 0x6c, 0x10, 0x17, 0x10, 0x71,
 
5253         0xfe, 0x30, 0xbc, 0xfe, 0xb2, 0xbc, 0x91, 0xc5, 0x66, 0x1b, 0xfe, 0x0f,
 
5254         0x79, 0xfe, 0x1c, 0xf7, 0xc5, 0x90, 0xfe, 0x9a, 0x16, 0xfe, 0x5c, 0x14,
 
5255         0x34, 0x03, 0xae, 0x21, 0xfe, 0x86, 0x16, 0xfe, 0x42, 0x10, 0xfe, 0x02,
 
5256         0xf6, 0x10, 0x71, 0xfe, 0x18, 0xfe, 0x54, 0xfe, 0x19, 0xfe, 0x55, 0xfc,
 
5257         0xfe, 0x1d, 0xf7, 0x4f, 0x90, 0xfe, 0xc0, 0x16, 0xfe, 0x36, 0x14, 0xfe,
 
5258         0x1c, 0x13, 0x91, 0x4f, 0x47, 0xfe, 0x83, 0x58, 0xfe, 0xaf, 0x19, 0xfe,
 
5259         0x80, 0xe7, 0x10, 0xfe, 0x81, 0xe7, 0x10, 0x11, 0xfe, 0xdd, 0x00, 0x63,
 
5260         0x27, 0x03, 0x63, 0x27, 0xfe, 0x12, 0x45, 0x21, 0xfe, 0xb0, 0x16, 0x14,
 
5261         0x06, 0x37, 0x95, 0xa9, 0x02, 0x29, 0xfe, 0x39, 0xf0, 0xfe, 0x04, 0x17,
 
5262         0x23, 0x03, 0xfe, 0x7e, 0x18, 0x1c, 0x1a, 0x5d, 0x13, 0x0d, 0x03, 0x71,
 
5263         0x05, 0xcb, 0x1c, 0x06, 0xfe, 0xef, 0x12, 0xfe, 0xe1, 0x10, 0x78, 0x2c,
 
5264         0x46, 0x2f, 0x07, 0x2d, 0xfe, 0x3c, 0x13, 0xfe, 0x82, 0x14, 0xfe, 0x42,
 
5265         0x13, 0x3c, 0x8a, 0x0a, 0x42, 0x01, 0x0e, 0xb0, 0xfe, 0x3e, 0x12, 0xf0,
 
5266         0xfe, 0x45, 0x48, 0x01, 0xe3, 0xfe, 0x00, 0xcc, 0xb0, 0xfe, 0xf3, 0x13,
 
5267         0x3d, 0x75, 0x07, 0x10, 0xa3, 0x0a, 0x80, 0x01, 0x0e, 0xf2, 0x01, 0x6f,
 
5268         0xfe, 0x16, 0x10, 0x07, 0x7e, 0x85, 0xfe, 0x40, 0x14, 0xfe, 0x24, 0x12,
 
5269         0xf6, 0xfe, 0xd6, 0xf0, 0xfe, 0x24, 0x17, 0x17, 0x0b, 0x03, 0xfe, 0x9c,
 
5270         0xe7, 0x0b, 0x0f, 0xfe, 0x15, 0x00, 0x59, 0x76, 0x27, 0x01, 0xda, 0x17,
 
5271         0x06, 0x03, 0x3c, 0x8a, 0x09, 0x4a, 0x1d, 0x35, 0x11, 0x2d, 0x01, 0x6f,
 
5272         0x17, 0x06, 0x03, 0xfe, 0x38, 0x90, 0xfe, 0xba, 0x90, 0x79, 0xc7, 0x68,
 
5273         0xc8, 0xfe, 0x48, 0x55, 0x34, 0xfe, 0xc9, 0x55, 0x03, 0x1e, 0x98, 0x73,
 
5274         0x12, 0x98, 0x03, 0x0a, 0x99, 0x01, 0x0e, 0xf0, 0x0a, 0x40, 0x01, 0x0e,
 
5275         0xfe, 0x49, 0x44, 0x16, 0xfe, 0xf0, 0x17, 0x73, 0x75, 0x03, 0x0a, 0x42,
 
5276         0x01, 0x0e, 0x07, 0x10, 0x45, 0x0a, 0x51, 0x01, 0x9e, 0x0a, 0x40, 0x01,
 
5277         0x0e, 0x73, 0x75, 0x03, 0xfe, 0x4e, 0xe4, 0x1a, 0x64, 0xfe, 0x24, 0x18,
 
5278         0x05, 0xfe, 0x90, 0x00, 0xfe, 0x3a, 0x45, 0x5b, 0xfe, 0x4e, 0xe4, 0xc2,
 
5279         0x64, 0xfe, 0x36, 0x18, 0x05, 0xfe, 0x92, 0x00, 0xfe, 0x02, 0xe6, 0x1b,
 
5280         0xdc, 0xfe, 0x4e, 0xe4, 0xfe, 0x0b, 0x00, 0x64, 0xfe, 0x48, 0x18, 0x05,
 
5281         0xfe, 0x94, 0x00, 0xfe, 0x02, 0xe6, 0x19, 0xfe, 0x08, 0x10, 0x05, 0xfe,
 
5282         0x96, 0x00, 0xfe, 0x02, 0xe6, 0x2c, 0xfe, 0x4e, 0x45, 0xfe, 0x0c, 0x12,
 
5283         0xaf, 0xff, 0x04, 0x68, 0x54, 0xde, 0x1c, 0x69, 0x03, 0x07, 0x7a, 0xfe,
 
5284         0x5a, 0xf0, 0xfe, 0x74, 0x18, 0x24, 0xfe, 0x09, 0x00, 0xfe, 0x34, 0x10,
 
5285         0x07, 0x1b, 0xfe, 0x5a, 0xf0, 0xfe, 0x82, 0x18, 0x24, 0xc3, 0xfe, 0x26,
 
5286         0x10, 0x07, 0x1a, 0x5d, 0x24, 0x2c, 0xdc, 0x07, 0x0b, 0x5d, 0x24, 0x93,
 
5287         0xfe, 0x0e, 0x10, 0x07, 0x06, 0x5d, 0x24, 0x4d, 0x9f, 0xad, 0x03, 0x14,
 
5288         0xfe, 0x09, 0x00, 0x01, 0x33, 0xfe, 0x04, 0xfe, 0x7d, 0x05, 0x7f, 0xf9,
 
5289         0x03, 0x25, 0xfe, 0xca, 0x18, 0xfe, 0x14, 0xf0, 0x08, 0x65, 0xfe, 0xc6,
 
5290         0x18, 0x03, 0xff, 0x1a, 0x00, 0x00,
 
5293 static unsigned short _adv_asc3550_size = sizeof(_adv_asc3550_buf);     /* 0x13AD */
 
5294 static ADV_DCNT _adv_asc3550_chksum = 0x04D52DDDUL;     /* Expanded little-endian checksum. */
 
5296 /* Microcode buffer is kept after initialization for error recovery. */
 
5297 static unsigned char _adv_asc38C0800_buf[] = {
 
5298         0x00, 0x00, 0x00, 0xf2, 0x00, 0xf0, 0x00, 0xfc, 0x00, 0x16, 0x18, 0xe4,
 
5299         0x01, 0x00, 0x48, 0xe4, 0x18, 0x80, 0x03, 0xf6, 0x02, 0x00, 0xce, 0x19,
 
5300         0x00, 0xfa, 0xff, 0xff, 0x1c, 0x0f, 0x00, 0xf6, 0x9e, 0xe7, 0xff, 0x00,
 
5301         0x82, 0xe7, 0x00, 0xea, 0x01, 0xfa, 0x01, 0xe6, 0x09, 0xe7, 0x55, 0xf0,
 
5302         0x01, 0xf6, 0x03, 0x00, 0x04, 0x00, 0x10, 0x00, 0x1e, 0xf0, 0x85, 0xf0,
 
5303         0x18, 0xf4, 0x08, 0x00, 0xbc, 0x00, 0x38, 0x54, 0x00, 0xec, 0xd5, 0xf0,
 
5304         0x82, 0x0d, 0x00, 0xe6, 0x86, 0xf0, 0xb1, 0xf0, 0x98, 0x57, 0x01, 0xfc,
 
5305         0xb4, 0x00, 0xd4, 0x01, 0x0c, 0x1c, 0x3e, 0x1c, 0x3c, 0x00, 0xbb, 0x00,
 
5306         0x00, 0x10, 0xba, 0x19, 0x02, 0x80, 0x32, 0xf0, 0x7c, 0x0d, 0x02, 0x13,
 
5307         0xba, 0x13, 0x18, 0x40, 0x00, 0x57, 0x01, 0xea, 0x02, 0xfc, 0x03, 0xfc,
 
5308         0x3e, 0x00, 0x6c, 0x01, 0x6e, 0x01, 0x74, 0x01, 0x76, 0x01, 0xb9, 0x54,
 
5309         0x3e, 0x57, 0x00, 0x80, 0x03, 0xe6, 0xb6, 0x00, 0xc0, 0x00, 0x01, 0x01,
 
5310         0x3e, 0x01, 0x7a, 0x01, 0xca, 0x08, 0xce, 0x10, 0x16, 0x11, 0x04, 0x12,
 
5311         0x08, 0x12, 0x02, 0x4a, 0xbb, 0x55, 0x3c, 0x56, 0x03, 0x58, 0x1b, 0x80,
 
5312         0x30, 0xe4, 0x4b, 0xe4, 0x5d, 0xf0, 0x02, 0xfa, 0x20, 0x00, 0x32, 0x00,
 
5313         0x40, 0x00, 0x80, 0x00, 0x24, 0x01, 0x3c, 0x01, 0x68, 0x01, 0x6a, 0x01,
 
5314         0x70, 0x01, 0x72, 0x01, 0x78, 0x01, 0x7c, 0x01, 0x62, 0x0a, 0x86, 0x0d,
 
5315         0x06, 0x13, 0x4c, 0x1c, 0x04, 0x80, 0x4a, 0xe4, 0x02, 0xee, 0x5b, 0xf0,
 
5316         0x03, 0xf7, 0x0c, 0x00, 0x0f, 0x00, 0x47, 0x00, 0xbe, 0x00, 0x00, 0x01,
 
5317         0x20, 0x11, 0x5c, 0x16, 0x32, 0x1c, 0x38, 0x1c, 0x4e, 0x1c, 0x10, 0x44,
 
5318         0x00, 0x4c, 0x04, 0xea, 0x5c, 0xf0, 0xa7, 0xf0, 0x04, 0xf6, 0x03, 0xfa,
 
5319         0x05, 0x00, 0x34, 0x00, 0x36, 0x00, 0x98, 0x00, 0xcc, 0x00, 0x20, 0x01,
 
5320         0x4e, 0x01, 0x4a, 0x0b, 0x42, 0x0c, 0x12, 0x0f, 0x0c, 0x10, 0x22, 0x11,
 
5321         0x0a, 0x12, 0x04, 0x13, 0x30, 0x1c, 0x02, 0x48, 0x00, 0x4e, 0x42, 0x54,
 
5322         0x44, 0x55, 0xbd, 0x56, 0x06, 0x83, 0x00, 0xdc, 0x05, 0xf0, 0x09, 0xf0,
 
5323         0x59, 0xf0, 0xb8, 0xf0, 0x4b, 0xf4, 0x06, 0xf7, 0x0e, 0xf7, 0x04, 0xfc,
 
5324         0x05, 0xfc, 0x06, 0x00, 0x19, 0x00, 0x33, 0x00, 0x9b, 0x00, 0xa4, 0x00,
 
5325         0xb5, 0x00, 0xba, 0x00, 0xd0, 0x00, 0xe1, 0x00, 0xe7, 0x00, 0xe2, 0x03,
 
5326         0x08, 0x0f, 0x02, 0x10, 0x04, 0x10, 0x0a, 0x10, 0x0a, 0x13, 0x0c, 0x13,
 
5327         0x12, 0x13, 0x24, 0x14, 0x34, 0x14, 0x04, 0x16, 0x08, 0x16, 0xa4, 0x17,
 
5328         0x20, 0x1c, 0x34, 0x1c, 0x36, 0x1c, 0x08, 0x44, 0x38, 0x44, 0x91, 0x44,
 
5329         0x0a, 0x45, 0x48, 0x46, 0x01, 0x48, 0x68, 0x54, 0x3a, 0x55, 0x83, 0x55,
 
5330         0xe5, 0x55, 0xb0, 0x57, 0x01, 0x58, 0x83, 0x59, 0x05, 0xe6, 0x0b, 0xf0,
 
5331         0x0c, 0xf0, 0x04, 0xf8, 0x05, 0xf8, 0x07, 0x00, 0x0a, 0x00, 0x1c, 0x00,
 
5332         0x1e, 0x00, 0x9e, 0x00, 0xa8, 0x00, 0xaa, 0x00, 0xb9, 0x00, 0xe0, 0x00,
 
5333         0x22, 0x01, 0x26, 0x01, 0x79, 0x01, 0x7e, 0x01, 0xc4, 0x01, 0xc6, 0x01,
 
5334         0x80, 0x02, 0x5e, 0x03, 0xee, 0x04, 0x9a, 0x06, 0xf8, 0x07, 0x62, 0x08,
 
5335         0x68, 0x08, 0x69, 0x08, 0xd6, 0x08, 0xe9, 0x09, 0xfa, 0x0b, 0x2e, 0x0f,
 
5336         0x12, 0x10, 0x1a, 0x10, 0xed, 0x10, 0xf1, 0x10, 0x2a, 0x11, 0x06, 0x12,
 
5337         0x0c, 0x12, 0x3e, 0x12, 0x10, 0x13, 0x16, 0x13, 0x1e, 0x13, 0x46, 0x14,
 
5338         0x76, 0x14, 0x82, 0x14, 0x36, 0x15, 0xca, 0x15, 0x6b, 0x18, 0xbe, 0x18,
 
5339         0xca, 0x18, 0xe6, 0x19, 0x12, 0x1c, 0x46, 0x1c, 0x9c, 0x32, 0x00, 0x40,
 
5340         0x0e, 0x47, 0xfe, 0x9c, 0xf0, 0x2b, 0x02, 0xfe, 0xac, 0x0d, 0xff, 0x10,
 
5341         0x00, 0x00, 0xd7, 0xfe, 0xe8, 0x19, 0x00, 0xd6, 0xfe, 0x84, 0x01, 0xff,
 
5342         0x03, 0x00, 0x00, 0xfe, 0x93, 0x15, 0xfe, 0x0f, 0x05, 0xff, 0x38, 0x00,
 
5343         0x00, 0xfe, 0x57, 0x24, 0x00, 0xfe, 0x4c, 0x00, 0x5b, 0xff, 0x04, 0x00,
 
5344         0x00, 0x11, 0xff, 0x09, 0x00, 0x00, 0xff, 0x08, 0x01, 0x01, 0xff, 0x08,
 
5345         0xff, 0xff, 0xff, 0x27, 0x00, 0x00, 0xff, 0x10, 0xff, 0xff, 0xff, 0x11,
 
5346         0x00, 0x00, 0xfe, 0x78, 0x56, 0xfe, 0x34, 0x12, 0xff, 0x21, 0x00, 0x00,
 
5347         0xfe, 0x04, 0xf7, 0xd6, 0x2c, 0x99, 0x0a, 0x01, 0xfe, 0xc2, 0x0f, 0xfe,
 
5348         0x04, 0xf7, 0xd6, 0x99, 0x0a, 0x42, 0x2c, 0xfe, 0x3d, 0xf0, 0xfe, 0x06,
 
5349         0x02, 0xfe, 0x20, 0xf0, 0xa7, 0xfe, 0x91, 0xf0, 0xfe, 0xf4, 0x01, 0xfe,
 
5350         0x90, 0xf0, 0xfe, 0xf4, 0x01, 0xfe, 0x8f, 0xf0, 0xa7, 0x03, 0x5d, 0x4d,
 
5351         0x02, 0xfe, 0xc8, 0x0d, 0x01, 0xfe, 0x38, 0x0e, 0xfe, 0xdd, 0x12, 0xfe,
 
5352         0xfc, 0x10, 0xfe, 0x28, 0x1c, 0x03, 0xfe, 0xa6, 0x00, 0xfe, 0xd3, 0x12,
 
5353         0x41, 0x14, 0xfe, 0xa6, 0x00, 0xc2, 0xfe, 0x48, 0xf0, 0xfe, 0x8a, 0x02,
 
5354         0xfe, 0x49, 0xf0, 0xfe, 0xa4, 0x02, 0xfe, 0x4a, 0xf0, 0xfe, 0xc2, 0x02,
 
5355         0xfe, 0x46, 0xf0, 0xfe, 0x54, 0x02, 0xfe, 0x47, 0xf0, 0xfe, 0x5a, 0x02,
 
5356         0xfe, 0x43, 0xf0, 0xfe, 0x48, 0x02, 0xfe, 0x44, 0xf0, 0xfe, 0x4c, 0x02,
 
5357         0xfe, 0x45, 0xf0, 0xfe, 0x50, 0x02, 0x18, 0x0a, 0xaa, 0x18, 0x06, 0x14,
 
5358         0xa1, 0x02, 0x2b, 0xfe, 0x00, 0x1c, 0xe7, 0xfe, 0x02, 0x1c, 0xe6, 0xfe,
 
5359         0x1e, 0x1c, 0xfe, 0xe9, 0x10, 0x01, 0xfe, 0x18, 0x18, 0xfe, 0xe7, 0x10,
 
5360         0xfe, 0x06, 0xfc, 0xce, 0x09, 0x70, 0x01, 0xa8, 0x02, 0x2b, 0x15, 0x59,
 
5361         0x39, 0xa2, 0x01, 0xfe, 0x58, 0x10, 0x09, 0x70, 0x01, 0x87, 0xfe, 0xbd,
 
5362         0x10, 0x09, 0x70, 0x01, 0x87, 0xfe, 0xad, 0x10, 0xfe, 0x16, 0x1c, 0xfe,
 
5363         0x58, 0x1c, 0x18, 0x06, 0x14, 0xa1, 0x2c, 0x1c, 0x2b, 0xfe, 0x3d, 0xf0,
 
5364         0xfe, 0x06, 0x02, 0x23, 0xfe, 0x98, 0x02, 0xfe, 0x5a, 0x1c, 0xf8, 0xfe,
 
5365         0x14, 0x1c, 0x15, 0xfe, 0x30, 0x00, 0x39, 0xa2, 0x01, 0xfe, 0x48, 0x10,
 
5366         0x18, 0x06, 0x14, 0xa1, 0x02, 0xd7, 0x22, 0x20, 0x07, 0x11, 0x35, 0xfe,
 
5367         0x69, 0x10, 0x18, 0x06, 0x14, 0xa1, 0xfe, 0x04, 0xec, 0x20, 0x4f, 0x43,
 
5368         0x13, 0x20, 0xfe, 0x05, 0xf6, 0xce, 0x01, 0xfe, 0x4a, 0x17, 0x08, 0x54,
 
5369         0x58, 0x37, 0x12, 0x2f, 0x42, 0x92, 0x01, 0xfe, 0x82, 0x16, 0x02, 0x2b,
 
5370         0x09, 0x46, 0x01, 0x0e, 0x07, 0x00, 0x66, 0x01, 0x73, 0xfe, 0x18, 0x10,
 
5371         0xfe, 0x41, 0x58, 0x09, 0xa4, 0x01, 0x0e, 0xfe, 0xc8, 0x54, 0x6b, 0xfe,
 
5372         0x10, 0x03, 0x01, 0xfe, 0x82, 0x16, 0x02, 0x2b, 0x2c, 0x4f, 0xfe, 0x02,
 
5373         0xe8, 0x2a, 0xfe, 0xbf, 0x57, 0xfe, 0x9e, 0x43, 0xfe, 0x77, 0x57, 0xfe,
 
5374         0x27, 0xf0, 0xfe, 0xe0, 0x01, 0xfe, 0x07, 0x4b, 0xfe, 0x20, 0xf0, 0xa7,
 
5375         0xfe, 0x40, 0x1c, 0x1c, 0xd9, 0xfe, 0x26, 0xf0, 0xfe, 0x5a, 0x03, 0xfe,
 
5376         0xa0, 0xf0, 0xfe, 0x48, 0x03, 0xfe, 0x11, 0xf0, 0xa7, 0xfe, 0xef, 0x10,
 
5377         0xfe, 0x9f, 0xf0, 0xfe, 0x68, 0x03, 0xf9, 0x10, 0xfe, 0x11, 0x00, 0x02,
 
5378         0x65, 0x2c, 0xfe, 0x48, 0x1c, 0xf9, 0x08, 0x05, 0x1b, 0xfe, 0x18, 0x13,
 
5379         0x21, 0x22, 0xa3, 0xb7, 0x13, 0xa3, 0x09, 0x46, 0x01, 0x0e, 0xb7, 0x78,
 
5380         0x01, 0xfe, 0xb4, 0x16, 0x12, 0xd1, 0x1c, 0xd9, 0xfe, 0x01, 0xf0, 0xd9,
 
5381         0xfe, 0x82, 0xf0, 0xfe, 0x96, 0x03, 0xfa, 0x12, 0xfe, 0xe4, 0x00, 0x27,
 
5382         0xfe, 0xa8, 0x03, 0x1c, 0x34, 0x1d, 0xfe, 0xb8, 0x03, 0x01, 0x4b, 0xfe,
 
5383         0x06, 0xf0, 0xfe, 0xc8, 0x03, 0x95, 0x86, 0xfe, 0x0a, 0xf0, 0xfe, 0x8a,
 
5384         0x06, 0x02, 0x24, 0x03, 0x70, 0x28, 0x17, 0xfe, 0xfa, 0x04, 0x15, 0x6d,
 
5385         0x01, 0x36, 0x7b, 0xfe, 0x6a, 0x02, 0x02, 0xd8, 0xf9, 0x2c, 0x99, 0x19,
 
5386         0xfe, 0x67, 0x1b, 0xfe, 0xbf, 0x57, 0xfe, 0x77, 0x57, 0xfe, 0x48, 0x1c,
 
5387         0x74, 0x01, 0xaf, 0x8c, 0x09, 0x46, 0x01, 0x0e, 0x07, 0x00, 0x17, 0xda,
 
5388         0x09, 0xd1, 0x01, 0x0e, 0x8d, 0x51, 0x64, 0x79, 0x2a, 0x03, 0x70, 0x28,
 
5389         0xfe, 0x10, 0x12, 0x15, 0x6d, 0x01, 0x36, 0x7b, 0xfe, 0x6a, 0x02, 0x02,
 
5390         0xd8, 0xc7, 0x81, 0xc8, 0x83, 0x1c, 0x24, 0x27, 0xfe, 0x40, 0x04, 0x1d,
 
5391         0xfe, 0x3c, 0x04, 0x3b, 0xfe, 0xa0, 0x00, 0xfe, 0x9b, 0x57, 0xfe, 0x4e,
 
5392         0x12, 0x2d, 0xff, 0x02, 0x00, 0x10, 0x01, 0x0b, 0x1d, 0xfe, 0xe4, 0x04,
 
5393         0x2d, 0x01, 0x0b, 0x1d, 0x24, 0x33, 0x31, 0xde, 0xfe, 0x4c, 0x44, 0xfe,
 
5394         0x4c, 0x12, 0x51, 0xfe, 0x44, 0x48, 0x0f, 0x6f, 0xfe, 0x4c, 0x54, 0x6b,
 
5395         0xda, 0x4f, 0x79, 0x2a, 0xfe, 0x06, 0x80, 0xfe, 0x48, 0x47, 0xfe, 0x62,
 
5396         0x13, 0x08, 0x05, 0x1b, 0xfe, 0x2a, 0x13, 0x32, 0x07, 0x82, 0xfe, 0x52,
 
5397         0x13, 0xfe, 0x20, 0x10, 0x0f, 0x6f, 0xfe, 0x4c, 0x54, 0x6b, 0xda, 0xfe,
 
5398         0x06, 0x80, 0xfe, 0x48, 0x47, 0xfe, 0x40, 0x13, 0x08, 0x05, 0x1b, 0xfe,
 
5399         0x08, 0x13, 0x32, 0x07, 0x82, 0xfe, 0x30, 0x13, 0x08, 0x05, 0x1b, 0xfe,
 
5400         0x1c, 0x12, 0x15, 0x9d, 0x08, 0x05, 0x06, 0x4d, 0x15, 0xfe, 0x0d, 0x00,
 
5401         0x01, 0x36, 0x7b, 0xfe, 0x64, 0x0d, 0x02, 0x24, 0x2d, 0x12, 0xfe, 0xe6,
 
5402         0x00, 0xfe, 0x1c, 0x90, 0xfe, 0x40, 0x5c, 0x04, 0x15, 0x9d, 0x01, 0x36,
 
5403         0x02, 0x2b, 0xfe, 0x42, 0x5b, 0x99, 0x19, 0xfe, 0x46, 0x59, 0xfe, 0xbf,
 
5404         0x57, 0xfe, 0x77, 0x57, 0xfe, 0x87, 0x80, 0xfe, 0x31, 0xe4, 0x5b, 0x08,
 
5405         0x05, 0x0a, 0xfe, 0x84, 0x13, 0xfe, 0x20, 0x80, 0x07, 0x19, 0xfe, 0x7c,
 
5406         0x12, 0x53, 0x05, 0x06, 0xfe, 0x6c, 0x13, 0x03, 0xfe, 0xa2, 0x00, 0x28,
 
5407         0x17, 0xfe, 0x90, 0x05, 0xfe, 0x31, 0xe4, 0x5a, 0x53, 0x05, 0x0a, 0xfe,
 
5408         0x56, 0x13, 0x03, 0xfe, 0xa0, 0x00, 0x28, 0xfe, 0x4e, 0x12, 0x67, 0xff,
 
5409         0x02, 0x00, 0x10, 0x27, 0xfe, 0x48, 0x05, 0x1c, 0x34, 0xfe, 0x89, 0x48,
 
5410         0xff, 0x02, 0x00, 0x10, 0x27, 0xfe, 0x56, 0x05, 0x26, 0xfe, 0xa8, 0x05,
 
5411         0x12, 0xfe, 0xe3, 0x00, 0x21, 0x53, 0xfe, 0x4a, 0xf0, 0xfe, 0x76, 0x05,
 
5412         0xfe, 0x49, 0xf0, 0xfe, 0x70, 0x05, 0x88, 0x25, 0xfe, 0x21, 0x00, 0xab,
 
5413         0x25, 0xfe, 0x22, 0x00, 0xaa, 0x25, 0x58, 0xfe, 0x09, 0x48, 0xff, 0x02,
 
5414         0x00, 0x10, 0x27, 0xfe, 0x86, 0x05, 0x26, 0xfe, 0xa8, 0x05, 0xfe, 0xe2,
 
5415         0x08, 0x53, 0x05, 0xcb, 0x4d, 0x01, 0xb0, 0x25, 0x06, 0x13, 0xd3, 0x39,
 
5416         0xfe, 0x27, 0x01, 0x08, 0x05, 0x1b, 0xfe, 0x22, 0x12, 0x41, 0x01, 0xb2,
 
5417         0x15, 0x9d, 0x08, 0x05, 0x06, 0x4d, 0x15, 0xfe, 0x0d, 0x00, 0x01, 0x36,
 
5418         0x7b, 0xfe, 0x64, 0x0d, 0x02, 0x24, 0x03, 0xfe, 0x9c, 0x00, 0x28, 0xeb,
 
5419         0x03, 0x5c, 0x28, 0xfe, 0x36, 0x13, 0x41, 0x01, 0xb2, 0x26, 0xfe, 0x18,
 
5420         0x06, 0x09, 0x06, 0x53, 0x05, 0x1f, 0xfe, 0x02, 0x12, 0x50, 0x01, 0xfe,
 
5421         0x9e, 0x15, 0x1d, 0xfe, 0x0e, 0x06, 0x12, 0xa5, 0x01, 0x4b, 0x12, 0xfe,
 
5422         0xe5, 0x00, 0x03, 0x5c, 0xc1, 0x0c, 0x5c, 0x03, 0xcd, 0x28, 0xfe, 0x62,
 
5423         0x12, 0x03, 0x45, 0x28, 0xfe, 0x5a, 0x13, 0x01, 0xfe, 0x0c, 0x19, 0x01,
 
5424         0xfe, 0x76, 0x19, 0xfe, 0x43, 0x48, 0xc4, 0xcc, 0x0f, 0x71, 0xff, 0x02,
 
5425         0x00, 0x57, 0x52, 0x93, 0x1e, 0x43, 0x8b, 0xc4, 0x6e, 0x41, 0x01, 0xb2,
 
5426         0x26, 0xfe, 0x82, 0x06, 0x53, 0x05, 0x1a, 0xe9, 0x91, 0x09, 0x59, 0x01,
 
5427         0xfe, 0xcc, 0x15, 0x1d, 0xfe, 0x78, 0x06, 0x12, 0xa5, 0x01, 0x4b, 0x12,
 
5428         0xfe, 0xe5, 0x00, 0x03, 0x45, 0xc1, 0x0c, 0x45, 0x18, 0x06, 0x01, 0xb2,
 
5429         0xfa, 0x76, 0x74, 0x01, 0xaf, 0x8c, 0x12, 0xfe, 0xe2, 0x00, 0x27, 0xdb,
 
5430         0x1c, 0x34, 0xfe, 0x0a, 0xf0, 0xfe, 0xb6, 0x06, 0x94, 0xfe, 0x6c, 0x07,
 
5431         0xfe, 0x06, 0xf0, 0xfe, 0x74, 0x07, 0x95, 0x86, 0x02, 0x24, 0x08, 0x05,
 
5432         0x0a, 0xfe, 0x2e, 0x12, 0x16, 0x19, 0x01, 0x0b, 0x16, 0x00, 0x01, 0x0b,
 
5433         0x16, 0x00, 0x01, 0x0b, 0x16, 0x00, 0x01, 0x0b, 0xfe, 0x99, 0xa4, 0x01,
 
5434         0x0b, 0x16, 0x00, 0x02, 0xfe, 0x42, 0x08, 0x68, 0x05, 0x1a, 0xfe, 0x38,
 
5435         0x12, 0x08, 0x05, 0x1a, 0xfe, 0x30, 0x13, 0x16, 0xfe, 0x1b, 0x00, 0x01,
 
5436         0x0b, 0x16, 0x00, 0x01, 0x0b, 0x16, 0x00, 0x01, 0x0b, 0x16, 0x00, 0x01,
 
5437         0x0b, 0x16, 0x06, 0x01, 0x0b, 0x16, 0x00, 0x02, 0xe2, 0x6c, 0x58, 0xbe,
 
5438         0x50, 0xfe, 0x9a, 0x81, 0x55, 0x1b, 0x7a, 0xfe, 0x42, 0x07, 0x09, 0x1b,
 
5439         0xfe, 0x09, 0x6f, 0xba, 0xfe, 0xca, 0x45, 0xfe, 0x32, 0x12, 0x69, 0x6d,
 
5440         0x8b, 0x6c, 0x7f, 0x27, 0xfe, 0x54, 0x07, 0x1c, 0x34, 0xfe, 0x0a, 0xf0,
 
5441         0xfe, 0x42, 0x07, 0x95, 0x86, 0x94, 0xfe, 0x6c, 0x07, 0x02, 0x24, 0x01,
 
5442         0x4b, 0x02, 0xdb, 0x16, 0x1f, 0x02, 0xdb, 0xfe, 0x9c, 0xf7, 0xdc, 0xfe,
 
5443         0x2c, 0x90, 0xfe, 0xae, 0x90, 0x56, 0xfe, 0xda, 0x07, 0x0c, 0x60, 0x14,
 
5444         0x61, 0x08, 0x54, 0x5a, 0x37, 0x22, 0x20, 0x07, 0x11, 0xfe, 0x0e, 0x12,
 
5445         0x8d, 0xfe, 0x80, 0x80, 0x39, 0x20, 0x6a, 0x2a, 0xfe, 0x06, 0x10, 0xfe,
 
5446         0x83, 0xe7, 0xfe, 0x48, 0x00, 0xab, 0xfe, 0x03, 0x40, 0x08, 0x54, 0x5b,
 
5447         0x37, 0x01, 0xb3, 0xb8, 0xfe, 0x1f, 0x40, 0x13, 0x62, 0x01, 0xef, 0xfe,
 
5448         0x08, 0x50, 0xfe, 0x8a, 0x50, 0xfe, 0x44, 0x51, 0xfe, 0xc6, 0x51, 0x88,
 
5449         0xfe, 0x08, 0x90, 0xfe, 0x8a, 0x90, 0x0c, 0x5e, 0x14, 0x5f, 0xfe, 0x0c,
 
5450         0x90, 0xfe, 0x8e, 0x90, 0xfe, 0x40, 0x50, 0xfe, 0xc2, 0x50, 0x0c, 0x3d,
 
5451         0x14, 0x3e, 0xfe, 0x4a, 0x10, 0x08, 0x05, 0x5a, 0xfe, 0x2a, 0x12, 0xfe,
 
5452         0x2c, 0x90, 0xfe, 0xae, 0x90, 0x0c, 0x60, 0x14, 0x61, 0x08, 0x05, 0x5b,
 
5453         0x8b, 0x01, 0xb3, 0xfe, 0x1f, 0x80, 0x13, 0x62, 0xfe, 0x44, 0x90, 0xfe,
 
5454         0xc6, 0x90, 0x0c, 0x3f, 0x14, 0x40, 0xfe, 0x08, 0x90, 0xfe, 0x8a, 0x90,
 
5455         0x0c, 0x5e, 0x14, 0x5f, 0xfe, 0x40, 0x90, 0xfe, 0xc2, 0x90, 0x0c, 0x3d,
 
5456         0x14, 0x3e, 0x0c, 0x2e, 0x14, 0x3c, 0x21, 0x0c, 0x49, 0x0c, 0x63, 0x08,
 
5457         0x54, 0x1f, 0x37, 0x2c, 0x0f, 0xfe, 0x4e, 0x11, 0x27, 0xdd, 0xfe, 0x9e,
 
5458         0xf0, 0xfe, 0x76, 0x08, 0xbc, 0x17, 0x34, 0x2c, 0x77, 0xe6, 0xc5, 0xfe,
 
5459         0x9a, 0x08, 0xc6, 0xfe, 0xb8, 0x08, 0x94, 0xfe, 0x8e, 0x08, 0xfe, 0x06,
 
5460         0xf0, 0xfe, 0x94, 0x08, 0x95, 0x86, 0x02, 0x24, 0x01, 0x4b, 0xfe, 0xc9,
 
5461         0x10, 0x16, 0x1f, 0xfe, 0xc9, 0x10, 0x68, 0x05, 0x06, 0xfe, 0x10, 0x12,
 
5462         0x68, 0x05, 0x0a, 0x4e, 0x08, 0x05, 0x0a, 0xfe, 0x90, 0x12, 0xfe, 0x2e,
 
5463         0x1c, 0x02, 0xfe, 0x18, 0x0b, 0x68, 0x05, 0x06, 0x4e, 0x68, 0x05, 0x0a,
 
5464         0xfe, 0x7a, 0x12, 0xfe, 0x2c, 0x1c, 0xfe, 0xaa, 0xf0, 0xfe, 0xd2, 0x09,
 
5465         0xfe, 0xac, 0xf0, 0xfe, 0x00, 0x09, 0x02, 0xfe, 0xde, 0x09, 0xfe, 0xb7,
 
5466         0xf0, 0xfe, 0xfc, 0x08, 0xfe, 0x02, 0xf6, 0x1a, 0x50, 0xfe, 0x70, 0x18,
 
5467         0xfe, 0xf1, 0x18, 0xfe, 0x40, 0x55, 0xfe, 0xe1, 0x55, 0xfe, 0x10, 0x58,
 
5468         0xfe, 0x91, 0x58, 0xfe, 0x14, 0x59, 0xfe, 0x95, 0x59, 0x1c, 0x85, 0xfe,
 
5469         0x8c, 0xf0, 0xfe, 0xfc, 0x08, 0xfe, 0xac, 0xf0, 0xfe, 0xf0, 0x08, 0xb5,
 
5470         0xfe, 0xcb, 0x10, 0xfe, 0xad, 0xf0, 0xfe, 0x0c, 0x09, 0x02, 0xfe, 0x18,
 
5471         0x0b, 0xb6, 0xfe, 0xbf, 0x10, 0xfe, 0x2b, 0xf0, 0x85, 0xf4, 0x1e, 0xfe,
 
5472         0x00, 0xfe, 0xfe, 0x1c, 0x12, 0xc2, 0xfe, 0xd2, 0xf0, 0x85, 0xfe, 0x76,
 
5473         0x18, 0x1e, 0x19, 0x17, 0x85, 0x03, 0xd2, 0x1e, 0x06, 0x17, 0x85, 0xc5,
 
5474         0x4a, 0xc6, 0x4a, 0xb5, 0xb6, 0xfe, 0x89, 0x10, 0x74, 0x67, 0x2d, 0x15,
 
5475         0x9d, 0x01, 0x36, 0x10, 0xfe, 0x35, 0x00, 0xfe, 0x01, 0xf0, 0x65, 0x10,
 
5476         0x80, 0x02, 0x65, 0xfe, 0x98, 0x80, 0xfe, 0x19, 0xe4, 0x0a, 0xfe, 0x1a,
 
5477         0x12, 0x51, 0xfe, 0x19, 0x82, 0xfe, 0x6c, 0x18, 0xfe, 0x44, 0x54, 0xbe,
 
5478         0xfe, 0x19, 0x81, 0xfe, 0x74, 0x18, 0x8f, 0x90, 0x17, 0xfe, 0xce, 0x08,
 
5479         0x02, 0x4a, 0x08, 0x05, 0x5a, 0xec, 0x03, 0x2e, 0x29, 0x3c, 0x0c, 0x3f,
 
5480         0x14, 0x40, 0x9b, 0x2e, 0x9c, 0x3c, 0xfe, 0x6c, 0x18, 0xfe, 0xed, 0x18,
 
5481         0xfe, 0x44, 0x54, 0xfe, 0xe5, 0x54, 0x3a, 0x3f, 0x3b, 0x40, 0x03, 0x49,
 
5482         0x29, 0x63, 0x8f, 0xfe, 0xe3, 0x54, 0xfe, 0x74, 0x18, 0xfe, 0xf5, 0x18,
 
5483         0x8f, 0xfe, 0xe3, 0x54, 0x90, 0xc0, 0x56, 0xfe, 0xce, 0x08, 0x02, 0x4a,
 
5484         0xfe, 0x37, 0xf0, 0xfe, 0xda, 0x09, 0xfe, 0x8b, 0xf0, 0xfe, 0x60, 0x09,
 
5485         0x02, 0x4a, 0x08, 0x05, 0x0a, 0x23, 0xfe, 0xfa, 0x0a, 0x3a, 0x49, 0x3b,
 
5486         0x63, 0x56, 0xfe, 0x3e, 0x0a, 0x0f, 0xfe, 0xc0, 0x07, 0x41, 0x98, 0x00,
 
5487         0xad, 0xfe, 0x01, 0x59, 0xfe, 0x52, 0xf0, 0xfe, 0x0c, 0x0a, 0x8f, 0x7a,
 
5488         0xfe, 0x24, 0x0a, 0x3a, 0x49, 0x8f, 0xfe, 0xe3, 0x54, 0x57, 0x49, 0x7d,
 
5489         0x63, 0xfe, 0x14, 0x58, 0xfe, 0x95, 0x58, 0x02, 0x4a, 0x3a, 0x49, 0x3b,
 
5490         0x63, 0xfe, 0x14, 0x59, 0xfe, 0x95, 0x59, 0xbe, 0x57, 0x49, 0x57, 0x63,
 
5491         0x02, 0x4a, 0x08, 0x05, 0x5a, 0xfe, 0x82, 0x12, 0x08, 0x05, 0x1f, 0xfe,
 
5492         0x66, 0x13, 0x22, 0x62, 0xb7, 0xfe, 0x03, 0xa1, 0xfe, 0x83, 0x80, 0xfe,
 
5493         0xc8, 0x44, 0xfe, 0x2e, 0x13, 0xfe, 0x04, 0x91, 0xfe, 0x86, 0x91, 0x6a,
 
5494         0x2a, 0xfe, 0x40, 0x59, 0xfe, 0xc1, 0x59, 0x56, 0xe0, 0x03, 0x60, 0x29,
 
5495         0x61, 0x0c, 0x7f, 0x14, 0x80, 0x57, 0x60, 0x7d, 0x61, 0x01, 0xb3, 0xb8,
 
5496         0x6a, 0x2a, 0x13, 0x62, 0x9b, 0x2e, 0x9c, 0x3c, 0x3a, 0x3f, 0x3b, 0x40,
 
5497         0x90, 0xc0, 0xfe, 0x04, 0xfa, 0x2e, 0xfe, 0x05, 0xfa, 0x3c, 0x01, 0xef,
 
5498         0xfe, 0x36, 0x10, 0x21, 0x0c, 0x7f, 0x0c, 0x80, 0x3a, 0x3f, 0x3b, 0x40,
 
5499         0xe4, 0x08, 0x05, 0x1f, 0x17, 0xe0, 0x3a, 0x3d, 0x3b, 0x3e, 0x08, 0x05,
 
5500         0xfe, 0xf7, 0x00, 0x37, 0x03, 0x5e, 0x29, 0x5f, 0xfe, 0x10, 0x58, 0xfe,
 
5501         0x91, 0x58, 0x57, 0x49, 0x7d, 0x63, 0x02, 0xfe, 0xf4, 0x09, 0x08, 0x05,
 
5502         0x1f, 0x17, 0xe0, 0x08, 0x05, 0xfe, 0xf7, 0x00, 0x37, 0xbe, 0xfe, 0x19,
 
5503         0x81, 0x50, 0xfe, 0x10, 0x90, 0xfe, 0x92, 0x90, 0xfe, 0xd3, 0x10, 0x32,
 
5504         0x07, 0xa6, 0x17, 0xfe, 0x08, 0x09, 0x12, 0xa6, 0x08, 0x05, 0x0a, 0xfe,
 
5505         0x14, 0x13, 0x03, 0x3d, 0x29, 0x3e, 0x56, 0xfe, 0x08, 0x09, 0xfe, 0x0c,
 
5506         0x58, 0xfe, 0x8d, 0x58, 0x02, 0x4a, 0x21, 0x41, 0xfe, 0x19, 0x80, 0xe7,
 
5507         0x08, 0x05, 0x0a, 0xfe, 0x1a, 0x12, 0xfe, 0x6c, 0x19, 0xfe, 0x19, 0x41,
 
5508         0xf4, 0xc2, 0xfe, 0xd1, 0xf0, 0xe2, 0x15, 0x7e, 0x01, 0x36, 0x10, 0xfe,
 
5509         0x44, 0x00, 0xfe, 0x8e, 0x10, 0xfe, 0x6c, 0x19, 0x57, 0x3d, 0xfe, 0xed,
 
5510         0x19, 0x7d, 0x3e, 0xfe, 0x0c, 0x51, 0xfe, 0x8e, 0x51, 0xf4, 0x1e, 0xfe,
 
5511         0x00, 0xff, 0x35, 0xfe, 0x74, 0x10, 0xc2, 0xfe, 0xd2, 0xf0, 0xfe, 0xa6,
 
5512         0x0b, 0xfe, 0x76, 0x18, 0x1e, 0x19, 0x8a, 0x03, 0xd2, 0x1e, 0x06, 0xfe,
 
5513         0x08, 0x13, 0x10, 0xfe, 0x16, 0x00, 0x02, 0x65, 0xfe, 0xd1, 0xf0, 0xfe,
 
5514         0xb8, 0x0b, 0x15, 0x7e, 0x01, 0x36, 0x10, 0xfe, 0x17, 0x00, 0xfe, 0x42,
 
5515         0x10, 0xfe, 0xce, 0xf0, 0xfe, 0xbe, 0x0b, 0xfe, 0x3c, 0x10, 0xfe, 0xcd,
 
5516         0xf0, 0xfe, 0xca, 0x0b, 0x10, 0xfe, 0x22, 0x00, 0x02, 0x65, 0xfe, 0xcb,
 
5517         0xf0, 0xfe, 0xd6, 0x0b, 0x10, 0xfe, 0x24, 0x00, 0x02, 0x65, 0xfe, 0xd0,
 
5518         0xf0, 0xfe, 0xe0, 0x0b, 0x10, 0x9e, 0xe5, 0xfe, 0xcf, 0xf0, 0xfe, 0xea,
 
5519         0x0b, 0x10, 0x58, 0xfe, 0x10, 0x10, 0xfe, 0xcc, 0xf0, 0xe2, 0x68, 0x05,
 
5520         0x1f, 0x4d, 0x10, 0xfe, 0x12, 0x00, 0x2c, 0x0f, 0xfe, 0x4e, 0x11, 0x27,
 
5521         0xfe, 0x00, 0x0c, 0xfe, 0x9e, 0xf0, 0xfe, 0x14, 0x0c, 0xbc, 0x17, 0x34,
 
5522         0x2c, 0x77, 0xe6, 0xc5, 0x24, 0xc6, 0x24, 0x2c, 0xfa, 0x27, 0xfe, 0x20,
 
5523         0x0c, 0x1c, 0x34, 0x94, 0xfe, 0x3c, 0x0c, 0x95, 0x86, 0xc5, 0xdc, 0xc6,
 
5524         0xdc, 0x02, 0x24, 0x01, 0x4b, 0xfe, 0xdb, 0x10, 0x12, 0xfe, 0xe8, 0x00,
 
5525         0xb5, 0xb6, 0x74, 0xc7, 0x81, 0xc8, 0x83, 0xfe, 0x89, 0xf0, 0x24, 0x33,
 
5526         0x31, 0xe1, 0xc7, 0x81, 0xc8, 0x83, 0x27, 0xfe, 0x66, 0x0c, 0x1d, 0x24,
 
5527         0x33, 0x31, 0xdf, 0xbc, 0x4e, 0x10, 0xfe, 0x42, 0x00, 0x02, 0x65, 0x7c,
 
5528         0x06, 0xfe, 0x81, 0x49, 0x17, 0xfe, 0x2c, 0x0d, 0x08, 0x05, 0x0a, 0xfe,
 
5529         0x44, 0x13, 0x10, 0x00, 0x55, 0x0a, 0xfe, 0x54, 0x12, 0x55, 0xfe, 0x28,
 
5530         0x00, 0x23, 0xfe, 0x9a, 0x0d, 0x09, 0x46, 0x01, 0x0e, 0x07, 0x00, 0x66,
 
5531         0x44, 0xfe, 0x28, 0x00, 0xfe, 0xe2, 0x10, 0x01, 0xf5, 0x01, 0xf6, 0x09,
 
5532         0xa4, 0x01, 0xfe, 0x26, 0x0f, 0x64, 0x12, 0x2f, 0x01, 0x73, 0x02, 0x2b,
 
5533         0x10, 0xfe, 0x44, 0x00, 0x55, 0x0a, 0xe9, 0x44, 0x0a, 0xfe, 0xb4, 0x10,
 
5534         0x01, 0xb0, 0x44, 0x0a, 0xfe, 0xaa, 0x10, 0x01, 0xb0, 0xfe, 0x19, 0x82,
 
5535         0xfe, 0x34, 0x46, 0xac, 0x44, 0x0a, 0x10, 0xfe, 0x43, 0x00, 0xfe, 0x96,
 
5536         0x10, 0x08, 0x54, 0x0a, 0x37, 0x01, 0xf5, 0x01, 0xf6, 0x64, 0x12, 0x2f,
 
5537         0x01, 0x73, 0x99, 0x0a, 0x64, 0x42, 0x92, 0x02, 0xfe, 0x2e, 0x03, 0x08,
 
5538         0x05, 0x0a, 0x8a, 0x44, 0x0a, 0x10, 0x00, 0xfe, 0x5c, 0x10, 0x68, 0x05,
 
5539         0x1a, 0xfe, 0x58, 0x12, 0x08, 0x05, 0x1a, 0xfe, 0x50, 0x13, 0xfe, 0x1c,
 
5540         0x1c, 0xfe, 0x9d, 0xf0, 0xfe, 0x50, 0x0d, 0xfe, 0x1c, 0x1c, 0xfe, 0x9d,
 
5541         0xf0, 0xfe, 0x56, 0x0d, 0x08, 0x54, 0x1a, 0x37, 0xfe, 0xa9, 0x10, 0x10,
 
5542         0xfe, 0x15, 0x00, 0xfe, 0x04, 0xe6, 0x0a, 0x50, 0xfe, 0x2e, 0x10, 0x10,
 
5543         0xfe, 0x13, 0x00, 0xfe, 0x10, 0x10, 0x10, 0x6f, 0xab, 0x10, 0xfe, 0x41,
 
5544         0x00, 0xaa, 0x10, 0xfe, 0x24, 0x00, 0x8c, 0xb5, 0xb6, 0x74, 0x03, 0x70,
 
5545         0x28, 0x23, 0xd8, 0x50, 0xfe, 0x04, 0xe6, 0x1a, 0xfe, 0x9d, 0x41, 0xfe,
 
5546         0x1c, 0x42, 0x64, 0x01, 0xe3, 0x02, 0x2b, 0xf8, 0x15, 0x0a, 0x39, 0xa0,
 
5547         0xb4, 0x15, 0xfe, 0x31, 0x00, 0x39, 0xa2, 0x01, 0xfe, 0x48, 0x10, 0x02,
 
5548         0xd7, 0x42, 0xfe, 0x06, 0xec, 0xd0, 0xfc, 0x44, 0x1b, 0xfe, 0xce, 0x45,
 
5549         0x35, 0x42, 0xfe, 0x06, 0xea, 0xd0, 0xfe, 0x47, 0x4b, 0x91, 0xfe, 0x75,
 
5550         0x57, 0x03, 0x5d, 0xfe, 0x98, 0x56, 0xfe, 0x38, 0x12, 0x09, 0x48, 0x01,
 
5551         0x0e, 0xfe, 0x44, 0x48, 0x4f, 0x08, 0x05, 0x1b, 0xfe, 0x1a, 0x13, 0x09,
 
5552         0x46, 0x01, 0x0e, 0x41, 0xfe, 0x41, 0x58, 0x09, 0xa4, 0x01, 0x0e, 0xfe,
 
5553         0x49, 0x54, 0x96, 0xfe, 0x1e, 0x0e, 0x02, 0xfe, 0x2e, 0x03, 0x09, 0x5d,
 
5554         0xfe, 0xee, 0x14, 0xfc, 0x44, 0x1b, 0xfe, 0xce, 0x45, 0x35, 0x42, 0xfe,
 
5555         0xce, 0x47, 0xfe, 0xad, 0x13, 0x02, 0x2b, 0x22, 0x20, 0x07, 0x11, 0xfe,
 
5556         0x9e, 0x12, 0x21, 0x13, 0x59, 0x13, 0x9f, 0x13, 0xd5, 0x22, 0x2f, 0x41,
 
5557         0x39, 0x2f, 0xbc, 0xad, 0xfe, 0xbc, 0xf0, 0xfe, 0xe0, 0x0e, 0x0f, 0x06,
 
5558         0x13, 0x59, 0x01, 0xfe, 0xda, 0x16, 0x03, 0xfe, 0x38, 0x01, 0x29, 0xfe,
 
5559         0x3a, 0x01, 0x56, 0xfe, 0xe4, 0x0e, 0xfe, 0x02, 0xec, 0xd5, 0x69, 0x00,
 
5560         0x66, 0xfe, 0x04, 0xec, 0x20, 0x4f, 0xfe, 0x05, 0xf6, 0xfe, 0x34, 0x01,
 
5561         0x01, 0xfe, 0x4a, 0x17, 0xfe, 0x08, 0x90, 0xfe, 0x48, 0xf4, 0x0d, 0xfe,
 
5562         0x18, 0x13, 0xba, 0xfe, 0x02, 0xea, 0xd5, 0x69, 0x7e, 0xfe, 0xc5, 0x13,
 
5563         0x15, 0x1a, 0x39, 0xa0, 0xb4, 0xfe, 0x2e, 0x10, 0x03, 0xfe, 0x38, 0x01,
 
5564         0x1e, 0xfe, 0xf0, 0xff, 0x0c, 0xfe, 0x60, 0x01, 0x03, 0xfe, 0x3a, 0x01,
 
5565         0x0c, 0xfe, 0x62, 0x01, 0x43, 0x13, 0x20, 0x25, 0x06, 0x13, 0x2f, 0x12,
 
5566         0x2f, 0x92, 0x0f, 0x06, 0x04, 0x21, 0x04, 0x22, 0x59, 0xfe, 0xf7, 0x12,
 
5567         0x22, 0x9f, 0xb7, 0x13, 0x9f, 0x07, 0x7e, 0xfe, 0x71, 0x13, 0xfe, 0x24,
 
5568         0x1c, 0x15, 0x19, 0x39, 0xa0, 0xb4, 0xfe, 0xd9, 0x10, 0xc3, 0xfe, 0x03,
 
5569         0xdc, 0xfe, 0x73, 0x57, 0xfe, 0x80, 0x5d, 0x04, 0xc3, 0xfe, 0x03, 0xdc,
 
5570         0xfe, 0x5b, 0x57, 0xfe, 0x80, 0x5d, 0x04, 0xfe, 0x03, 0x57, 0xc3, 0x21,
 
5571         0xfe, 0x00, 0xcc, 0x04, 0xfe, 0x03, 0x57, 0xc3, 0x78, 0x04, 0x08, 0x05,
 
5572         0x58, 0xfe, 0x22, 0x13, 0xfe, 0x1c, 0x80, 0x07, 0x06, 0xfe, 0x1a, 0x13,
 
5573         0xfe, 0x1e, 0x80, 0xed, 0xfe, 0x1d, 0x80, 0xae, 0xfe, 0x0c, 0x90, 0xfe,
 
5574         0x0e, 0x13, 0xfe, 0x0e, 0x90, 0xac, 0xfe, 0x3c, 0x90, 0xfe, 0x30, 0xf4,
 
5575         0x0a, 0xfe, 0x3c, 0x50, 0xaa, 0x01, 0xfe, 0x7a, 0x17, 0x32, 0x07, 0x2f,
 
5576         0xad, 0x01, 0xfe, 0xb4, 0x16, 0x08, 0x05, 0x1b, 0x4e, 0x01, 0xf5, 0x01,
 
5577         0xf6, 0x12, 0xfe, 0xe9, 0x00, 0x08, 0x05, 0x58, 0xfe, 0x2c, 0x13, 0x01,
 
5578         0xfe, 0x0c, 0x17, 0xfe, 0x1e, 0x1c, 0xfe, 0x14, 0x90, 0xfe, 0x96, 0x90,
 
5579         0x0c, 0xfe, 0x64, 0x01, 0x14, 0xfe, 0x66, 0x01, 0x08, 0x05, 0x5b, 0xfe,
 
5580         0x12, 0x12, 0xfe, 0x03, 0x80, 0x8d, 0xfe, 0x01, 0xec, 0x20, 0xfe, 0x80,
 
5581         0x40, 0x13, 0x20, 0x6a, 0x2a, 0x12, 0xcf, 0x64, 0x22, 0x20, 0xfb, 0x79,
 
5582         0x20, 0x04, 0xfe, 0x08, 0x1c, 0x03, 0xfe, 0xac, 0x00, 0xfe, 0x06, 0x58,
 
5583         0x03, 0xfe, 0xae, 0x00, 0xfe, 0x07, 0x58, 0x03, 0xfe, 0xb0, 0x00, 0xfe,
 
5584         0x08, 0x58, 0x03, 0xfe, 0xb2, 0x00, 0xfe, 0x09, 0x58, 0xfe, 0x0a, 0x1c,
 
5585         0x25, 0x6e, 0x13, 0xd0, 0x21, 0x0c, 0x5c, 0x0c, 0x45, 0x0f, 0x46, 0x52,
 
5586         0x50, 0x18, 0x1b, 0xfe, 0x90, 0x4d, 0xfe, 0x91, 0x54, 0x23, 0xfe, 0xfc,
 
5587         0x0f, 0x44, 0x11, 0x0f, 0x48, 0x52, 0x18, 0x58, 0xfe, 0x90, 0x4d, 0xfe,
 
5588         0x91, 0x54, 0x23, 0xe4, 0x25, 0x11, 0x13, 0x20, 0x7c, 0x6f, 0x4f, 0x22,
 
5589         0x20, 0xfb, 0x79, 0x20, 0x12, 0xcf, 0xfe, 0x14, 0x56, 0xfe, 0xd6, 0xf0,
 
5590         0xfe, 0x26, 0x10, 0xf8, 0x74, 0xfe, 0x14, 0x1c, 0xfe, 0x10, 0x1c, 0xfe,
 
5591         0x18, 0x1c, 0x04, 0x42, 0xfe, 0x0c, 0x14, 0xfc, 0xfe, 0x07, 0xe6, 0x1b,
 
5592         0xfe, 0xce, 0x47, 0xfe, 0xf5, 0x13, 0x04, 0x01, 0xb0, 0x7c, 0x6f, 0x4f,
 
5593         0xfe, 0x06, 0x80, 0xfe, 0x48, 0x47, 0xfe, 0x42, 0x13, 0x32, 0x07, 0x2f,
 
5594         0xfe, 0x34, 0x13, 0x09, 0x48, 0x01, 0x0e, 0xbb, 0xfe, 0x36, 0x12, 0xfe,
 
5595         0x41, 0x48, 0xfe, 0x45, 0x48, 0x01, 0xf0, 0xfe, 0x00, 0xcc, 0xbb, 0xfe,
 
5596         0xf3, 0x13, 0x43, 0x78, 0x07, 0x11, 0xac, 0x09, 0x84, 0x01, 0x0e, 0xfe,
 
5597         0x80, 0x5c, 0x01, 0x73, 0xfe, 0x0e, 0x10, 0x07, 0x82, 0x4e, 0xfe, 0x14,
 
5598         0x56, 0xfe, 0xd6, 0xf0, 0xfe, 0x60, 0x10, 0x04, 0xfe, 0x44, 0x58, 0x8d,
 
5599         0xfe, 0x01, 0xec, 0xa2, 0xfe, 0x9e, 0x40, 0xfe, 0x9d, 0xe7, 0x00, 0xfe,
 
5600         0x9c, 0xe7, 0x1a, 0x79, 0x2a, 0x01, 0xe3, 0xfe, 0xdd, 0x10, 0x2c, 0xc7,
 
5601         0x81, 0xc8, 0x83, 0x33, 0x31, 0xde, 0x07, 0x1a, 0xfe, 0x48, 0x12, 0x07,
 
5602         0x0a, 0xfe, 0x56, 0x12, 0x07, 0x19, 0xfe, 0x30, 0x12, 0x07, 0xc9, 0x17,
 
5603         0xfe, 0x32, 0x12, 0x07, 0xfe, 0x23, 0x00, 0x17, 0xeb, 0x07, 0x06, 0x17,
 
5604         0xfe, 0x9c, 0x12, 0x07, 0x1f, 0xfe, 0x12, 0x12, 0x07, 0x00, 0x17, 0x24,
 
5605         0x15, 0xc9, 0x01, 0x36, 0xa9, 0x2d, 0x01, 0x0b, 0x94, 0x4b, 0x04, 0x2d,
 
5606         0xdd, 0x09, 0xd1, 0x01, 0xfe, 0x26, 0x0f, 0x12, 0x82, 0x02, 0x2b, 0x2d,
 
5607         0x32, 0x07, 0xa6, 0xfe, 0xd9, 0x13, 0x3a, 0x3d, 0x3b, 0x3e, 0x56, 0xfe,
 
5608         0xf0, 0x11, 0x08, 0x05, 0x5a, 0xfe, 0x72, 0x12, 0x9b, 0x2e, 0x9c, 0x3c,
 
5609         0x90, 0xc0, 0x96, 0xfe, 0xba, 0x11, 0x22, 0x62, 0xfe, 0x26, 0x13, 0x03,
 
5610         0x7f, 0x29, 0x80, 0x56, 0xfe, 0x76, 0x0d, 0x0c, 0x60, 0x14, 0x61, 0x21,
 
5611         0x0c, 0x7f, 0x0c, 0x80, 0x01, 0xb3, 0x25, 0x6e, 0x77, 0x13, 0x62, 0x01,
 
5612         0xef, 0x9b, 0x2e, 0x9c, 0x3c, 0xfe, 0x04, 0x55, 0xfe, 0xa5, 0x55, 0xfe,
 
5613         0x04, 0xfa, 0x2e, 0xfe, 0x05, 0xfa, 0x3c, 0xfe, 0x91, 0x10, 0x03, 0x3f,
 
5614         0x29, 0x40, 0xfe, 0x40, 0x56, 0xfe, 0xe1, 0x56, 0x0c, 0x3f, 0x14, 0x40,
 
5615         0x88, 0x9b, 0x2e, 0x9c, 0x3c, 0x90, 0xc0, 0x03, 0x5e, 0x29, 0x5f, 0xfe,
 
5616         0x00, 0x56, 0xfe, 0xa1, 0x56, 0x0c, 0x5e, 0x14, 0x5f, 0x08, 0x05, 0x5a,
 
5617         0xfe, 0x1e, 0x12, 0x22, 0x62, 0xfe, 0x1f, 0x40, 0x03, 0x60, 0x29, 0x61,
 
5618         0xfe, 0x2c, 0x50, 0xfe, 0xae, 0x50, 0x03, 0x3f, 0x29, 0x40, 0xfe, 0x44,
 
5619         0x50, 0xfe, 0xc6, 0x50, 0x03, 0x5e, 0x29, 0x5f, 0xfe, 0x08, 0x50, 0xfe,
 
5620         0x8a, 0x50, 0x03, 0x3d, 0x29, 0x3e, 0xfe, 0x40, 0x50, 0xfe, 0xc2, 0x50,
 
5621         0x02, 0x89, 0x25, 0x06, 0x13, 0xd4, 0x02, 0x72, 0x2d, 0x01, 0x0b, 0x1d,
 
5622         0x4c, 0x33, 0x31, 0xde, 0x07, 0x06, 0x23, 0x4c, 0x32, 0x07, 0xa6, 0x23,
 
5623         0x72, 0x01, 0xaf, 0x1e, 0x43, 0x17, 0x4c, 0x08, 0x05, 0x0a, 0xee, 0x3a,
 
5624         0x3d, 0x3b, 0x3e, 0xfe, 0x0a, 0x55, 0x35, 0xfe, 0x8b, 0x55, 0x57, 0x3d,
 
5625         0x7d, 0x3e, 0xfe, 0x0c, 0x51, 0xfe, 0x8e, 0x51, 0x02, 0x72, 0xfe, 0x19,
 
5626         0x81, 0xba, 0xfe, 0x19, 0x41, 0x02, 0x72, 0x2d, 0x01, 0x0b, 0x1c, 0x34,
 
5627         0x1d, 0xe8, 0x33, 0x31, 0xe1, 0x55, 0x19, 0xfe, 0xa6, 0x12, 0x55, 0x0a,
 
5628         0x4d, 0x02, 0x4c, 0x01, 0x0b, 0x1c, 0x34, 0x1d, 0xe8, 0x33, 0x31, 0xdf,
 
5629         0x07, 0x19, 0x23, 0x4c, 0x01, 0x0b, 0x1d, 0xe8, 0x33, 0x31, 0xfe, 0xe8,
 
5630         0x09, 0xfe, 0xc2, 0x49, 0x51, 0x03, 0xfe, 0x9c, 0x00, 0x28, 0x8a, 0x53,
 
5631         0x05, 0x1f, 0x35, 0xa9, 0xfe, 0xbb, 0x45, 0x55, 0x00, 0x4e, 0x44, 0x06,
 
5632         0x7c, 0x43, 0xfe, 0xda, 0x14, 0x01, 0xaf, 0x8c, 0xfe, 0x4b, 0x45, 0xee,
 
5633         0x32, 0x07, 0xa5, 0xed, 0x03, 0xcd, 0x28, 0x8a, 0x03, 0x45, 0x28, 0x35,
 
5634         0x67, 0x02, 0x72, 0xfe, 0xc0, 0x5d, 0xfe, 0xf8, 0x14, 0xfe, 0x03, 0x17,
 
5635         0x03, 0x5c, 0xc1, 0x0c, 0x5c, 0x67, 0x2d, 0x01, 0x0b, 0x26, 0x89, 0x01,
 
5636         0xfe, 0x9e, 0x15, 0x02, 0x89, 0x01, 0x0b, 0x1c, 0x34, 0x1d, 0x4c, 0x33,
 
5637         0x31, 0xdf, 0x07, 0x06, 0x23, 0x4c, 0x01, 0xf1, 0xfe, 0x42, 0x58, 0xf1,
 
5638         0xfe, 0xa4, 0x14, 0x8c, 0xfe, 0x4a, 0xf4, 0x0a, 0x17, 0x4c, 0xfe, 0x4a,
 
5639         0xf4, 0x06, 0xea, 0x32, 0x07, 0xa5, 0x8b, 0x02, 0x72, 0x03, 0x45, 0xc1,
 
5640         0x0c, 0x45, 0x67, 0x2d, 0x01, 0x0b, 0x26, 0x89, 0x01, 0xfe, 0xcc, 0x15,
 
5641         0x02, 0x89, 0x0f, 0x06, 0x27, 0xfe, 0xbe, 0x13, 0x26, 0xfe, 0xd4, 0x13,
 
5642         0x76, 0xfe, 0x89, 0x48, 0x01, 0x0b, 0x21, 0x76, 0x04, 0x7b, 0xfe, 0xd0,
 
5643         0x13, 0x1c, 0xfe, 0xd0, 0x13, 0x1d, 0xfe, 0xbe, 0x13, 0x67, 0x2d, 0x01,
 
5644         0x0b, 0xfe, 0xd5, 0x10, 0x0f, 0x71, 0xff, 0x02, 0x00, 0x57, 0x52, 0x93,
 
5645         0x1e, 0xfe, 0xff, 0x7f, 0xfe, 0x30, 0x56, 0xfe, 0x00, 0x5c, 0x04, 0x0f,
 
5646         0x71, 0xff, 0x02, 0x00, 0x57, 0x52, 0x93, 0x1e, 0x43, 0xfe, 0x30, 0x56,
 
5647         0xfe, 0x00, 0x5c, 0x04, 0x0f, 0x71, 0xff, 0x02, 0x00, 0x57, 0x52, 0x93,
 
5648         0x04, 0x0f, 0x71, 0xff, 0x02, 0x00, 0x57, 0x52, 0x93, 0xfe, 0x0b, 0x58,
 
5649         0x04, 0x09, 0x5c, 0x01, 0x87, 0x09, 0x45, 0x01, 0x87, 0x04, 0xfe, 0x03,
 
5650         0xa1, 0x1e, 0x11, 0xff, 0x03, 0x00, 0x54, 0xfe, 0x00, 0xf4, 0x1f, 0x52,
 
5651         0xfe, 0x00, 0x7d, 0xfe, 0x01, 0x7d, 0xfe, 0x02, 0x7d, 0xfe, 0x03, 0x7c,
 
5652         0x6a, 0x2a, 0x0c, 0x5e, 0x14, 0x5f, 0x57, 0x3f, 0x7d, 0x40, 0x04, 0xdd,
 
5653         0xfe, 0x82, 0x4a, 0xfe, 0xe1, 0x1a, 0xfe, 0x83, 0x5a, 0x8d, 0x04, 0x01,
 
5654         0xfe, 0x0c, 0x19, 0xfe, 0x42, 0x48, 0x50, 0x51, 0x91, 0x01, 0x0b, 0x1d,
 
5655         0xfe, 0x96, 0x15, 0x33, 0x31, 0xe1, 0x01, 0x0b, 0x1d, 0xfe, 0x96, 0x15,
 
5656         0x33, 0x31, 0xfe, 0xe8, 0x0a, 0xfe, 0xc1, 0x59, 0x03, 0xcd, 0x28, 0xfe,
 
5657         0xcc, 0x12, 0x53, 0x05, 0x1a, 0xfe, 0xc4, 0x13, 0x21, 0x69, 0x1a, 0xee,
 
5658         0x55, 0xca, 0x6b, 0xfe, 0xdc, 0x14, 0x4d, 0x0f, 0x06, 0x18, 0xca, 0x7c,
 
5659         0x30, 0xfe, 0x78, 0x10, 0xff, 0x02, 0x83, 0x55, 0xab, 0xff, 0x02, 0x83,
 
5660         0x55, 0x69, 0x19, 0xae, 0x98, 0xfe, 0x30, 0x00, 0x96, 0xf2, 0x18, 0x6d,
 
5661         0x0f, 0x06, 0xfe, 0x56, 0x10, 0x69, 0x0a, 0xed, 0x98, 0xfe, 0x64, 0x00,
 
5662         0x96, 0xf2, 0x09, 0xfe, 0x64, 0x00, 0x18, 0x9e, 0x0f, 0x06, 0xfe, 0x28,
 
5663         0x10, 0x69, 0x06, 0xfe, 0x60, 0x13, 0x98, 0xfe, 0xc8, 0x00, 0x96, 0xf2,
 
5664         0x09, 0xfe, 0xc8, 0x00, 0x18, 0x59, 0x0f, 0x06, 0x88, 0x98, 0xfe, 0x90,
 
5665         0x01, 0x7a, 0xfe, 0x42, 0x15, 0x91, 0xe4, 0xfe, 0x43, 0xf4, 0x9f, 0xfe,
 
5666         0x56, 0xf0, 0xfe, 0x54, 0x15, 0xfe, 0x04, 0xf4, 0x71, 0xfe, 0x43, 0xf4,
 
5667         0x9e, 0xfe, 0xf3, 0x10, 0xfe, 0x40, 0x5c, 0x01, 0xfe, 0x16, 0x14, 0x1e,
 
5668         0x43, 0xec, 0xfe, 0x00, 0x17, 0xfe, 0x4d, 0xe4, 0x6e, 0x7a, 0xfe, 0x90,
 
5669         0x15, 0xc4, 0x6e, 0xfe, 0x1c, 0x10, 0xfe, 0x00, 0x17, 0xfe, 0x4d, 0xe4,
 
5670         0xcc, 0x7a, 0xfe, 0x90, 0x15, 0xc4, 0xcc, 0x88, 0x51, 0x21, 0xfe, 0x4d,
 
5671         0xf4, 0x00, 0xe9, 0x91, 0x0f, 0x06, 0xfe, 0xb4, 0x56, 0xfe, 0xc3, 0x58,
 
5672         0x04, 0x51, 0x0f, 0x0a, 0x04, 0x16, 0x06, 0x01, 0x0b, 0x26, 0xf3, 0x16,
 
5673         0x0a, 0x01, 0x0b, 0x26, 0xf3, 0x16, 0x19, 0x01, 0x0b, 0x26, 0xf3, 0x76,
 
5674         0xfe, 0x89, 0x49, 0x01, 0x0b, 0x04, 0x16, 0x06, 0x01, 0x0b, 0x26, 0xb1,
 
5675         0x16, 0x19, 0x01, 0x0b, 0x26, 0xb1, 0x16, 0x06, 0x01, 0x0b, 0x26, 0xb1,
 
5676         0xfe, 0x89, 0x49, 0x01, 0x0b, 0x26, 0xb1, 0x76, 0xfe, 0x89, 0x4a, 0x01,
 
5677         0x0b, 0x04, 0x51, 0x04, 0x22, 0xd3, 0x07, 0x06, 0xfe, 0x48, 0x13, 0xb8,
 
5678         0x13, 0xd3, 0xfe, 0x49, 0xf4, 0x00, 0x4d, 0x76, 0xa9, 0x67, 0xfe, 0x01,
 
5679         0xec, 0xfe, 0x27, 0x01, 0xfe, 0x89, 0x48, 0xff, 0x02, 0x00, 0x10, 0x27,
 
5680         0xfe, 0x2e, 0x16, 0x32, 0x07, 0xfe, 0xe3, 0x00, 0xfe, 0x20, 0x13, 0x1d,
 
5681         0xfe, 0x52, 0x16, 0x21, 0x13, 0xd4, 0x01, 0x4b, 0x22, 0xd4, 0x07, 0x06,
 
5682         0x4e, 0x08, 0x54, 0x06, 0x37, 0x04, 0x09, 0x48, 0x01, 0x0e, 0xfb, 0x8e,
 
5683         0x07, 0x11, 0xae, 0x09, 0x84, 0x01, 0x0e, 0x8e, 0x09, 0x5d, 0x01, 0xa8,
 
5684         0x04, 0x09, 0x84, 0x01, 0x0e, 0x8e, 0xfe, 0x80, 0xe7, 0x11, 0x07, 0x11,
 
5685         0x8a, 0xfe, 0x45, 0x58, 0x01, 0xf0, 0x8e, 0x04, 0x09, 0x48, 0x01, 0x0e,
 
5686         0x8e, 0x09, 0x5d, 0x01, 0xa8, 0x04, 0x09, 0x48, 0x01, 0x0e, 0xfe, 0x80,
 
5687         0x80, 0xfe, 0x80, 0x4c, 0xfe, 0x49, 0xe4, 0x11, 0xae, 0x09, 0x84, 0x01,
 
5688         0x0e, 0xfe, 0x80, 0x4c, 0x09, 0x5d, 0x01, 0x87, 0x04, 0x18, 0x11, 0x75,
 
5689         0x6c, 0xfe, 0x60, 0x01, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde, 0xfe, 0x24,
 
5690         0x1c, 0xfe, 0x1d, 0xf7, 0x1b, 0x97, 0xfe, 0xee, 0x16, 0x01, 0xfe, 0xf4,
 
5691         0x17, 0xad, 0x9a, 0x1b, 0x6c, 0xfe, 0x2c, 0x01, 0xfe, 0x2f, 0x19, 0x04,
 
5692         0xb9, 0x23, 0xfe, 0xde, 0x16, 0xfe, 0xda, 0x10, 0x18, 0x11, 0x75, 0x03,
 
5693         0xfe, 0x64, 0x01, 0xfe, 0x00, 0xf4, 0x1f, 0xfe, 0x18, 0x58, 0x03, 0xfe,
 
5694         0x66, 0x01, 0xfe, 0x19, 0x58, 0x9a, 0x1f, 0xfe, 0x3c, 0x90, 0xfe, 0x30,
 
5695         0xf4, 0x06, 0xfe, 0x3c, 0x50, 0x6c, 0xfe, 0x38, 0x00, 0xfe, 0x0f, 0x79,
 
5696         0xfe, 0x1c, 0xf7, 0x1f, 0x97, 0xfe, 0x38, 0x17, 0xfe, 0xb6, 0x14, 0x35,
 
5697         0x04, 0xb9, 0x23, 0xfe, 0x10, 0x17, 0xfe, 0x9c, 0x10, 0x18, 0x11, 0x75,
 
5698         0xfe, 0x83, 0x5a, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde, 0xfe, 0x1d, 0xf7,
 
5699         0x2e, 0x97, 0xfe, 0x5a, 0x17, 0xfe, 0x94, 0x14, 0xec, 0x9a, 0x2e, 0x6c,
 
5700         0x1a, 0xfe, 0xaf, 0x19, 0xfe, 0x98, 0xe7, 0x00, 0x04, 0xb9, 0x23, 0xfe,
 
5701         0x4e, 0x17, 0xfe, 0x6c, 0x10, 0x18, 0x11, 0x75, 0xfe, 0x30, 0xbc, 0xfe,
 
5702         0xb2, 0xbc, 0x9a, 0xcb, 0x6c, 0x1a, 0xfe, 0x0f, 0x79, 0xfe, 0x1c, 0xf7,
 
5703         0xcb, 0x97, 0xfe, 0x92, 0x17, 0xfe, 0x5c, 0x14, 0x35, 0x04, 0xb9, 0x23,
 
5704         0xfe, 0x7e, 0x17, 0xfe, 0x42, 0x10, 0xfe, 0x02, 0xf6, 0x11, 0x75, 0xfe,
 
5705         0x18, 0xfe, 0x60, 0xfe, 0x19, 0xfe, 0x61, 0xfe, 0x03, 0xa1, 0xfe, 0x1d,
 
5706         0xf7, 0x5b, 0x97, 0xfe, 0xb8, 0x17, 0xfe, 0x36, 0x14, 0xfe, 0x1c, 0x13,
 
5707         0x9a, 0x5b, 0x41, 0xfe, 0x83, 0x58, 0xfe, 0xaf, 0x19, 0xfe, 0x80, 0xe7,
 
5708         0x11, 0xfe, 0x81, 0xe7, 0x11, 0x12, 0xfe, 0xdd, 0x00, 0x6a, 0x2a, 0x04,
 
5709         0x6a, 0x2a, 0xfe, 0x12, 0x45, 0x23, 0xfe, 0xa8, 0x17, 0x15, 0x06, 0x39,
 
5710         0xa0, 0xb4, 0x02, 0x2b, 0xfe, 0x39, 0xf0, 0xfe, 0xfc, 0x17, 0x21, 0x04,
 
5711         0xfe, 0x7e, 0x18, 0x1e, 0x19, 0x66, 0x0f, 0x0d, 0x04, 0x75, 0x03, 0xd2,
 
5712         0x1e, 0x06, 0xfe, 0xef, 0x12, 0xfe, 0xe1, 0x10, 0x7c, 0x6f, 0x4f, 0x32,
 
5713         0x07, 0x2f, 0xfe, 0x3c, 0x13, 0xf1, 0xfe, 0x42, 0x13, 0x42, 0x92, 0x09,
 
5714         0x48, 0x01, 0x0e, 0xbb, 0xeb, 0xfe, 0x41, 0x48, 0xfe, 0x45, 0x48, 0x01,
 
5715         0xf0, 0xfe, 0x00, 0xcc, 0xbb, 0xfe, 0xf3, 0x13, 0x43, 0x78, 0x07, 0x11,
 
5716         0xac, 0x09, 0x84, 0x01, 0x0e, 0xfe, 0x80, 0x4c, 0x01, 0x73, 0xfe, 0x16,
 
5717         0x10, 0x07, 0x82, 0x8b, 0xfe, 0x40, 0x14, 0xfe, 0x24, 0x12, 0xfe, 0x14,
 
5718         0x56, 0xfe, 0xd6, 0xf0, 0xfe, 0x1c, 0x18, 0x18, 0x0a, 0x04, 0xfe, 0x9c,
 
5719         0xe7, 0x0a, 0x10, 0xfe, 0x15, 0x00, 0x64, 0x79, 0x2a, 0x01, 0xe3, 0x18,
 
5720         0x06, 0x04, 0x42, 0x92, 0x08, 0x54, 0x1b, 0x37, 0x12, 0x2f, 0x01, 0x73,
 
5721         0x18, 0x06, 0x04, 0xfe, 0x38, 0x90, 0xfe, 0xba, 0x90, 0x3a, 0xce, 0x3b,
 
5722         0xcf, 0xfe, 0x48, 0x55, 0x35, 0xfe, 0xc9, 0x55, 0x04, 0x22, 0xa3, 0x77,
 
5723         0x13, 0xa3, 0x04, 0x09, 0xa4, 0x01, 0x0e, 0xfe, 0x41, 0x48, 0x09, 0x46,
 
5724         0x01, 0x0e, 0xfe, 0x49, 0x44, 0x17, 0xfe, 0xe8, 0x18, 0x77, 0x78, 0x04,
 
5725         0x09, 0x48, 0x01, 0x0e, 0x07, 0x11, 0x4e, 0x09, 0x5d, 0x01, 0xa8, 0x09,
 
5726         0x46, 0x01, 0x0e, 0x77, 0x78, 0x04, 0xfe, 0x4e, 0xe4, 0x19, 0x6b, 0xfe,
 
5727         0x1c, 0x19, 0x03, 0xfe, 0x90, 0x00, 0xfe, 0x3a, 0x45, 0xfe, 0x2c, 0x10,
 
5728         0xfe, 0x4e, 0xe4, 0xc9, 0x6b, 0xfe, 0x2e, 0x19, 0x03, 0xfe, 0x92, 0x00,
 
5729         0xfe, 0x02, 0xe6, 0x1a, 0xe5, 0xfe, 0x4e, 0xe4, 0xfe, 0x0b, 0x00, 0x6b,
 
5730         0xfe, 0x40, 0x19, 0x03, 0xfe, 0x94, 0x00, 0xfe, 0x02, 0xe6, 0x1f, 0xfe,
 
5731         0x08, 0x10, 0x03, 0xfe, 0x96, 0x00, 0xfe, 0x02, 0xe6, 0x6d, 0xfe, 0x4e,
 
5732         0x45, 0xea, 0xba, 0xff, 0x04, 0x68, 0x54, 0xe7, 0x1e, 0x6e, 0xfe, 0x08,
 
5733         0x1c, 0xfe, 0x67, 0x19, 0xfe, 0x0a, 0x1c, 0xfe, 0x1a, 0xf4, 0xfe, 0x00,
 
5734         0x04, 0xea, 0xfe, 0x48, 0xf4, 0x19, 0x7a, 0xfe, 0x74, 0x19, 0x0f, 0x19,
 
5735         0x04, 0x07, 0x7e, 0xfe, 0x5a, 0xf0, 0xfe, 0x84, 0x19, 0x25, 0xfe, 0x09,
 
5736         0x00, 0xfe, 0x34, 0x10, 0x07, 0x1a, 0xfe, 0x5a, 0xf0, 0xfe, 0x92, 0x19,
 
5737         0x25, 0xca, 0xfe, 0x26, 0x10, 0x07, 0x19, 0x66, 0x25, 0x6d, 0xe5, 0x07,
 
5738         0x0a, 0x66, 0x25, 0x9e, 0xfe, 0x0e, 0x10, 0x07, 0x06, 0x66, 0x25, 0x59,
 
5739         0xa9, 0xb8, 0x04, 0x15, 0xfe, 0x09, 0x00, 0x01, 0x36, 0xfe, 0x04, 0xfe,
 
5740         0x81, 0x03, 0x83, 0xfe, 0x40, 0x5c, 0x04, 0x1c, 0xf7, 0xfe, 0x14, 0xf0,
 
5741         0x0b, 0x27, 0xfe, 0xd6, 0x19, 0x1c, 0xf7, 0x7b, 0xf7, 0xfe, 0x82, 0xf0,
 
5742         0xfe, 0xda, 0x19, 0x04, 0xff, 0xcc, 0x00, 0x00,
 
5745 static unsigned short _adv_asc38C0800_size = sizeof(_adv_asc38C0800_buf);       /* 0x14E1 */
 
5746 static ADV_DCNT _adv_asc38C0800_chksum = 0x050D3FD8UL;  /* Expanded little-endian checksum. */
 
5748 /* Microcode buffer is kept after initialization for error recovery. */
 
5749 static unsigned char _adv_asc38C1600_buf[] = {
 
5750         0x00, 0x00, 0x00, 0xf2, 0x00, 0x16, 0x00, 0xfc, 0x00, 0x10, 0x00, 0xf0,
 
5751         0x18, 0xe4, 0x01, 0x00, 0x04, 0x1e, 0x48, 0xe4, 0x03, 0xf6, 0xf7, 0x13,
 
5752         0x2e, 0x1e, 0x02, 0x00, 0x07, 0x17, 0xc0, 0x5f, 0x00, 0xfa, 0xff, 0xff,
 
5753         0x04, 0x00, 0x00, 0xf6, 0x09, 0xe7, 0x82, 0xe7, 0x85, 0xf0, 0x86, 0xf0,
 
5754         0x4e, 0x10, 0x9e, 0xe7, 0xff, 0x00, 0x55, 0xf0, 0x01, 0xf6, 0x03, 0x00,
 
5755         0x98, 0x57, 0x01, 0xe6, 0x00, 0xea, 0x00, 0xec, 0x01, 0xfa, 0x18, 0xf4,
 
5756         0x08, 0x00, 0xf0, 0x1d, 0x38, 0x54, 0x32, 0xf0, 0x10, 0x00, 0xc2, 0x0e,
 
5757         0x1e, 0xf0, 0xd5, 0xf0, 0xbc, 0x00, 0x4b, 0xe4, 0x00, 0xe6, 0xb1, 0xf0,
 
5758         0xb4, 0x00, 0x02, 0x13, 0x3e, 0x1c, 0xc8, 0x47, 0x3e, 0x00, 0xd8, 0x01,
 
5759         0x06, 0x13, 0x0c, 0x1c, 0x5e, 0x1e, 0x00, 0x57, 0xc8, 0x57, 0x01, 0xfc,
 
5760         0xbc, 0x0e, 0xa2, 0x12, 0xb9, 0x54, 0x00, 0x80, 0x62, 0x0a, 0x5a, 0x12,
 
5761         0xc8, 0x15, 0x3e, 0x1e, 0x18, 0x40, 0xbd, 0x56, 0x03, 0xe6, 0x01, 0xea,
 
5762         0x5c, 0xf0, 0x0f, 0x00, 0x20, 0x00, 0x6c, 0x01, 0x6e, 0x01, 0x04, 0x12,
 
5763         0x04, 0x13, 0xbb, 0x55, 0x3c, 0x56, 0x3e, 0x57, 0x03, 0x58, 0x4a, 0xe4,
 
5764         0x40, 0x00, 0xb6, 0x00, 0xbb, 0x00, 0xc0, 0x00, 0x00, 0x01, 0x01, 0x01,
 
5765         0x3e, 0x01, 0x58, 0x0a, 0x44, 0x10, 0x0a, 0x12, 0x4c, 0x1c, 0x4e, 0x1c,
 
5766         0x02, 0x4a, 0x30, 0xe4, 0x05, 0xe6, 0x0c, 0x00, 0x3c, 0x00, 0x80, 0x00,
 
5767         0x24, 0x01, 0x3c, 0x01, 0x68, 0x01, 0x6a, 0x01, 0x70, 0x01, 0x72, 0x01,
 
5768         0x74, 0x01, 0x76, 0x01, 0x78, 0x01, 0x7c, 0x01, 0xc6, 0x0e, 0x0c, 0x10,
 
5769         0xac, 0x12, 0xae, 0x12, 0x16, 0x1a, 0x32, 0x1c, 0x6e, 0x1e, 0x02, 0x48,
 
5770         0x3a, 0x55, 0xc9, 0x57, 0x02, 0xee, 0x5b, 0xf0, 0x03, 0xf7, 0x06, 0xf7,
 
5771         0x03, 0xfc, 0x06, 0x00, 0x1e, 0x00, 0xbe, 0x00, 0xe1, 0x00, 0x0c, 0x12,
 
5772         0x18, 0x1a, 0x70, 0x1a, 0x30, 0x1c, 0x38, 0x1c, 0x10, 0x44, 0x00, 0x4c,
 
5773         0xb0, 0x57, 0x40, 0x5c, 0x4d, 0xe4, 0x04, 0xea, 0x5d, 0xf0, 0xa7, 0xf0,
 
5774         0x04, 0xf6, 0x02, 0xfc, 0x05, 0x00, 0x09, 0x00, 0x19, 0x00, 0x32, 0x00,
 
5775         0x33, 0x00, 0x34, 0x00, 0x36, 0x00, 0x98, 0x00, 0x9e, 0x00, 0xcc, 0x00,
 
5776         0x20, 0x01, 0x4e, 0x01, 0x79, 0x01, 0x3c, 0x09, 0x68, 0x0d, 0x02, 0x10,
 
5777         0x04, 0x10, 0x3a, 0x10, 0x08, 0x12, 0x0a, 0x13, 0x40, 0x16, 0x50, 0x16,
 
5778         0x00, 0x17, 0x4a, 0x19, 0x00, 0x4e, 0x00, 0x54, 0x01, 0x58, 0x00, 0xdc,
 
5779         0x05, 0xf0, 0x09, 0xf0, 0x59, 0xf0, 0xb8, 0xf0, 0x48, 0xf4, 0x0e, 0xf7,
 
5780         0x0a, 0x00, 0x9b, 0x00, 0x9c, 0x00, 0xa4, 0x00, 0xb5, 0x00, 0xba, 0x00,
 
5781         0xd0, 0x00, 0xe7, 0x00, 0xf0, 0x03, 0x69, 0x08, 0xe9, 0x09, 0x5c, 0x0c,
 
5782         0xb6, 0x12, 0xbc, 0x19, 0xd8, 0x1b, 0x20, 0x1c, 0x34, 0x1c, 0x36, 0x1c,
 
5783         0x42, 0x1d, 0x08, 0x44, 0x38, 0x44, 0x91, 0x44, 0x0a, 0x45, 0x48, 0x46,
 
5784         0x89, 0x48, 0x68, 0x54, 0x83, 0x55, 0x83, 0x59, 0x31, 0xe4, 0x02, 0xe6,
 
5785         0x07, 0xf0, 0x08, 0xf0, 0x0b, 0xf0, 0x0c, 0xf0, 0x4b, 0xf4, 0x04, 0xf8,
 
5786         0x05, 0xf8, 0x02, 0xfa, 0x03, 0xfa, 0x04, 0xfc, 0x05, 0xfc, 0x07, 0x00,
 
5787         0xa8, 0x00, 0xaa, 0x00, 0xb9, 0x00, 0xe0, 0x00, 0xe5, 0x00, 0x22, 0x01,
 
5788         0x26, 0x01, 0x60, 0x01, 0x7a, 0x01, 0x82, 0x01, 0xc8, 0x01, 0xca, 0x01,
 
5789         0x86, 0x02, 0x6a, 0x03, 0x18, 0x05, 0xb2, 0x07, 0x68, 0x08, 0x10, 0x0d,
 
5790         0x06, 0x10, 0x0a, 0x10, 0x0e, 0x10, 0x12, 0x10, 0x60, 0x10, 0xed, 0x10,
 
5791         0xf3, 0x10, 0x06, 0x12, 0x10, 0x12, 0x1e, 0x12, 0x0c, 0x13, 0x0e, 0x13,
 
5792         0x10, 0x13, 0xfe, 0x9c, 0xf0, 0x35, 0x05, 0xfe, 0xec, 0x0e, 0xff, 0x10,
 
5793         0x00, 0x00, 0xe9, 0xfe, 0x34, 0x1f, 0x00, 0xe8, 0xfe, 0x88, 0x01, 0xff,
 
5794         0x03, 0x00, 0x00, 0xfe, 0x93, 0x15, 0xfe, 0x0f, 0x05, 0xff, 0x38, 0x00,
 
5795         0x00, 0xfe, 0x57, 0x24, 0x00, 0xfe, 0x4c, 0x00, 0x65, 0xff, 0x04, 0x00,
 
5796         0x00, 0x1a, 0xff, 0x09, 0x00, 0x00, 0xff, 0x08, 0x01, 0x01, 0xff, 0x08,
 
5797         0xff, 0xff, 0xff, 0x27, 0x00, 0x00, 0xff, 0x10, 0xff, 0xff, 0xff, 0x13,
 
5798         0x00, 0x00, 0xfe, 0x78, 0x56, 0xfe, 0x34, 0x12, 0xff, 0x21, 0x00, 0x00,
 
5799         0xfe, 0x04, 0xf7, 0xe8, 0x37, 0x7d, 0x0d, 0x01, 0xfe, 0x4a, 0x11, 0xfe,
 
5800         0x04, 0xf7, 0xe8, 0x7d, 0x0d, 0x51, 0x37, 0xfe, 0x3d, 0xf0, 0xfe, 0x0c,
 
5801         0x02, 0xfe, 0x20, 0xf0, 0xbc, 0xfe, 0x91, 0xf0, 0xfe, 0xf8, 0x01, 0xfe,
 
5802         0x90, 0xf0, 0xfe, 0xf8, 0x01, 0xfe, 0x8f, 0xf0, 0xbc, 0x03, 0x67, 0x4d,
 
5803         0x05, 0xfe, 0x08, 0x0f, 0x01, 0xfe, 0x78, 0x0f, 0xfe, 0xdd, 0x12, 0x05,
 
5804         0xfe, 0x0e, 0x03, 0xfe, 0x28, 0x1c, 0x03, 0xfe, 0xa6, 0x00, 0xfe, 0xd1,
 
5805         0x12, 0x3e, 0x22, 0xfe, 0xa6, 0x00, 0xac, 0xfe, 0x48, 0xf0, 0xfe, 0x90,
 
5806         0x02, 0xfe, 0x49, 0xf0, 0xfe, 0xaa, 0x02, 0xfe, 0x4a, 0xf0, 0xfe, 0xc8,
 
5807         0x02, 0xfe, 0x46, 0xf0, 0xfe, 0x5a, 0x02, 0xfe, 0x47, 0xf0, 0xfe, 0x60,
 
5808         0x02, 0xfe, 0x43, 0xf0, 0xfe, 0x4e, 0x02, 0xfe, 0x44, 0xf0, 0xfe, 0x52,
 
5809         0x02, 0xfe, 0x45, 0xf0, 0xfe, 0x56, 0x02, 0x1c, 0x0d, 0xa2, 0x1c, 0x07,
 
5810         0x22, 0xb7, 0x05, 0x35, 0xfe, 0x00, 0x1c, 0xfe, 0xf1, 0x10, 0xfe, 0x02,
 
5811         0x1c, 0xf5, 0xfe, 0x1e, 0x1c, 0xfe, 0xe9, 0x10, 0x01, 0x5f, 0xfe, 0xe7,
 
5812         0x10, 0xfe, 0x06, 0xfc, 0xde, 0x0a, 0x81, 0x01, 0xa3, 0x05, 0x35, 0x1f,
 
5813         0x95, 0x47, 0xb8, 0x01, 0xfe, 0xe4, 0x11, 0x0a, 0x81, 0x01, 0x5c, 0xfe,
 
5814         0xbd, 0x10, 0x0a, 0x81, 0x01, 0x5c, 0xfe, 0xad, 0x10, 0xfe, 0x16, 0x1c,
 
5815         0xfe, 0x58, 0x1c, 0x1c, 0x07, 0x22, 0xb7, 0x37, 0x2a, 0x35, 0xfe, 0x3d,
 
5816         0xf0, 0xfe, 0x0c, 0x02, 0x2b, 0xfe, 0x9e, 0x02, 0xfe, 0x5a, 0x1c, 0xfe,
 
5817         0x12, 0x1c, 0xfe, 0x14, 0x1c, 0x1f, 0xfe, 0x30, 0x00, 0x47, 0xb8, 0x01,
 
5818         0xfe, 0xd4, 0x11, 0x1c, 0x07, 0x22, 0xb7, 0x05, 0xe9, 0x21, 0x2c, 0x09,
 
5819         0x1a, 0x31, 0xfe, 0x69, 0x10, 0x1c, 0x07, 0x22, 0xb7, 0xfe, 0x04, 0xec,
 
5820         0x2c, 0x60, 0x01, 0xfe, 0x1e, 0x1e, 0x20, 0x2c, 0xfe, 0x05, 0xf6, 0xde,
 
5821         0x01, 0xfe, 0x62, 0x1b, 0x01, 0x0c, 0x61, 0x4a, 0x44, 0x15, 0x56, 0x51,
 
5822         0x01, 0xfe, 0x9e, 0x1e, 0x01, 0xfe, 0x96, 0x1a, 0x05, 0x35, 0x0a, 0x57,
 
5823         0x01, 0x18, 0x09, 0x00, 0x36, 0x01, 0x85, 0xfe, 0x18, 0x10, 0xfe, 0x41,
 
5824         0x58, 0x0a, 0xba, 0x01, 0x18, 0xfe, 0xc8, 0x54, 0x7b, 0xfe, 0x1c, 0x03,
 
5825         0x01, 0xfe, 0x96, 0x1a, 0x05, 0x35, 0x37, 0x60, 0xfe, 0x02, 0xe8, 0x30,
 
5826         0xfe, 0xbf, 0x57, 0xfe, 0x9e, 0x43, 0xfe, 0x77, 0x57, 0xfe, 0x27, 0xf0,
 
5827         0xfe, 0xe4, 0x01, 0xfe, 0x07, 0x4b, 0xfe, 0x20, 0xf0, 0xbc, 0xfe, 0x40,
 
5828         0x1c, 0x2a, 0xeb, 0xfe, 0x26, 0xf0, 0xfe, 0x66, 0x03, 0xfe, 0xa0, 0xf0,
 
5829         0xfe, 0x54, 0x03, 0xfe, 0x11, 0xf0, 0xbc, 0xfe, 0xef, 0x10, 0xfe, 0x9f,
 
5830         0xf0, 0xfe, 0x74, 0x03, 0xfe, 0x46, 0x1c, 0x19, 0xfe, 0x11, 0x00, 0x05,
 
5831         0x70, 0x37, 0xfe, 0x48, 0x1c, 0xfe, 0x46, 0x1c, 0x01, 0x0c, 0x06, 0x28,
 
5832         0xfe, 0x18, 0x13, 0x26, 0x21, 0xb9, 0xc7, 0x20, 0xb9, 0x0a, 0x57, 0x01,
 
5833         0x18, 0xc7, 0x89, 0x01, 0xfe, 0xc8, 0x1a, 0x15, 0xe1, 0x2a, 0xeb, 0xfe,
 
5834         0x01, 0xf0, 0xeb, 0xfe, 0x82, 0xf0, 0xfe, 0xa4, 0x03, 0xfe, 0x9c, 0x32,
 
5835         0x15, 0xfe, 0xe4, 0x00, 0x2f, 0xfe, 0xb6, 0x03, 0x2a, 0x3c, 0x16, 0xfe,
 
5836         0xc6, 0x03, 0x01, 0x41, 0xfe, 0x06, 0xf0, 0xfe, 0xd6, 0x03, 0xaf, 0xa0,
 
5837         0xfe, 0x0a, 0xf0, 0xfe, 0xa2, 0x07, 0x05, 0x29, 0x03, 0x81, 0x1e, 0x1b,
 
5838         0xfe, 0x24, 0x05, 0x1f, 0x63, 0x01, 0x42, 0x8f, 0xfe, 0x70, 0x02, 0x05,
 
5839         0xea, 0xfe, 0x46, 0x1c, 0x37, 0x7d, 0x1d, 0xfe, 0x67, 0x1b, 0xfe, 0xbf,
 
5840         0x57, 0xfe, 0x77, 0x57, 0xfe, 0x48, 0x1c, 0x75, 0x01, 0xa6, 0x86, 0x0a,
 
5841         0x57, 0x01, 0x18, 0x09, 0x00, 0x1b, 0xec, 0x0a, 0xe1, 0x01, 0x18, 0x77,
 
5842         0x50, 0x40, 0x8d, 0x30, 0x03, 0x81, 0x1e, 0xf8, 0x1f, 0x63, 0x01, 0x42,
 
5843         0x8f, 0xfe, 0x70, 0x02, 0x05, 0xea, 0xd7, 0x99, 0xd8, 0x9c, 0x2a, 0x29,
 
5844         0x2f, 0xfe, 0x4e, 0x04, 0x16, 0xfe, 0x4a, 0x04, 0x7e, 0xfe, 0xa0, 0x00,
 
5845         0xfe, 0x9b, 0x57, 0xfe, 0x54, 0x12, 0x32, 0xff, 0x02, 0x00, 0x10, 0x01,
 
5846         0x08, 0x16, 0xfe, 0x02, 0x05, 0x32, 0x01, 0x08, 0x16, 0x29, 0x27, 0x25,
 
5847         0xee, 0xfe, 0x4c, 0x44, 0xfe, 0x58, 0x12, 0x50, 0xfe, 0x44, 0x48, 0x13,
 
5848         0x34, 0xfe, 0x4c, 0x54, 0x7b, 0xec, 0x60, 0x8d, 0x30, 0x01, 0xfe, 0x4e,
 
5849         0x1e, 0xfe, 0x48, 0x47, 0xfe, 0x7c, 0x13, 0x01, 0x0c, 0x06, 0x28, 0xfe,
 
5850         0x32, 0x13, 0x01, 0x43, 0x09, 0x9b, 0xfe, 0x68, 0x13, 0xfe, 0x26, 0x10,
 
5851         0x13, 0x34, 0xfe, 0x4c, 0x54, 0x7b, 0xec, 0x01, 0xfe, 0x4e, 0x1e, 0xfe,
 
5852         0x48, 0x47, 0xfe, 0x54, 0x13, 0x01, 0x0c, 0x06, 0x28, 0xa5, 0x01, 0x43,
 
5853         0x09, 0x9b, 0xfe, 0x40, 0x13, 0x01, 0x0c, 0x06, 0x28, 0xf9, 0x1f, 0x7f,
 
5854         0x01, 0x0c, 0x06, 0x07, 0x4d, 0x1f, 0xfe, 0x0d, 0x00, 0x01, 0x42, 0x8f,
 
5855         0xfe, 0xa4, 0x0e, 0x05, 0x29, 0x32, 0x15, 0xfe, 0xe6, 0x00, 0x0f, 0xfe,
 
5856         0x1c, 0x90, 0x04, 0xfe, 0x9c, 0x93, 0x3a, 0x0b, 0x0e, 0x8b, 0x02, 0x1f,
 
5857         0x7f, 0x01, 0x42, 0x05, 0x35, 0xfe, 0x42, 0x5b, 0x7d, 0x1d, 0xfe, 0x46,
 
5858         0x59, 0xfe, 0xbf, 0x57, 0xfe, 0x77, 0x57, 0x0f, 0xfe, 0x87, 0x80, 0x04,
 
5859         0xfe, 0x87, 0x83, 0xfe, 0xc9, 0x47, 0x0b, 0x0e, 0xd0, 0x65, 0x01, 0x0c,
 
5860         0x06, 0x0d, 0xfe, 0x98, 0x13, 0x0f, 0xfe, 0x20, 0x80, 0x04, 0xfe, 0xa0,
 
5861         0x83, 0x33, 0x0b, 0x0e, 0x09, 0x1d, 0xfe, 0x84, 0x12, 0x01, 0x38, 0x06,
 
5862         0x07, 0xfe, 0x70, 0x13, 0x03, 0xfe, 0xa2, 0x00, 0x1e, 0x1b, 0xfe, 0xda,
 
5863         0x05, 0xd0, 0x54, 0x01, 0x38, 0x06, 0x0d, 0xfe, 0x58, 0x13, 0x03, 0xfe,
 
5864         0xa0, 0x00, 0x1e, 0xfe, 0x50, 0x12, 0x5e, 0xff, 0x02, 0x00, 0x10, 0x2f,
 
5865         0xfe, 0x90, 0x05, 0x2a, 0x3c, 0xcc, 0xff, 0x02, 0x00, 0x10, 0x2f, 0xfe,
 
5866         0x9e, 0x05, 0x17, 0xfe, 0xf4, 0x05, 0x15, 0xfe, 0xe3, 0x00, 0x26, 0x01,
 
5867         0x38, 0xfe, 0x4a, 0xf0, 0xfe, 0xc0, 0x05, 0xfe, 0x49, 0xf0, 0xfe, 0xba,
 
5868         0x05, 0x71, 0x2e, 0xfe, 0x21, 0x00, 0xf1, 0x2e, 0xfe, 0x22, 0x00, 0xa2,
 
5869         0x2e, 0x4a, 0xfe, 0x09, 0x48, 0xff, 0x02, 0x00, 0x10, 0x2f, 0xfe, 0xd0,
 
5870         0x05, 0x17, 0xfe, 0xf4, 0x05, 0xfe, 0xe2, 0x08, 0x01, 0x38, 0x06, 0xfe,
 
5871         0x1c, 0x00, 0x4d, 0x01, 0xa7, 0x2e, 0x07, 0x20, 0xe4, 0x47, 0xfe, 0x27,
 
5872         0x01, 0x01, 0x0c, 0x06, 0x28, 0xfe, 0x24, 0x12, 0x3e, 0x01, 0x84, 0x1f,
 
5873         0x7f, 0x01, 0x0c, 0x06, 0x07, 0x4d, 0x1f, 0xfe, 0x0d, 0x00, 0x01, 0x42,
 
5874         0x8f, 0xfe, 0xa4, 0x0e, 0x05, 0x29, 0x03, 0xe6, 0x1e, 0xfe, 0xca, 0x13,
 
5875         0x03, 0xb6, 0x1e, 0xfe, 0x40, 0x12, 0x03, 0x66, 0x1e, 0xfe, 0x38, 0x13,
 
5876         0x3e, 0x01, 0x84, 0x17, 0xfe, 0x72, 0x06, 0x0a, 0x07, 0x01, 0x38, 0x06,
 
5877         0x24, 0xfe, 0x02, 0x12, 0x4f, 0x01, 0xfe, 0x56, 0x19, 0x16, 0xfe, 0x68,
 
5878         0x06, 0x15, 0x82, 0x01, 0x41, 0x15, 0xe2, 0x03, 0x66, 0x8a, 0x10, 0x66,
 
5879         0x03, 0x9a, 0x1e, 0xfe, 0x70, 0x12, 0x03, 0x55, 0x1e, 0xfe, 0x68, 0x13,
 
5880         0x01, 0xc6, 0x09, 0x12, 0x48, 0xfe, 0x92, 0x06, 0x2e, 0x12, 0x01, 0xfe,
 
5881         0xac, 0x1d, 0xfe, 0x43, 0x48, 0x62, 0x80, 0x13, 0x58, 0xff, 0x02, 0x00,
 
5882         0x57, 0x52, 0xad, 0x23, 0x3f, 0x4e, 0x62, 0x49, 0x3e, 0x01, 0x84, 0x17,
 
5883         0xfe, 0xea, 0x06, 0x01, 0x38, 0x06, 0x12, 0xf7, 0x45, 0x0a, 0x95, 0x01,
 
5884         0xfe, 0x84, 0x19, 0x16, 0xfe, 0xe0, 0x06, 0x15, 0x82, 0x01, 0x41, 0x15,
 
5885         0xe2, 0x03, 0x55, 0x8a, 0x10, 0x55, 0x1c, 0x07, 0x01, 0x84, 0xfe, 0xae,
 
5886         0x10, 0x03, 0x6f, 0x1e, 0xfe, 0x9e, 0x13, 0x3e, 0x01, 0x84, 0x03, 0x9a,
 
5887         0x1e, 0xfe, 0x1a, 0x12, 0x01, 0x38, 0x06, 0x12, 0xfc, 0x01, 0xc6, 0x01,
 
5888         0xfe, 0xac, 0x1d, 0xfe, 0x43, 0x48, 0x62, 0x80, 0xf0, 0x45, 0x0a, 0x95,
 
5889         0x03, 0xb6, 0x1e, 0xf8, 0x01, 0x38, 0x06, 0x24, 0x36, 0xfe, 0x02, 0xf6,
 
5890         0x07, 0x71, 0x78, 0x8c, 0x00, 0x4d, 0x62, 0x49, 0x3e, 0x2d, 0x93, 0x4e,
 
5891         0xd0, 0x0d, 0x17, 0xfe, 0x9a, 0x07, 0x01, 0xfe, 0xc0, 0x19, 0x16, 0xfe,
 
5892         0x90, 0x07, 0x26, 0x20, 0x9e, 0x15, 0x82, 0x01, 0x41, 0x15, 0xe2, 0x21,
 
5893         0x9e, 0x09, 0x07, 0xfb, 0x03, 0xe6, 0xfe, 0x58, 0x57, 0x10, 0xe6, 0x05,
 
5894         0xfe, 0x2a, 0x06, 0x03, 0x6f, 0x8a, 0x10, 0x6f, 0x1c, 0x07, 0x01, 0x84,
 
5895         0xfe, 0x9c, 0x32, 0x5f, 0x75, 0x01, 0xa6, 0x86, 0x15, 0xfe, 0xe2, 0x00,
 
5896         0x2f, 0xed, 0x2a, 0x3c, 0xfe, 0x0a, 0xf0, 0xfe, 0xce, 0x07, 0xae, 0xfe,
 
5897         0x96, 0x08, 0xfe, 0x06, 0xf0, 0xfe, 0x9e, 0x08, 0xaf, 0xa0, 0x05, 0x29,
 
5898         0x01, 0x0c, 0x06, 0x0d, 0xfe, 0x2e, 0x12, 0x14, 0x1d, 0x01, 0x08, 0x14,
 
5899         0x00, 0x01, 0x08, 0x14, 0x00, 0x01, 0x08, 0x14, 0x00, 0x01, 0x08, 0xfe,
 
5900         0x99, 0xa4, 0x01, 0x08, 0x14, 0x00, 0x05, 0xfe, 0xc6, 0x09, 0x01, 0x76,
 
5901         0x06, 0x12, 0xfe, 0x3a, 0x12, 0x01, 0x0c, 0x06, 0x12, 0xfe, 0x30, 0x13,
 
5902         0x14, 0xfe, 0x1b, 0x00, 0x01, 0x08, 0x14, 0x00, 0x01, 0x08, 0x14, 0x00,
 
5903         0x01, 0x08, 0x14, 0x00, 0x01, 0x08, 0x14, 0x07, 0x01, 0x08, 0x14, 0x00,
 
5904         0x05, 0xef, 0x7c, 0x4a, 0x78, 0x4f, 0x0f, 0xfe, 0x9a, 0x81, 0x04, 0xfe,
 
5905         0x9a, 0x83, 0xfe, 0xcb, 0x47, 0x0b, 0x0e, 0x2d, 0x28, 0x48, 0xfe, 0x6c,
 
5906         0x08, 0x0a, 0x28, 0xfe, 0x09, 0x6f, 0xca, 0xfe, 0xca, 0x45, 0xfe, 0x32,
 
5907         0x12, 0x53, 0x63, 0x4e, 0x7c, 0x97, 0x2f, 0xfe, 0x7e, 0x08, 0x2a, 0x3c,
 
5908         0xfe, 0x0a, 0xf0, 0xfe, 0x6c, 0x08, 0xaf, 0xa0, 0xae, 0xfe, 0x96, 0x08,
 
5909         0x05, 0x29, 0x01, 0x41, 0x05, 0xed, 0x14, 0x24, 0x05, 0xed, 0xfe, 0x9c,
 
5910         0xf7, 0x9f, 0x01, 0xfe, 0xae, 0x1e, 0xfe, 0x18, 0x58, 0x01, 0xfe, 0xbe,
 
5911         0x1e, 0xfe, 0x99, 0x58, 0xfe, 0x78, 0x18, 0xfe, 0xf9, 0x18, 0x8e, 0xfe,
 
5912         0x16, 0x09, 0x10, 0x6a, 0x22, 0x6b, 0x01, 0x0c, 0x61, 0x54, 0x44, 0x21,
 
5913         0x2c, 0x09, 0x1a, 0xf8, 0x77, 0x01, 0xfe, 0x7e, 0x1e, 0x47, 0x2c, 0x7a,
 
5914         0x30, 0xf0, 0xfe, 0x83, 0xe7, 0xfe, 0x3f, 0x00, 0x71, 0xfe, 0x03, 0x40,
 
5915         0x01, 0x0c, 0x61, 0x65, 0x44, 0x01, 0xc2, 0xc8, 0xfe, 0x1f, 0x40, 0x20,
 
5916         0x6e, 0x01, 0xfe, 0x6a, 0x16, 0xfe, 0x08, 0x50, 0xfe, 0x8a, 0x50, 0xfe,
 
5917         0x44, 0x51, 0xfe, 0xc6, 0x51, 0xfe, 0x10, 0x10, 0x01, 0xfe, 0xce, 0x1e,
 
5918         0x01, 0xfe, 0xde, 0x1e, 0x10, 0x68, 0x22, 0x69, 0x01, 0xfe, 0xee, 0x1e,
 
5919         0x01, 0xfe, 0xfe, 0x1e, 0xfe, 0x40, 0x50, 0xfe, 0xc2, 0x50, 0x10, 0x4b,
 
5920         0x22, 0x4c, 0xfe, 0x8a, 0x10, 0x01, 0x0c, 0x06, 0x54, 0xfe, 0x50, 0x12,
 
5921         0x01, 0xfe, 0xae, 0x1e, 0x01, 0xfe, 0xbe, 0x1e, 0x10, 0x6a, 0x22, 0x6b,
 
5922         0x01, 0x0c, 0x06, 0x65, 0x4e, 0x01, 0xc2, 0x0f, 0xfe, 0x1f, 0x80, 0x04,
 
5923         0xfe, 0x9f, 0x83, 0x33, 0x0b, 0x0e, 0x20, 0x6e, 0x0f, 0xfe, 0x44, 0x90,
 
5924         0x04, 0xfe, 0xc4, 0x93, 0x3a, 0x0b, 0xfe, 0xc6, 0x90, 0x04, 0xfe, 0xc6,
 
5925         0x93, 0x79, 0x0b, 0x0e, 0x10, 0x6c, 0x22, 0x6d, 0x01, 0xfe, 0xce, 0x1e,
 
5926         0x01, 0xfe, 0xde, 0x1e, 0x10, 0x68, 0x22, 0x69, 0x0f, 0xfe, 0x40, 0x90,
 
5927         0x04, 0xfe, 0xc0, 0x93, 0x3a, 0x0b, 0xfe, 0xc2, 0x90, 0x04, 0xfe, 0xc2,
 
5928         0x93, 0x79, 0x0b, 0x0e, 0x10, 0x4b, 0x22, 0x4c, 0x10, 0x64, 0x22, 0x34,
 
5929         0x01, 0x0c, 0x61, 0x24, 0x44, 0x37, 0x13, 0xfe, 0x4e, 0x11, 0x2f, 0xfe,
 
5930         0xde, 0x09, 0xfe, 0x9e, 0xf0, 0xfe, 0xf2, 0x09, 0xfe, 0x01, 0x48, 0x1b,
 
5931         0x3c, 0x37, 0x88, 0xf5, 0xd4, 0xfe, 0x1e, 0x0a, 0xd5, 0xfe, 0x42, 0x0a,
 
5932         0xd2, 0xfe, 0x1e, 0x0a, 0xd3, 0xfe, 0x42, 0x0a, 0xae, 0xfe, 0x12, 0x0a,
 
5933         0xfe, 0x06, 0xf0, 0xfe, 0x18, 0x0a, 0xaf, 0xa0, 0x05, 0x29, 0x01, 0x41,
 
5934         0xfe, 0xc1, 0x10, 0x14, 0x24, 0xfe, 0xc1, 0x10, 0x01, 0x76, 0x06, 0x07,
 
5935         0xfe, 0x14, 0x12, 0x01, 0x76, 0x06, 0x0d, 0x5d, 0x01, 0x0c, 0x06, 0x0d,
 
5936         0xfe, 0x74, 0x12, 0xfe, 0x2e, 0x1c, 0x05, 0xfe, 0x1a, 0x0c, 0x01, 0x76,
 
5937         0x06, 0x07, 0x5d, 0x01, 0x76, 0x06, 0x0d, 0x41, 0xfe, 0x2c, 0x1c, 0xfe,
 
5938         0xaa, 0xf0, 0xfe, 0xce, 0x0a, 0xfe, 0xac, 0xf0, 0xfe, 0x66, 0x0a, 0xfe,
 
5939         0x92, 0x10, 0xc4, 0xf6, 0xfe, 0xad, 0xf0, 0xfe, 0x72, 0x0a, 0x05, 0xfe,
 
5940         0x1a, 0x0c, 0xc5, 0xfe, 0xe7, 0x10, 0xfe, 0x2b, 0xf0, 0xbf, 0xfe, 0x6b,
 
5941         0x18, 0x23, 0xfe, 0x00, 0xfe, 0xfe, 0x1c, 0x12, 0xac, 0xfe, 0xd2, 0xf0,
 
5942         0xbf, 0xfe, 0x76, 0x18, 0x23, 0x1d, 0x1b, 0xbf, 0x03, 0xe3, 0x23, 0x07,
 
5943         0x1b, 0xbf, 0xd4, 0x5b, 0xd5, 0x5b, 0xd2, 0x5b, 0xd3, 0x5b, 0xc4, 0xc5,
 
5944         0xfe, 0xa9, 0x10, 0x75, 0x5e, 0x32, 0x1f, 0x7f, 0x01, 0x42, 0x19, 0xfe,
 
5945         0x35, 0x00, 0xfe, 0x01, 0xf0, 0x70, 0x19, 0x98, 0x05, 0x70, 0xfe, 0x74,
 
5946         0x18, 0x23, 0xfe, 0x00, 0xf8, 0x1b, 0x5b, 0x7d, 0x12, 0x01, 0xfe, 0x78,
 
5947         0x0f, 0x4d, 0x01, 0xfe, 0x96, 0x1a, 0x21, 0x30, 0x77, 0x7d, 0x1d, 0x05,
 
5948         0x5b, 0x01, 0x0c, 0x06, 0x0d, 0x2b, 0xfe, 0xe2, 0x0b, 0x01, 0x0c, 0x06,
 
5949         0x54, 0xfe, 0xa6, 0x12, 0x01, 0x0c, 0x06, 0x24, 0xfe, 0x88, 0x13, 0x21,
 
5950         0x6e, 0xc7, 0x01, 0xfe, 0x1e, 0x1f, 0x0f, 0xfe, 0x83, 0x80, 0x04, 0xfe,
 
5951         0x83, 0x83, 0xfe, 0xc9, 0x47, 0x0b, 0x0e, 0xfe, 0xc8, 0x44, 0xfe, 0x42,
 
5952         0x13, 0x0f, 0xfe, 0x04, 0x91, 0x04, 0xfe, 0x84, 0x93, 0xfe, 0xca, 0x57,
 
5953         0x0b, 0xfe, 0x86, 0x91, 0x04, 0xfe, 0x86, 0x93, 0xfe, 0xcb, 0x57, 0x0b,
 
5954         0x0e, 0x7a, 0x30, 0xfe, 0x40, 0x59, 0xfe, 0xc1, 0x59, 0x8e, 0x40, 0x03,
 
5955         0x6a, 0x3b, 0x6b, 0x10, 0x97, 0x22, 0x98, 0xd9, 0x6a, 0xda, 0x6b, 0x01,
 
5956         0xc2, 0xc8, 0x7a, 0x30, 0x20, 0x6e, 0xdb, 0x64, 0xdc, 0x34, 0x91, 0x6c,
 
5957         0x7e, 0x6d, 0xfe, 0x44, 0x55, 0xfe, 0xe5, 0x55, 0xfe, 0x04, 0xfa, 0x64,
 
5958         0xfe, 0x05, 0xfa, 0x34, 0x01, 0xfe, 0x6a, 0x16, 0xa3, 0x26, 0x10, 0x97,
 
5959         0x10, 0x98, 0x91, 0x6c, 0x7e, 0x6d, 0xfe, 0x14, 0x10, 0x01, 0x0c, 0x06,
 
5960         0x24, 0x1b, 0x40, 0x91, 0x4b, 0x7e, 0x4c, 0x01, 0x0c, 0x06, 0xfe, 0xf7,
 
5961         0x00, 0x44, 0x03, 0x68, 0x3b, 0x69, 0xfe, 0x10, 0x58, 0xfe, 0x91, 0x58,
 
5962         0xfe, 0x14, 0x59, 0xfe, 0x95, 0x59, 0x05, 0x5b, 0x01, 0x0c, 0x06, 0x24,
 
5963         0x1b, 0x40, 0x01, 0x0c, 0x06, 0xfe, 0xf7, 0x00, 0x44, 0x78, 0x01, 0xfe,
 
5964         0x8e, 0x1e, 0x4f, 0x0f, 0xfe, 0x10, 0x90, 0x04, 0xfe, 0x90, 0x93, 0x3a,
 
5965         0x0b, 0xfe, 0x92, 0x90, 0x04, 0xfe, 0x92, 0x93, 0x79, 0x0b, 0x0e, 0xfe,
 
5966         0xbd, 0x10, 0x01, 0x43, 0x09, 0xbb, 0x1b, 0xfe, 0x6e, 0x0a, 0x15, 0xbb,
 
5967         0x01, 0x0c, 0x06, 0x0d, 0xfe, 0x14, 0x13, 0x03, 0x4b, 0x3b, 0x4c, 0x8e,
 
5968         0xfe, 0x6e, 0x0a, 0xfe, 0x0c, 0x58, 0xfe, 0x8d, 0x58, 0x05, 0x5b, 0x26,
 
5969         0x3e, 0x0f, 0xfe, 0x19, 0x80, 0x04, 0xfe, 0x99, 0x83, 0x33, 0x0b, 0x0e,
 
5970         0xfe, 0xe5, 0x10, 0x01, 0x0c, 0x06, 0x0d, 0xfe, 0x1a, 0x12, 0xfe, 0x6c,
 
5971         0x19, 0xfe, 0x19, 0x41, 0xfe, 0x6b, 0x18, 0xac, 0xfe, 0xd1, 0xf0, 0xef,
 
5972         0x1f, 0x92, 0x01, 0x42, 0x19, 0xfe, 0x44, 0x00, 0xfe, 0x90, 0x10, 0xfe,
 
5973         0x6c, 0x19, 0xd9, 0x4b, 0xfe, 0xed, 0x19, 0xda, 0x4c, 0xfe, 0x0c, 0x51,
 
5974         0xfe, 0x8e, 0x51, 0xfe, 0x6b, 0x18, 0x23, 0xfe, 0x00, 0xff, 0x31, 0xfe,
 
5975         0x76, 0x10, 0xac, 0xfe, 0xd2, 0xf0, 0xfe, 0xba, 0x0c, 0xfe, 0x76, 0x18,
 
5976         0x23, 0x1d, 0x5d, 0x03, 0xe3, 0x23, 0x07, 0xfe, 0x08, 0x13, 0x19, 0xfe,
 
5977         0x16, 0x00, 0x05, 0x70, 0xfe, 0xd1, 0xf0, 0xfe, 0xcc, 0x0c, 0x1f, 0x92,
 
5978         0x01, 0x42, 0x19, 0xfe, 0x17, 0x00, 0x5c, 0xfe, 0xce, 0xf0, 0xfe, 0xd2,
 
5979         0x0c, 0xfe, 0x3e, 0x10, 0xfe, 0xcd, 0xf0, 0xfe, 0xde, 0x0c, 0x19, 0xfe,
 
5980         0x22, 0x00, 0x05, 0x70, 0xfe, 0xcb, 0xf0, 0xfe, 0xea, 0x0c, 0x19, 0xfe,
 
5981         0x24, 0x00, 0x05, 0x70, 0xfe, 0xd0, 0xf0, 0xfe, 0xf4, 0x0c, 0x19, 0x94,
 
5982         0xfe, 0x1c, 0x10, 0xfe, 0xcf, 0xf0, 0xfe, 0xfe, 0x0c, 0x19, 0x4a, 0xf3,
 
5983         0xfe, 0xcc, 0xf0, 0xef, 0x01, 0x76, 0x06, 0x24, 0x4d, 0x19, 0xfe, 0x12,
 
5984         0x00, 0x37, 0x13, 0xfe, 0x4e, 0x11, 0x2f, 0xfe, 0x16, 0x0d, 0xfe, 0x9e,
 
5985         0xf0, 0xfe, 0x2a, 0x0d, 0xfe, 0x01, 0x48, 0x1b, 0x3c, 0x37, 0x88, 0xf5,
 
5986         0xd4, 0x29, 0xd5, 0x29, 0xd2, 0x29, 0xd3, 0x29, 0x37, 0xfe, 0x9c, 0x32,
 
5987         0x2f, 0xfe, 0x3e, 0x0d, 0x2a, 0x3c, 0xae, 0xfe, 0x62, 0x0d, 0xaf, 0xa0,
 
5988         0xd4, 0x9f, 0xd5, 0x9f, 0xd2, 0x9f, 0xd3, 0x9f, 0x05, 0x29, 0x01, 0x41,
 
5989         0xfe, 0xd3, 0x10, 0x15, 0xfe, 0xe8, 0x00, 0xc4, 0xc5, 0x75, 0xd7, 0x99,
 
5990         0xd8, 0x9c, 0xfe, 0x89, 0xf0, 0x29, 0x27, 0x25, 0xbe, 0xd7, 0x99, 0xd8,
 
5991         0x9c, 0x2f, 0xfe, 0x8c, 0x0d, 0x16, 0x29, 0x27, 0x25, 0xbd, 0xfe, 0x01,
 
5992         0x48, 0xa4, 0x19, 0xfe, 0x42, 0x00, 0x05, 0x70, 0x90, 0x07, 0xfe, 0x81,
 
5993         0x49, 0x1b, 0xfe, 0x64, 0x0e, 0x01, 0x0c, 0x06, 0x0d, 0xfe, 0x44, 0x13,
 
5994         0x19, 0x00, 0x2d, 0x0d, 0xfe, 0x54, 0x12, 0x2d, 0xfe, 0x28, 0x00, 0x2b,
 
5995         0xfe, 0xda, 0x0e, 0x0a, 0x57, 0x01, 0x18, 0x09, 0x00, 0x36, 0x46, 0xfe,
 
5996         0x28, 0x00, 0xfe, 0xfa, 0x10, 0x01, 0xfe, 0xf4, 0x1c, 0x01, 0xfe, 0x00,
 
5997         0x1d, 0x0a, 0xba, 0x01, 0xfe, 0x58, 0x10, 0x40, 0x15, 0x56, 0x01, 0x85,
 
5998         0x05, 0x35, 0x19, 0xfe, 0x44, 0x00, 0x2d, 0x0d, 0xf7, 0x46, 0x0d, 0xfe,
 
5999         0xcc, 0x10, 0x01, 0xa7, 0x46, 0x0d, 0xfe, 0xc2, 0x10, 0x01, 0xa7, 0x0f,
 
6000         0xfe, 0x19, 0x82, 0x04, 0xfe, 0x99, 0x83, 0xfe, 0xcc, 0x47, 0x0b, 0x0e,
 
6001         0xfe, 0x34, 0x46, 0xa5, 0x46, 0x0d, 0x19, 0xfe, 0x43, 0x00, 0xfe, 0xa2,
 
6002         0x10, 0x01, 0x0c, 0x61, 0x0d, 0x44, 0x01, 0xfe, 0xf4, 0x1c, 0x01, 0xfe,
 
6003         0x00, 0x1d, 0x40, 0x15, 0x56, 0x01, 0x85, 0x7d, 0x0d, 0x40, 0x51, 0x01,
 
6004         0xfe, 0x9e, 0x1e, 0x05, 0xfe, 0x3a, 0x03, 0x01, 0x0c, 0x06, 0x0d, 0x5d,
 
6005         0x46, 0x0d, 0x19, 0x00, 0xfe, 0x62, 0x10, 0x01, 0x76, 0x06, 0x12, 0xfe,
 
6006         0x5c, 0x12, 0x01, 0x0c, 0x06, 0x12, 0xfe, 0x52, 0x13, 0xfe, 0x1c, 0x1c,
 
6007         0xfe, 0x9d, 0xf0, 0xfe, 0x8e, 0x0e, 0xfe, 0x1c, 0x1c, 0xfe, 0x9d, 0xf0,
 
6008         0xfe, 0x94, 0x0e, 0x01, 0x0c, 0x61, 0x12, 0x44, 0xfe, 0x9f, 0x10, 0x19,
 
6009         0xfe, 0x15, 0x00, 0xfe, 0x04, 0xe6, 0x0d, 0x4f, 0xfe, 0x2e, 0x10, 0x19,
 
6010         0xfe, 0x13, 0x00, 0xfe, 0x10, 0x10, 0x19, 0xfe, 0x47, 0x00, 0xf1, 0x19,
 
6011         0xfe, 0x41, 0x00, 0xa2, 0x19, 0xfe, 0x24, 0x00, 0x86, 0xc4, 0xc5, 0x75,
 
6012         0x03, 0x81, 0x1e, 0x2b, 0xea, 0x4f, 0xfe, 0x04, 0xe6, 0x12, 0xfe, 0x9d,
 
6013         0x41, 0xfe, 0x1c, 0x42, 0x40, 0x01, 0xf4, 0x05, 0x35, 0xfe, 0x12, 0x1c,
 
6014         0x1f, 0x0d, 0x47, 0xb5, 0xc3, 0x1f, 0xfe, 0x31, 0x00, 0x47, 0xb8, 0x01,
 
6015         0xfe, 0xd4, 0x11, 0x05, 0xe9, 0x51, 0xfe, 0x06, 0xec, 0xe0, 0xfe, 0x0e,
 
6016         0x47, 0x46, 0x28, 0xfe, 0xce, 0x45, 0x31, 0x51, 0xfe, 0x06, 0xea, 0xe0,
 
6017         0xfe, 0x47, 0x4b, 0x45, 0xfe, 0x75, 0x57, 0x03, 0x67, 0xfe, 0x98, 0x56,
 
6018         0xfe, 0x38, 0x12, 0x0a, 0x5a, 0x01, 0x18, 0xfe, 0x44, 0x48, 0x60, 0x01,
 
6019         0x0c, 0x06, 0x28, 0xfe, 0x18, 0x13, 0x0a, 0x57, 0x01, 0x18, 0x3e, 0xfe,
 
6020         0x41, 0x58, 0x0a, 0xba, 0xfe, 0xfa, 0x14, 0xfe, 0x49, 0x54, 0xb0, 0xfe,
 
6021         0x5e, 0x0f, 0x05, 0xfe, 0x3a, 0x03, 0x0a, 0x67, 0xfe, 0xe0, 0x14, 0xfe,
 
6022         0x0e, 0x47, 0x46, 0x28, 0xfe, 0xce, 0x45, 0x31, 0x51, 0xfe, 0xce, 0x47,
 
6023         0xfe, 0xad, 0x13, 0x05, 0x35, 0x21, 0x2c, 0x09, 0x1a, 0xfe, 0x98, 0x12,
 
6024         0x26, 0x20, 0x96, 0x20, 0xe7, 0xfe, 0x08, 0x1c, 0xfe, 0x7c, 0x19, 0xfe,
 
6025         0xfd, 0x19, 0xfe, 0x0a, 0x1c, 0x03, 0xe5, 0xfe, 0x48, 0x55, 0xa5, 0x3b,
 
6026         0xfe, 0x62, 0x01, 0xfe, 0xc9, 0x55, 0x31, 0xfe, 0x74, 0x10, 0x01, 0xfe,
 
6027         0xf0, 0x1a, 0x03, 0xfe, 0x38, 0x01, 0x3b, 0xfe, 0x3a, 0x01, 0x8e, 0xfe,
 
6028         0x1e, 0x10, 0xfe, 0x02, 0xec, 0xe7, 0x53, 0x00, 0x36, 0xfe, 0x04, 0xec,
 
6029         0x2c, 0x60, 0xfe, 0x05, 0xf6, 0xfe, 0x34, 0x01, 0x01, 0xfe, 0x62, 0x1b,
 
6030         0x01, 0xfe, 0xce, 0x1e, 0xb2, 0x11, 0xfe, 0x18, 0x13, 0xca, 0xfe, 0x02,
 
6031         0xea, 0xe7, 0x53, 0x92, 0xfe, 0xc3, 0x13, 0x1f, 0x12, 0x47, 0xb5, 0xc3,
 
6032         0xfe, 0x2a, 0x10, 0x03, 0xfe, 0x38, 0x01, 0x23, 0xfe, 0xf0, 0xff, 0x10,
 
6033         0xe5, 0x03, 0xfe, 0x3a, 0x01, 0x10, 0xfe, 0x62, 0x01, 0x01, 0xfe, 0x1e,
 
6034         0x1e, 0x20, 0x2c, 0x15, 0x56, 0x01, 0xfe, 0x9e, 0x1e, 0x13, 0x07, 0x02,
 
6035         0x26, 0x02, 0x21, 0x96, 0xc7, 0x20, 0x96, 0x09, 0x92, 0xfe, 0x79, 0x13,
 
6036         0x1f, 0x1d, 0x47, 0xb5, 0xc3, 0xfe, 0xe1, 0x10, 0xcf, 0xfe, 0x03, 0xdc,
 
6037         0xfe, 0x73, 0x57, 0xfe, 0x80, 0x5d, 0x02, 0xcf, 0xfe, 0x03, 0xdc, 0xfe,
 
6038         0x5b, 0x57, 0xfe, 0x80, 0x5d, 0x02, 0xfe, 0x03, 0x57, 0xcf, 0x26, 0xfe,
 
6039         0x00, 0xcc, 0x02, 0xfe, 0x03, 0x57, 0xcf, 0x89, 0x02, 0x01, 0x0c, 0x06,
 
6040         0x4a, 0xfe, 0x4e, 0x13, 0x0f, 0xfe, 0x1c, 0x80, 0x04, 0xfe, 0x9c, 0x83,
 
6041         0x33, 0x0b, 0x0e, 0x09, 0x07, 0xfe, 0x3a, 0x13, 0x0f, 0xfe, 0x1e, 0x80,
 
6042         0x04, 0xfe, 0x9e, 0x83, 0x33, 0x0b, 0x0e, 0xfe, 0x2a, 0x13, 0x0f, 0xfe,
 
6043         0x1d, 0x80, 0x04, 0xfe, 0x9d, 0x83, 0xfe, 0xf9, 0x13, 0x0e, 0xfe, 0x1c,
 
6044         0x13, 0x01, 0xfe, 0xee, 0x1e, 0xac, 0xfe, 0x14, 0x13, 0x01, 0xfe, 0xfe,
 
6045         0x1e, 0xfe, 0x81, 0x58, 0xfa, 0x01, 0xfe, 0x0e, 0x1f, 0xfe, 0x30, 0xf4,
 
6046         0x0d, 0xfe, 0x3c, 0x50, 0xa2, 0x01, 0xfe, 0x92, 0x1b, 0x01, 0x43, 0x09,
 
6047         0x56, 0xfb, 0x01, 0xfe, 0xc8, 0x1a, 0x01, 0x0c, 0x06, 0x28, 0xa4, 0x01,
 
6048         0xfe, 0xf4, 0x1c, 0x01, 0xfe, 0x00, 0x1d, 0x15, 0xfe, 0xe9, 0x00, 0x01,
 
6049         0x0c, 0x06, 0x4a, 0xfe, 0x4e, 0x13, 0x01, 0xfe, 0x22, 0x1b, 0xfe, 0x1e,
 
6050         0x1c, 0x0f, 0xfe, 0x14, 0x90, 0x04, 0xfe, 0x94, 0x93, 0x3a, 0x0b, 0xfe,
 
6051         0x96, 0x90, 0x04, 0xfe, 0x96, 0x93, 0x79, 0x0b, 0x0e, 0x10, 0xfe, 0x64,
 
6052         0x01, 0x22, 0xfe, 0x66, 0x01, 0x01, 0x0c, 0x06, 0x65, 0xf9, 0x0f, 0xfe,
 
6053         0x03, 0x80, 0x04, 0xfe, 0x83, 0x83, 0x33, 0x0b, 0x0e, 0x77, 0xfe, 0x01,
 
6054         0xec, 0x2c, 0xfe, 0x80, 0x40, 0x20, 0x2c, 0x7a, 0x30, 0x15, 0xdf, 0x40,
 
6055         0x21, 0x2c, 0xfe, 0x00, 0x40, 0x8d, 0x2c, 0x02, 0xfe, 0x08, 0x1c, 0x03,
 
6056         0xfe, 0xac, 0x00, 0xfe, 0x06, 0x58, 0x03, 0xfe, 0xae, 0x00, 0xfe, 0x07,
 
6057         0x58, 0x03, 0xfe, 0xb0, 0x00, 0xfe, 0x08, 0x58, 0x03, 0xfe, 0xb2, 0x00,
 
6058         0xfe, 0x09, 0x58, 0xfe, 0x0a, 0x1c, 0x2e, 0x49, 0x20, 0xe0, 0x26, 0x10,
 
6059         0x66, 0x10, 0x55, 0x10, 0x6f, 0x13, 0x57, 0x52, 0x4f, 0x1c, 0x28, 0xfe,
 
6060         0x90, 0x4d, 0xfe, 0x91, 0x54, 0x2b, 0xfe, 0x88, 0x11, 0x46, 0x1a, 0x13,
 
6061         0x5a, 0x52, 0x1c, 0x4a, 0xfe, 0x90, 0x4d, 0xfe, 0x91, 0x54, 0x2b, 0xfe,
 
6062         0x9e, 0x11, 0x2e, 0x1a, 0x20, 0x2c, 0x90, 0x34, 0x60, 0x21, 0x2c, 0xfe,
 
6063         0x00, 0x40, 0x8d, 0x2c, 0x15, 0xdf, 0xfe, 0x14, 0x56, 0xfe, 0xd6, 0xf0,
 
6064         0xfe, 0xb2, 0x11, 0xfe, 0x12, 0x1c, 0x75, 0xfe, 0x14, 0x1c, 0xfe, 0x10,
 
6065         0x1c, 0xfe, 0x18, 0x1c, 0x02, 0x51, 0xfe, 0x0c, 0x14, 0xfe, 0x0e, 0x47,
 
6066         0xfe, 0x07, 0xe6, 0x28, 0xfe, 0xce, 0x47, 0xfe, 0xf5, 0x13, 0x02, 0x01,
 
6067         0xa7, 0x90, 0x34, 0x60, 0xfe, 0x06, 0x80, 0xfe, 0x48, 0x47, 0xfe, 0x42,
 
6068         0x13, 0xfe, 0x02, 0x80, 0x09, 0x56, 0xfe, 0x34, 0x13, 0x0a, 0x5a, 0x01,
 
6069         0x18, 0xcb, 0xfe, 0x36, 0x12, 0xfe, 0x41, 0x48, 0xfe, 0x45, 0x48, 0x01,
 
6070         0xfe, 0xb2, 0x16, 0xfe, 0x00, 0xcc, 0xcb, 0xfe, 0xf3, 0x13, 0x3f, 0x89,
 
6071         0x09, 0x1a, 0xa5, 0x0a, 0x9d, 0x01, 0x18, 0xfe, 0x80, 0x5c, 0x01, 0x85,
 
6072         0xf2, 0x09, 0x9b, 0xa4, 0xfe, 0x14, 0x56, 0xfe, 0xd6, 0xf0, 0xfe, 0xec,
 
6073         0x11, 0x02, 0xfe, 0x44, 0x58, 0x77, 0xfe, 0x01, 0xec, 0xb8, 0xfe, 0x9e,
 
6074         0x40, 0xfe, 0x9d, 0xe7, 0x00, 0xfe, 0x9c, 0xe7, 0x12, 0x8d, 0x30, 0x01,
 
6075         0xf4, 0xfe, 0xdd, 0x10, 0x37, 0xd7, 0x99, 0xd8, 0x9c, 0x27, 0x25, 0xee,
 
6076         0x09, 0x12, 0xfe, 0x48, 0x12, 0x09, 0x0d, 0xfe, 0x56, 0x12, 0x09, 0x1d,
 
6077         0xfe, 0x30, 0x12, 0x09, 0xdd, 0x1b, 0xfe, 0xc4, 0x13, 0x09, 0xfe, 0x23,
 
6078         0x00, 0x1b, 0xfe, 0xd0, 0x13, 0x09, 0x07, 0x1b, 0xfe, 0x34, 0x14, 0x09,
 
6079         0x24, 0xfe, 0x12, 0x12, 0x09, 0x00, 0x1b, 0x29, 0x1f, 0xdd, 0x01, 0x42,
 
6080         0xa1, 0x32, 0x01, 0x08, 0xae, 0x41, 0x02, 0x32, 0xfe, 0x62, 0x08, 0x0a,
 
6081         0xe1, 0x01, 0xfe, 0x58, 0x10, 0x15, 0x9b, 0x05, 0x35, 0x32, 0x01, 0x43,
 
6082         0x09, 0xbb, 0xfe, 0xd7, 0x13, 0x91, 0x4b, 0x7e, 0x4c, 0x8e, 0xfe, 0x80,
 
6083         0x13, 0x01, 0x0c, 0x06, 0x54, 0xfe, 0x72, 0x12, 0xdb, 0x64, 0xdc, 0x34,
 
6084         0xfe, 0x44, 0x55, 0xfe, 0xe5, 0x55, 0xb0, 0xfe, 0x4a, 0x13, 0x21, 0x6e,
 
6085         0xfe, 0x26, 0x13, 0x03, 0x97, 0x3b, 0x98, 0x8e, 0xfe, 0xb6, 0x0e, 0x10,
 
6086         0x6a, 0x22, 0x6b, 0x26, 0x10, 0x97, 0x10, 0x98, 0x01, 0xc2, 0x2e, 0x49,
 
6087         0x88, 0x20, 0x6e, 0x01, 0xfe, 0x6a, 0x16, 0xdb, 0x64, 0xdc, 0x34, 0xfe,
 
6088         0x04, 0x55, 0xfe, 0xa5, 0x55, 0xfe, 0x04, 0xfa, 0x64, 0xfe, 0x05, 0xfa,
 
6089         0x34, 0xfe, 0x8f, 0x10, 0x03, 0x6c, 0x3b, 0x6d, 0xfe, 0x40, 0x56, 0xfe,
 
6090         0xe1, 0x56, 0x10, 0x6c, 0x22, 0x6d, 0x71, 0xdb, 0x64, 0xdc, 0x34, 0xfe,
 
6091         0x44, 0x55, 0xfe, 0xe5, 0x55, 0x03, 0x68, 0x3b, 0x69, 0xfe, 0x00, 0x56,
 
6092         0xfe, 0xa1, 0x56, 0x10, 0x68, 0x22, 0x69, 0x01, 0x0c, 0x06, 0x54, 0xf9,
 
6093         0x21, 0x6e, 0xfe, 0x1f, 0x40, 0x03, 0x6a, 0x3b, 0x6b, 0xfe, 0x2c, 0x50,
 
6094         0xfe, 0xae, 0x50, 0x03, 0x6c, 0x3b, 0x6d, 0xfe, 0x44, 0x50, 0xfe, 0xc6,
 
6095         0x50, 0x03, 0x68, 0x3b, 0x69, 0xfe, 0x08, 0x50, 0xfe, 0x8a, 0x50, 0x03,
 
6096         0x4b, 0x3b, 0x4c, 0xfe, 0x40, 0x50, 0xfe, 0xc2, 0x50, 0x05, 0x73, 0x2e,
 
6097         0x07, 0x20, 0x9e, 0x05, 0x72, 0x32, 0x01, 0x08, 0x16, 0x3d, 0x27, 0x25,
 
6098         0xee, 0x09, 0x07, 0x2b, 0x3d, 0x01, 0x43, 0x09, 0xbb, 0x2b, 0x72, 0x01,
 
6099         0xa6, 0x23, 0x3f, 0x1b, 0x3d, 0x01, 0x0c, 0x06, 0x0d, 0xfe, 0x1e, 0x13,
 
6100         0x91, 0x4b, 0x7e, 0x4c, 0xfe, 0x0a, 0x55, 0x31, 0xfe, 0x8b, 0x55, 0xd9,
 
6101         0x4b, 0xda, 0x4c, 0xfe, 0x0c, 0x51, 0xfe, 0x8e, 0x51, 0x05, 0x72, 0x01,
 
6102         0xfe, 0x8e, 0x1e, 0xca, 0xfe, 0x19, 0x41, 0x05, 0x72, 0x32, 0x01, 0x08,
 
6103         0x2a, 0x3c, 0x16, 0xc0, 0x27, 0x25, 0xbe, 0x2d, 0x1d, 0xc0, 0x2d, 0x0d,
 
6104         0x83, 0x2d, 0x7f, 0x1b, 0xfe, 0x66, 0x15, 0x05, 0x3d, 0x01, 0x08, 0x2a,
 
6105         0x3c, 0x16, 0xc0, 0x27, 0x25, 0xbd, 0x09, 0x1d, 0x2b, 0x3d, 0x01, 0x08,
 
6106         0x16, 0xc0, 0x27, 0x25, 0xfe, 0xe8, 0x09, 0xfe, 0xc2, 0x49, 0x50, 0x03,
 
6107         0xb6, 0x1e, 0x83, 0x01, 0x38, 0x06, 0x24, 0x31, 0xa1, 0xfe, 0xbb, 0x45,
 
6108         0x2d, 0x00, 0xa4, 0x46, 0x07, 0x90, 0x3f, 0x01, 0xfe, 0xf8, 0x15, 0x01,
 
6109         0xa6, 0x86, 0xfe, 0x4b, 0x45, 0xfe, 0x20, 0x13, 0x01, 0x43, 0x09, 0x82,
 
6110         0xfe, 0x16, 0x13, 0x03, 0x9a, 0x1e, 0x5d, 0x03, 0x55, 0x1e, 0x31, 0x5e,
 
6111         0x05, 0x72, 0xfe, 0xc0, 0x5d, 0x01, 0xa7, 0xfe, 0x03, 0x17, 0x03, 0x66,
 
6112         0x8a, 0x10, 0x66, 0x5e, 0x32, 0x01, 0x08, 0x17, 0x73, 0x01, 0xfe, 0x56,
 
6113         0x19, 0x05, 0x73, 0x01, 0x08, 0x2a, 0x3c, 0x16, 0x3d, 0x27, 0x25, 0xbd,
 
6114         0x09, 0x07, 0x2b, 0x3d, 0x01, 0xfe, 0xbe, 0x16, 0xfe, 0x42, 0x58, 0xfe,
 
6115         0xe8, 0x14, 0x01, 0xa6, 0x86, 0xfe, 0x4a, 0xf4, 0x0d, 0x1b, 0x3d, 0xfe,
 
6116         0x4a, 0xf4, 0x07, 0xfe, 0x0e, 0x12, 0x01, 0x43, 0x09, 0x82, 0x4e, 0x05,
 
6117         0x72, 0x03, 0x55, 0x8a, 0x10, 0x55, 0x5e, 0x32, 0x01, 0x08, 0x17, 0x73,
 
6118         0x01, 0xfe, 0x84, 0x19, 0x05, 0x73, 0x01, 0x08, 0x2a, 0x3c, 0x16, 0x3d,
 
6119         0x27, 0x25, 0xbd, 0x09, 0x12, 0x2b, 0x3d, 0x01, 0xfe, 0xe8, 0x17, 0x8b,
 
6120         0xfe, 0xaa, 0x14, 0xfe, 0xb6, 0x14, 0x86, 0xa8, 0xb2, 0x0d, 0x1b, 0x3d,
 
6121         0xb2, 0x07, 0xfe, 0x0e, 0x12, 0x01, 0x43, 0x09, 0x82, 0x4e, 0x05, 0x72,
 
6122         0x03, 0x6f, 0x8a, 0x10, 0x6f, 0x5e, 0x32, 0x01, 0x08, 0x17, 0x73, 0x01,
 
6123         0xfe, 0xc0, 0x19, 0x05, 0x73, 0x13, 0x07, 0x2f, 0xfe, 0xcc, 0x15, 0x17,
 
6124         0xfe, 0xe2, 0x15, 0x5f, 0xcc, 0x01, 0x08, 0x26, 0x5f, 0x02, 0x8f, 0xfe,
 
6125         0xde, 0x15, 0x2a, 0xfe, 0xde, 0x15, 0x16, 0xfe, 0xcc, 0x15, 0x5e, 0x32,
 
6126         0x01, 0x08, 0xfe, 0xd5, 0x10, 0x13, 0x58, 0xff, 0x02, 0x00, 0x57, 0x52,
 
6127         0xad, 0x23, 0xfe, 0xff, 0x7f, 0xfe, 0x30, 0x56, 0xfe, 0x00, 0x5c, 0x02,
 
6128         0x13, 0x58, 0xff, 0x02, 0x00, 0x57, 0x52, 0xad, 0x23, 0x3f, 0xfe, 0x30,
 
6129         0x56, 0xfe, 0x00, 0x5c, 0x02, 0x13, 0x58, 0xff, 0x02, 0x00, 0x57, 0x52,
 
6130         0xad, 0x02, 0x13, 0x58, 0xff, 0x02, 0x00, 0x57, 0x52, 0xfe, 0x00, 0x5e,
 
6131         0x02, 0x13, 0x58, 0xff, 0x02, 0x00, 0x57, 0x52, 0xad, 0xfe, 0x0b, 0x58,
 
6132         0x02, 0x0a, 0x66, 0x01, 0x5c, 0x0a, 0x55, 0x01, 0x5c, 0x0a, 0x6f, 0x01,
 
6133         0x5c, 0x02, 0x01, 0xfe, 0x1e, 0x1f, 0x23, 0x1a, 0xff, 0x03, 0x00, 0x54,
 
6134         0xfe, 0x00, 0xf4, 0x24, 0x52, 0x0f, 0xfe, 0x00, 0x7c, 0x04, 0xfe, 0x07,
 
6135         0x7c, 0x3a, 0x0b, 0x0e, 0xfe, 0x00, 0x71, 0xfe, 0xf9, 0x18, 0xfe, 0x7a,
 
6136         0x19, 0xfe, 0xfb, 0x19, 0xfe, 0x1a, 0xf7, 0x00, 0xfe, 0x1b, 0xf7, 0x00,
 
6137         0x7a, 0x30, 0x10, 0x68, 0x22, 0x69, 0xd9, 0x6c, 0xda, 0x6d, 0x02, 0xfe,
 
6138         0x62, 0x08, 0xfe, 0x82, 0x4a, 0xfe, 0xe1, 0x1a, 0xfe, 0x83, 0x5a, 0x77,
 
6139         0x02, 0x01, 0xc6, 0xfe, 0x42, 0x48, 0x4f, 0x50, 0x45, 0x01, 0x08, 0x16,
 
6140         0xfe, 0xe0, 0x17, 0x27, 0x25, 0xbe, 0x01, 0x08, 0x16, 0xfe, 0xe0, 0x17,
 
6141         0x27, 0x25, 0xfe, 0xe8, 0x0a, 0xfe, 0xc1, 0x59, 0x03, 0x9a, 0x1e, 0xfe,
 
6142         0xda, 0x12, 0x01, 0x38, 0x06, 0x12, 0xfe, 0xd0, 0x13, 0x26, 0x53, 0x12,
 
6143         0x48, 0xfe, 0x08, 0x17, 0xd1, 0x12, 0x53, 0x12, 0xfe, 0x1e, 0x13, 0x2d,
 
6144         0xb4, 0x7b, 0xfe, 0x26, 0x17, 0x4d, 0x13, 0x07, 0x1c, 0xb4, 0x90, 0x04,
 
6145         0xfe, 0x78, 0x10, 0xff, 0x02, 0x83, 0x55, 0xf1, 0xff, 0x02, 0x83, 0x55,
 
6146         0x53, 0x1d, 0xfe, 0x12, 0x13, 0xd6, 0xfe, 0x30, 0x00, 0xb0, 0xfe, 0x80,
 
6147         0x17, 0x1c, 0x63, 0x13, 0x07, 0xfe, 0x56, 0x10, 0x53, 0x0d, 0xfe, 0x16,
 
6148         0x13, 0xd6, 0xfe, 0x64, 0x00, 0xb0, 0xfe, 0x80, 0x17, 0x0a, 0xfe, 0x64,
 
6149         0x00, 0x1c, 0x94, 0x13, 0x07, 0xfe, 0x28, 0x10, 0x53, 0x07, 0xfe, 0x60,
 
6150         0x13, 0xd6, 0xfe, 0xc8, 0x00, 0xb0, 0xfe, 0x80, 0x17, 0x0a, 0xfe, 0xc8,
 
6151         0x00, 0x1c, 0x95, 0x13, 0x07, 0x71, 0xd6, 0xfe, 0x90, 0x01, 0x48, 0xfe,
 
6152         0x8c, 0x17, 0x45, 0xf3, 0xfe, 0x43, 0xf4, 0x96, 0xfe, 0x56, 0xf0, 0xfe,
 
6153         0x9e, 0x17, 0xfe, 0x04, 0xf4, 0x58, 0xfe, 0x43, 0xf4, 0x94, 0xf6, 0x8b,
 
6154         0x01, 0xfe, 0x24, 0x16, 0x23, 0x3f, 0xfc, 0xa8, 0x8c, 0x49, 0x48, 0xfe,
 
6155         0xda, 0x17, 0x62, 0x49, 0xfe, 0x1c, 0x10, 0xa8, 0x8c, 0x80, 0x48, 0xfe,
 
6156         0xda, 0x17, 0x62, 0x80, 0x71, 0x50, 0x26, 0xfe, 0x4d, 0xf4, 0x00, 0xf7,
 
6157         0x45, 0x13, 0x07, 0xfe, 0xb4, 0x56, 0xfe, 0xc3, 0x58, 0x02, 0x50, 0x13,
 
6158         0x0d, 0x02, 0x50, 0x3e, 0x78, 0x4f, 0x45, 0x01, 0x08, 0x16, 0xa9, 0x27,
 
6159         0x25, 0xbe, 0xfe, 0x03, 0xea, 0xfe, 0x7e, 0x01, 0x01, 0x08, 0x16, 0xa9,
 
6160         0x27, 0x25, 0xfe, 0xe9, 0x0a, 0x01, 0x08, 0x16, 0xa9, 0x27, 0x25, 0xfe,
 
6161         0xe9, 0x0a, 0xfe, 0x05, 0xea, 0xfe, 0x7f, 0x01, 0x01, 0x08, 0x16, 0xa9,
 
6162         0x27, 0x25, 0xfe, 0x69, 0x09, 0xfe, 0x02, 0xea, 0xfe, 0x80, 0x01, 0x01,
 
6163         0x08, 0x16, 0xa9, 0x27, 0x25, 0xfe, 0xe8, 0x08, 0x47, 0xfe, 0x81, 0x01,
 
6164         0x03, 0xb6, 0x1e, 0x83, 0x01, 0x38, 0x06, 0x24, 0x31, 0xa2, 0x78, 0xf2,
 
6165         0x53, 0x07, 0x36, 0xfe, 0x34, 0xf4, 0x3f, 0xa1, 0x78, 0x03, 0x9a, 0x1e,
 
6166         0x83, 0x01, 0x38, 0x06, 0x12, 0x31, 0xf0, 0x4f, 0x45, 0xfe, 0x90, 0x10,
 
6167         0xfe, 0x40, 0x5a, 0x23, 0x3f, 0xfb, 0x8c, 0x49, 0x48, 0xfe, 0xaa, 0x18,
 
6168         0x62, 0x49, 0x71, 0x8c, 0x80, 0x48, 0xfe, 0xaa, 0x18, 0x62, 0x80, 0xfe,
 
6169         0xb4, 0x56, 0xfe, 0x40, 0x5d, 0x01, 0xc6, 0x01, 0xfe, 0xac, 0x1d, 0xfe,
 
6170         0x02, 0x17, 0xfe, 0xc8, 0x45, 0xfe, 0x5a, 0xf0, 0xfe, 0xc0, 0x18, 0xfe,
 
6171         0x43, 0x48, 0x2d, 0x93, 0x36, 0xfe, 0x34, 0xf4, 0xfe, 0x00, 0x11, 0xfe,
 
6172         0x40, 0x10, 0x2d, 0xb4, 0x36, 0xfe, 0x34, 0xf4, 0x04, 0xfe, 0x34, 0x10,
 
6173         0x2d, 0xfe, 0x0b, 0x00, 0x36, 0x46, 0x63, 0xfe, 0x28, 0x10, 0xfe, 0xc0,
 
6174         0x49, 0xff, 0x02, 0x00, 0x54, 0xb2, 0xfe, 0x90, 0x01, 0x48, 0xfe, 0xfa,
 
6175         0x18, 0x45, 0xfe, 0x1c, 0xf4, 0x3f, 0xf3, 0xfe, 0x40, 0xf4, 0x96, 0xfe,
 
6176         0x56, 0xf0, 0xfe, 0x0c, 0x19, 0xfe, 0x04, 0xf4, 0x58, 0xfe, 0x40, 0xf4,
 
6177         0x94, 0xf6, 0x3e, 0x2d, 0x93, 0x4e, 0xd0, 0x0d, 0x21, 0xfe, 0x7f, 0x01,
 
6178         0xfe, 0xc8, 0x46, 0xfe, 0x24, 0x13, 0x8c, 0x00, 0x5d, 0x26, 0x21, 0xfe,
 
6179         0x7e, 0x01, 0xfe, 0xc8, 0x45, 0xfe, 0x14, 0x13, 0x21, 0xfe, 0x80, 0x01,
 
6180         0xfe, 0x48, 0x45, 0xfa, 0x21, 0xfe, 0x81, 0x01, 0xfe, 0xc8, 0x44, 0x4e,
 
6181         0x26, 0x02, 0x13, 0x07, 0x02, 0x78, 0x45, 0x50, 0x13, 0x0d, 0x02, 0x14,
 
6182         0x07, 0x01, 0x08, 0x17, 0xfe, 0x82, 0x19, 0x14, 0x0d, 0x01, 0x08, 0x17,
 
6183         0xfe, 0x82, 0x19, 0x14, 0x1d, 0x01, 0x08, 0x17, 0xfe, 0x82, 0x19, 0x5f,
 
6184         0xfe, 0x89, 0x49, 0x01, 0x08, 0x02, 0x14, 0x07, 0x01, 0x08, 0x17, 0xc1,
 
6185         0x14, 0x1d, 0x01, 0x08, 0x17, 0xc1, 0x14, 0x07, 0x01, 0x08, 0x17, 0xc1,
 
6186         0xfe, 0x89, 0x49, 0x01, 0x08, 0x17, 0xc1, 0x5f, 0xfe, 0x89, 0x4a, 0x01,
 
6187         0x08, 0x02, 0x50, 0x02, 0x14, 0x07, 0x01, 0x08, 0x17, 0x74, 0x14, 0x7f,
 
6188         0x01, 0x08, 0x17, 0x74, 0x14, 0x12, 0x01, 0x08, 0x17, 0x74, 0xfe, 0x89,
 
6189         0x49, 0x01, 0x08, 0x17, 0x74, 0x14, 0x00, 0x01, 0x08, 0x17, 0x74, 0xfe,
 
6190         0x89, 0x4a, 0x01, 0x08, 0x17, 0x74, 0xfe, 0x09, 0x49, 0x01, 0x08, 0x17,
 
6191         0x74, 0x5f, 0xcc, 0x01, 0x08, 0x02, 0x21, 0xe4, 0x09, 0x07, 0xfe, 0x4c,
 
6192         0x13, 0xc8, 0x20, 0xe4, 0xfe, 0x49, 0xf4, 0x00, 0x4d, 0x5f, 0xa1, 0x5e,
 
6193         0xfe, 0x01, 0xec, 0xfe, 0x27, 0x01, 0xcc, 0xff, 0x02, 0x00, 0x10, 0x2f,
 
6194         0xfe, 0x3e, 0x1a, 0x01, 0x43, 0x09, 0xfe, 0xe3, 0x00, 0xfe, 0x22, 0x13,
 
6195         0x16, 0xfe, 0x64, 0x1a, 0x26, 0x20, 0x9e, 0x01, 0x41, 0x21, 0x9e, 0x09,
 
6196         0x07, 0x5d, 0x01, 0x0c, 0x61, 0x07, 0x44, 0x02, 0x0a, 0x5a, 0x01, 0x18,
 
6197         0xfe, 0x00, 0x40, 0xaa, 0x09, 0x1a, 0xfe, 0x12, 0x13, 0x0a, 0x9d, 0x01,
 
6198         0x18, 0xaa, 0x0a, 0x67, 0x01, 0xa3, 0x02, 0x0a, 0x9d, 0x01, 0x18, 0xaa,
 
6199         0xfe, 0x80, 0xe7, 0x1a, 0x09, 0x1a, 0x5d, 0xfe, 0x45, 0x58, 0x01, 0xfe,
 
6200         0xb2, 0x16, 0xaa, 0x02, 0x0a, 0x5a, 0x01, 0x18, 0xaa, 0x0a, 0x67, 0x01,
 
6201         0xa3, 0x02, 0x0a, 0x5a, 0x01, 0x18, 0x01, 0xfe, 0x7e, 0x1e, 0xfe, 0x80,
 
6202         0x4c, 0xfe, 0x49, 0xe4, 0x1a, 0xfe, 0x12, 0x13, 0x0a, 0x9d, 0x01, 0x18,
 
6203         0xfe, 0x80, 0x4c, 0x0a, 0x67, 0x01, 0x5c, 0x02, 0x1c, 0x1a, 0x87, 0x7c,
 
6204         0xe5, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde, 0xfe, 0x24, 0x1c, 0xfe, 0x1d,
 
6205         0xf7, 0x28, 0xb1, 0xfe, 0x04, 0x1b, 0x01, 0xfe, 0x2a, 0x1c, 0xfa, 0xb3,
 
6206         0x28, 0x7c, 0xfe, 0x2c, 0x01, 0xfe, 0x2f, 0x19, 0x02, 0xc9, 0x2b, 0xfe,
 
6207         0xf4, 0x1a, 0xfe, 0xfa, 0x10, 0x1c, 0x1a, 0x87, 0x03, 0xfe, 0x64, 0x01,
 
6208         0xfe, 0x00, 0xf4, 0x24, 0xfe, 0x18, 0x58, 0x03, 0xfe, 0x66, 0x01, 0xfe,
 
6209         0x19, 0x58, 0xb3, 0x24, 0x01, 0xfe, 0x0e, 0x1f, 0xfe, 0x30, 0xf4, 0x07,
 
6210         0xfe, 0x3c, 0x50, 0x7c, 0xfe, 0x38, 0x00, 0xfe, 0x0f, 0x79, 0xfe, 0x1c,
 
6211         0xf7, 0x24, 0xb1, 0xfe, 0x50, 0x1b, 0xfe, 0xd4, 0x14, 0x31, 0x02, 0xc9,
 
6212         0x2b, 0xfe, 0x26, 0x1b, 0xfe, 0xba, 0x10, 0x1c, 0x1a, 0x87, 0xfe, 0x83,
 
6213         0x5a, 0xfe, 0x18, 0xdf, 0xfe, 0x19, 0xde, 0xfe, 0x1d, 0xf7, 0x54, 0xb1,
 
6214         0xfe, 0x72, 0x1b, 0xfe, 0xb2, 0x14, 0xfc, 0xb3, 0x54, 0x7c, 0x12, 0xfe,
 
6215         0xaf, 0x19, 0xfe, 0x98, 0xe7, 0x00, 0x02, 0xc9, 0x2b, 0xfe, 0x66, 0x1b,
 
6216         0xfe, 0x8a, 0x10, 0x1c, 0x1a, 0x87, 0x8b, 0x0f, 0xfe, 0x30, 0x90, 0x04,
 
6217         0xfe, 0xb0, 0x93, 0x3a, 0x0b, 0xfe, 0x18, 0x58, 0xfe, 0x32, 0x90, 0x04,
 
6218         0xfe, 0xb2, 0x93, 0x3a, 0x0b, 0xfe, 0x19, 0x58, 0x0e, 0xa8, 0xb3, 0x4a,
 
6219         0x7c, 0x12, 0xfe, 0x0f, 0x79, 0xfe, 0x1c, 0xf7, 0x4a, 0xb1, 0xfe, 0xc6,
 
6220         0x1b, 0xfe, 0x5e, 0x14, 0x31, 0x02, 0xc9, 0x2b, 0xfe, 0x96, 0x1b, 0x5c,
 
6221         0xfe, 0x02, 0xf6, 0x1a, 0x87, 0xfe, 0x18, 0xfe, 0x6a, 0xfe, 0x19, 0xfe,
 
6222         0x6b, 0x01, 0xfe, 0x1e, 0x1f, 0xfe, 0x1d, 0xf7, 0x65, 0xb1, 0xfe, 0xee,
 
6223         0x1b, 0xfe, 0x36, 0x14, 0xfe, 0x1c, 0x13, 0xb3, 0x65, 0x3e, 0xfe, 0x83,
 
6224         0x58, 0xfe, 0xaf, 0x19, 0xfe, 0x80, 0xe7, 0x1a, 0xfe, 0x81, 0xe7, 0x1a,
 
6225         0x15, 0xfe, 0xdd, 0x00, 0x7a, 0x30, 0x02, 0x7a, 0x30, 0xfe, 0x12, 0x45,
 
6226         0x2b, 0xfe, 0xdc, 0x1b, 0x1f, 0x07, 0x47, 0xb5, 0xc3, 0x05, 0x35, 0xfe,
 
6227         0x39, 0xf0, 0x75, 0x26, 0x02, 0xfe, 0x7e, 0x18, 0x23, 0x1d, 0x36, 0x13,
 
6228         0x11, 0x02, 0x87, 0x03, 0xe3, 0x23, 0x07, 0xfe, 0xef, 0x12, 0xfe, 0xe1,
 
6229         0x10, 0x90, 0x34, 0x60, 0xfe, 0x02, 0x80, 0x09, 0x56, 0xfe, 0x3c, 0x13,
 
6230         0xfe, 0x82, 0x14, 0xfe, 0x42, 0x13, 0x51, 0xfe, 0x06, 0x83, 0x0a, 0x5a,
 
6231         0x01, 0x18, 0xcb, 0xfe, 0x3e, 0x12, 0xfe, 0x41, 0x48, 0xfe, 0x45, 0x48,
 
6232         0x01, 0xfe, 0xb2, 0x16, 0xfe, 0x00, 0xcc, 0xcb, 0xfe, 0xf3, 0x13, 0x3f,
 
6233         0x89, 0x09, 0x1a, 0xa5, 0x0a, 0x9d, 0x01, 0x18, 0xfe, 0x80, 0x4c, 0x01,
 
6234         0x85, 0xfe, 0x16, 0x10, 0x09, 0x9b, 0x4e, 0xfe, 0x40, 0x14, 0xfe, 0x24,
 
6235         0x12, 0xfe, 0x14, 0x56, 0xfe, 0xd6, 0xf0, 0xfe, 0x52, 0x1c, 0x1c, 0x0d,
 
6236         0x02, 0xfe, 0x9c, 0xe7, 0x0d, 0x19, 0xfe, 0x15, 0x00, 0x40, 0x8d, 0x30,
 
6237         0x01, 0xf4, 0x1c, 0x07, 0x02, 0x51, 0xfe, 0x06, 0x83, 0xfe, 0x18, 0x80,
 
6238         0x61, 0x28, 0x44, 0x15, 0x56, 0x01, 0x85, 0x1c, 0x07, 0x02, 0xfe, 0x38,
 
6239         0x90, 0xfe, 0xba, 0x90, 0x91, 0xde, 0x7e, 0xdf, 0xfe, 0x48, 0x55, 0x31,
 
6240         0xfe, 0xc9, 0x55, 0x02, 0x21, 0xb9, 0x88, 0x20, 0xb9, 0x02, 0x0a, 0xba,
 
6241         0x01, 0x18, 0xfe, 0x41, 0x48, 0x0a, 0x57, 0x01, 0x18, 0xfe, 0x49, 0x44,
 
6242         0x1b, 0xfe, 0x1e, 0x1d, 0x88, 0x89, 0x02, 0x0a, 0x5a, 0x01, 0x18, 0x09,
 
6243         0x1a, 0xa4, 0x0a, 0x67, 0x01, 0xa3, 0x0a, 0x57, 0x01, 0x18, 0x88, 0x89,
 
6244         0x02, 0xfe, 0x4e, 0xe4, 0x1d, 0x7b, 0xfe, 0x52, 0x1d, 0x03, 0xfe, 0x90,
 
6245         0x00, 0xfe, 0x3a, 0x45, 0xfe, 0x2c, 0x10, 0xfe, 0x4e, 0xe4, 0xdd, 0x7b,
 
6246         0xfe, 0x64, 0x1d, 0x03, 0xfe, 0x92, 0x00, 0xd1, 0x12, 0xfe, 0x1a, 0x10,
 
6247         0xfe, 0x4e, 0xe4, 0xfe, 0x0b, 0x00, 0x7b, 0xfe, 0x76, 0x1d, 0x03, 0xfe,
 
6248         0x94, 0x00, 0xd1, 0x24, 0xfe, 0x08, 0x10, 0x03, 0xfe, 0x96, 0x00, 0xd1,
 
6249         0x63, 0xfe, 0x4e, 0x45, 0x83, 0xca, 0xff, 0x04, 0x68, 0x54, 0xfe, 0xf1,
 
6250         0x10, 0x23, 0x49, 0xfe, 0x08, 0x1c, 0xfe, 0x67, 0x19, 0xfe, 0x0a, 0x1c,
 
6251         0xfe, 0x1a, 0xf4, 0xfe, 0x00, 0x04, 0x83, 0xb2, 0x1d, 0x48, 0xfe, 0xaa,
 
6252         0x1d, 0x13, 0x1d, 0x02, 0x09, 0x92, 0xfe, 0x5a, 0xf0, 0xfe, 0xba, 0x1d,
 
6253         0x2e, 0x93, 0xfe, 0x34, 0x10, 0x09, 0x12, 0xfe, 0x5a, 0xf0, 0xfe, 0xc8,
 
6254         0x1d, 0x2e, 0xb4, 0xfe, 0x26, 0x10, 0x09, 0x1d, 0x36, 0x2e, 0x63, 0xfe,
 
6255         0x1a, 0x10, 0x09, 0x0d, 0x36, 0x2e, 0x94, 0xf2, 0x09, 0x07, 0x36, 0x2e,
 
6256         0x95, 0xa1, 0xc8, 0x02, 0x1f, 0x93, 0x01, 0x42, 0xfe, 0x04, 0xfe, 0x99,
 
6257         0x03, 0x9c, 0x8b, 0x02, 0x2a, 0xfe, 0x1c, 0x1e, 0xfe, 0x14, 0xf0, 0x08,
 
6258         0x2f, 0xfe, 0x0c, 0x1e, 0x2a, 0xfe, 0x1c, 0x1e, 0x8f, 0xfe, 0x1c, 0x1e,
 
6259         0xfe, 0x82, 0xf0, 0xfe, 0x10, 0x1e, 0x02, 0x0f, 0x3f, 0x04, 0xfe, 0x80,
 
6260         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x18, 0x80, 0x04, 0xfe, 0x98,
 
6261         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x02, 0x80, 0x04, 0xfe, 0x82,
 
6262         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x06, 0x80, 0x04, 0xfe, 0x86,
 
6263         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x1b, 0x80, 0x04, 0xfe, 0x9b,
 
6264         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x04, 0x80, 0x04, 0xfe, 0x84,
 
6265         0x83, 0x33, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x80, 0x80, 0x04, 0xfe, 0x80,
 
6266         0x83, 0xfe, 0xc9, 0x47, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x19, 0x81, 0x04,
 
6267         0xfe, 0x99, 0x83, 0xfe, 0xca, 0x47, 0x0b, 0x0e, 0x02, 0x0f, 0xfe, 0x06,
 
6268         0x83, 0x04, 0xfe, 0x86, 0x83, 0xfe, 0xce, 0x47, 0x0b, 0x0e, 0x02, 0x0f,
 
6269         0xfe, 0x2c, 0x90, 0x04, 0xfe, 0xac, 0x93, 0x3a, 0x0b, 0x0e, 0x02, 0x0f,
 
6270         0xfe, 0xae, 0x90, 0x04, 0xfe, 0xae, 0x93, 0x79, 0x0b, 0x0e, 0x02, 0x0f,
 
6271         0xfe, 0x08, 0x90, 0x04, 0xfe, 0x88, 0x93, 0x3a, 0x0b, 0x0e, 0x02, 0x0f,
 
6272         0xfe, 0x8a, 0x90, 0x04, 0xfe, 0x8a, 0x93, 0x79, 0x0b, 0x0e, 0x02, 0x0f,
 
6273         0xfe, 0x0c, 0x90, 0x04, 0xfe, 0x8c, 0x93, 0x3a, 0x0b, 0x0e, 0x02, 0x0f,
 
6274         0xfe, 0x8e, 0x90, 0x04, 0xfe, 0x8e, 0x93, 0x79, 0x0b, 0x0e, 0x02, 0x0f,
 
6275         0xfe, 0x3c, 0x90, 0x04, 0xfe, 0xbc, 0x93, 0x3a, 0x0b, 0x0e, 0x02, 0x8b,
 
6276         0x0f, 0xfe, 0x03, 0x80, 0x04, 0xfe, 0x83, 0x83, 0x33, 0x0b, 0x77, 0x0e,
 
6277         0xa8, 0x02, 0xff, 0x66, 0x00, 0x00,
 
6280 static unsigned short _adv_asc38C1600_size = sizeof(_adv_asc38C1600_buf);       /* 0x1673 */
 
6281 static ADV_DCNT _adv_asc38C1600_chksum = 0x0604EF77UL;  /* Expanded little-endian checksum. */
 
6283 static void AscInitQLinkVar(ASC_DVC_VAR *asc_dvc)
 
6289         iop_base = asc_dvc->iop_base;
 
6290         AscPutRiscVarFreeQHead(iop_base, 1);
 
6291         AscPutRiscVarDoneQTail(iop_base, asc_dvc->max_total_qng);
 
6292         AscPutVarFreeQHead(iop_base, 1);
 
6293         AscPutVarDoneQTail(iop_base, asc_dvc->max_total_qng);
 
6294         AscWriteLramByte(iop_base, ASCV_BUSY_QHEAD_B,
 
6295                          (uchar)((int)asc_dvc->max_total_qng + 1));
 
6296         AscWriteLramByte(iop_base, ASCV_DISC1_QHEAD_B,
 
6297                          (uchar)((int)asc_dvc->max_total_qng + 2));
 
6298         AscWriteLramByte(iop_base, (ushort)ASCV_TOTAL_READY_Q_B,
 
6299                          asc_dvc->max_total_qng);
 
6300         AscWriteLramWord(iop_base, ASCV_ASCDVC_ERR_CODE_W, 0);
 
6301         AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
6302         AscWriteLramByte(iop_base, ASCV_STOP_CODE_B, 0);
 
6303         AscWriteLramByte(iop_base, ASCV_SCSIBUSY_B, 0);
 
6304         AscWriteLramByte(iop_base, ASCV_WTM_FLAG_B, 0);
 
6305         AscPutQDoneInProgress(iop_base, 0);
 
6306         lram_addr = ASC_QADR_BEG;
 
6307         for (i = 0; i < 32; i++, lram_addr += 2) {
 
6308                 AscWriteLramWord(iop_base, lram_addr, 0);
 
6312 static ushort AscInitMicroCodeVar(ASC_DVC_VAR *asc_dvc)
 
6319         struct asc_board *board = asc_dvc_to_board(asc_dvc);
 
6321         iop_base = asc_dvc->iop_base;
 
6323         for (i = 0; i <= ASC_MAX_TID; i++) {
 
6324                 AscPutMCodeInitSDTRAtID(iop_base, i,
 
6325                                         asc_dvc->cfg->sdtr_period_offset[i]);
 
6328         AscInitQLinkVar(asc_dvc);
 
6329         AscWriteLramByte(iop_base, ASCV_DISC_ENABLE_B,
 
6330                          asc_dvc->cfg->disc_enable);
 
6331         AscWriteLramByte(iop_base, ASCV_HOSTSCSI_ID_B,
 
6332                          ASC_TID_TO_TARGET_ID(asc_dvc->cfg->chip_scsi_id));
 
6334         /* Ensure overrun buffer is aligned on an 8 byte boundary. */
 
6335         BUG_ON((unsigned long)asc_dvc->overrun_buf & 7);
 
6336         asc_dvc->overrun_dma = dma_map_single(board->dev, asc_dvc->overrun_buf,
 
6337                                         ASC_OVERRUN_BSIZE, DMA_FROM_DEVICE);
 
6338         phy_addr = cpu_to_le32(asc_dvc->overrun_dma);
 
6339         AscMemDWordCopyPtrToLram(iop_base, ASCV_OVERRUN_PADDR_D,
 
6340                                  (uchar *)&phy_addr, 1);
 
6341         phy_size = cpu_to_le32(ASC_OVERRUN_BSIZE);
 
6342         AscMemDWordCopyPtrToLram(iop_base, ASCV_OVERRUN_BSIZE_D,
 
6343                                  (uchar *)&phy_size, 1);
 
6345         asc_dvc->cfg->mcode_date =
 
6346             AscReadLramWord(iop_base, (ushort)ASCV_MC_DATE_W);
 
6347         asc_dvc->cfg->mcode_version =
 
6348             AscReadLramWord(iop_base, (ushort)ASCV_MC_VER_W);
 
6350         AscSetPCAddr(iop_base, ASC_MCODE_START_ADDR);
 
6351         if (AscGetPCAddr(iop_base) != ASC_MCODE_START_ADDR) {
 
6352                 asc_dvc->err_code |= ASC_IERR_SET_PC_ADDR;
 
6355         if (AscStartChip(iop_base) != 1) {
 
6356                 asc_dvc->err_code |= ASC_IERR_START_STOP_CHIP;
 
6363 static ushort AscInitAsc1000Driver(ASC_DVC_VAR *asc_dvc)
 
6368         iop_base = asc_dvc->iop_base;
 
6370         if ((asc_dvc->dvc_cntl & ASC_CNTL_RESET_SCSI) &&
 
6371             !(asc_dvc->init_state & ASC_INIT_RESET_SCSI_DONE)) {
 
6372                 AscResetChipAndScsiBus(asc_dvc);
 
6373                 mdelay(asc_dvc->scsi_reset_wait * 1000); /* XXX: msleep? */
 
6375         asc_dvc->init_state |= ASC_INIT_STATE_BEG_LOAD_MC;
 
6376         if (asc_dvc->err_code != 0)
 
6378         if (!AscFindSignature(asc_dvc->iop_base)) {
 
6379                 asc_dvc->err_code = ASC_IERR_BAD_SIGNATURE;
 
6382         AscDisableInterrupt(iop_base);
 
6383         warn_code |= AscInitLram(asc_dvc);
 
6384         if (asc_dvc->err_code != 0)
 
6386         ASC_DBG(1, "_asc_mcode_chksum 0x%lx\n", (ulong)_asc_mcode_chksum);
 
6387         if (AscLoadMicroCode(iop_base, 0, _asc_mcode_buf,
 
6388                              _asc_mcode_size) != _asc_mcode_chksum) {
 
6389                 asc_dvc->err_code |= ASC_IERR_MCODE_CHKSUM;
 
6392         warn_code |= AscInitMicroCodeVar(asc_dvc);
 
6393         asc_dvc->init_state |= ASC_INIT_STATE_END_LOAD_MC;
 
6394         AscEnableInterrupt(iop_base);
 
6399  * Load the Microcode
 
6401  * Write the microcode image to RISC memory starting at address 0.
 
6403  * The microcode is stored compressed in the following format:
 
6405  *  254 word (508 byte) table indexed by byte code followed
 
6406  *  by the following byte codes:
 
6409  *      00: Emit word 0 in table.
 
6410  *      01: Emit word 1 in table.
 
6412  *      FD: Emit word 253 in table.
 
6415  *      FE WW WW: (3 byte code) Word to emit is the next word WW WW.
 
6416  *      FF BB WW WW: (4 byte code) Emit BB count times next word WW WW.
 
6418  * Returns 0 or an error if the checksum doesn't match
 
6420 static int AdvLoadMicrocode(AdvPortAddr iop_base, unsigned char *buf, int size,
 
6421                             int memsize, int chksum)
 
6423         int i, j, end, len = 0;
 
6426         AdvWriteWordRegister(iop_base, IOPW_RAM_ADDR, 0);
 
6428         for (i = 253 * 2; i < size; i++) {
 
6429                 if (buf[i] == 0xff) {
 
6430                         unsigned short word = (buf[i + 3] << 8) | buf[i + 2];
 
6431                         for (j = 0; j < buf[i + 1]; j++) {
 
6432                                 AdvWriteWordAutoIncLram(iop_base, word);
 
6436                 } else if (buf[i] == 0xfe) {
 
6437                         unsigned short word = (buf[i + 2] << 8) | buf[i + 1];
 
6438                         AdvWriteWordAutoIncLram(iop_base, word);
 
6442                         unsigned char off = buf[i] * 2;
 
6443                         unsigned short word = (buf[off + 1] << 8) | buf[off];
 
6444                         AdvWriteWordAutoIncLram(iop_base, word);
 
6451         while (len < memsize) {
 
6452                 AdvWriteWordAutoIncLram(iop_base, 0);
 
6456         /* Verify the microcode checksum. */
 
6458         AdvWriteWordRegister(iop_base, IOPW_RAM_ADDR, 0);
 
6460         for (len = 0; len < end; len += 2) {
 
6461                 sum += AdvReadWordAutoIncLram(iop_base);
 
6465                 return ASC_IERR_MCODE_CHKSUM;
 
6470 static void AdvBuildCarrierFreelist(struct adv_dvc_var *asc_dvc)
 
6474         ADV_PADDR carr_paddr;
 
6476         carrp = (ADV_CARR_T *) ADV_16BALIGN(asc_dvc->carrier_buf);
 
6477         asc_dvc->carr_freelist = NULL;
 
6478         if (carrp == asc_dvc->carrier_buf) {
 
6479                 buf_size = ADV_CARRIER_BUFSIZE;
 
6481                 buf_size = ADV_CARRIER_BUFSIZE - sizeof(ADV_CARR_T);
 
6485                 /* Get physical address of the carrier 'carrp'. */
 
6486                 carr_paddr = cpu_to_le32(virt_to_bus(carrp));
 
6488                 buf_size -= sizeof(ADV_CARR_T);
 
6490                 carrp->carr_pa = carr_paddr;
 
6491                 carrp->carr_va = cpu_to_le32(ADV_VADDR_TO_U32(carrp));
 
6494                  * Insert the carrier at the beginning of the freelist.
 
6497                         cpu_to_le32(ADV_VADDR_TO_U32(asc_dvc->carr_freelist));
 
6498                 asc_dvc->carr_freelist = carrp;
 
6501         } while (buf_size > 0);
 
6505  * Send an idle command to the chip and wait for completion.
 
6507  * Command completion is polled for once per microsecond.
 
6509  * The function can be called from anywhere including an interrupt handler.
 
6510  * But the function is not re-entrant, so it uses the DvcEnter/LeaveCritical()
 
6511  * functions to prevent reentrancy.
 
6514  *   ADV_TRUE - command completed successfully
 
6515  *   ADV_FALSE - command failed
 
6516  *   ADV_ERROR - command timed out
 
6519 AdvSendIdleCmd(ADV_DVC_VAR *asc_dvc,
 
6520                ushort idle_cmd, ADV_DCNT idle_cmd_parameter)
 
6524         AdvPortAddr iop_base;
 
6526         iop_base = asc_dvc->iop_base;
 
6529          * Clear the idle command status which is set by the microcode
 
6530          * to a non-zero value to indicate when the command is completed.
 
6531          * The non-zero result is one of the IDLE_CMD_STATUS_* values
 
6533         AdvWriteWordLram(iop_base, ASC_MC_IDLE_CMD_STATUS, (ushort)0);
 
6536          * Write the idle command value after the idle command parameter
 
6537          * has been written to avoid a race condition. If the order is not
 
6538          * followed, the microcode may process the idle command before the
 
6539          * parameters have been written to LRAM.
 
6541         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_IDLE_CMD_PARAMETER,
 
6542                                 cpu_to_le32(idle_cmd_parameter));
 
6543         AdvWriteWordLram(iop_base, ASC_MC_IDLE_CMD, idle_cmd);
 
6546          * Tickle the RISC to tell it to process the idle command.
 
6548         AdvWriteByteRegister(iop_base, IOPB_TICKLE, ADV_TICKLE_B);
 
6549         if (asc_dvc->chip_type == ADV_CHIP_ASC3550) {
 
6551                  * Clear the tickle value. In the ASC-3550 the RISC flag
 
6552                  * command 'clr_tickle_b' does not work unless the host
 
6555                 AdvWriteByteRegister(iop_base, IOPB_TICKLE, ADV_TICKLE_NOP);
 
6558         /* Wait for up to 100 millisecond for the idle command to timeout. */
 
6559         for (i = 0; i < SCSI_WAIT_100_MSEC; i++) {
 
6560                 /* Poll once each microsecond for command completion. */
 
6561                 for (j = 0; j < SCSI_US_PER_MSEC; j++) {
 
6562                         AdvReadWordLram(iop_base, ASC_MC_IDLE_CMD_STATUS,
 
6570         BUG();          /* The idle command should never timeout. */
 
6575  * Reset SCSI Bus and purge all outstanding requests.
 
6578  *      ADV_TRUE(1) -   All requests are purged and SCSI Bus is reset.
 
6579  *      ADV_FALSE(0) -  Microcode command failed.
 
6580  *      ADV_ERROR(-1) - Microcode command timed-out. Microcode or IC
 
6581  *                      may be hung which requires driver recovery.
 
6583 static int AdvResetSB(ADV_DVC_VAR *asc_dvc)
 
6588          * Send the SCSI Bus Reset idle start idle command which asserts
 
6589          * the SCSI Bus Reset signal.
 
6591         status = AdvSendIdleCmd(asc_dvc, (ushort)IDLE_CMD_SCSI_RESET_START, 0L);
 
6592         if (status != ADV_TRUE) {
 
6597          * Delay for the specified SCSI Bus Reset hold time.
 
6599          * The hold time delay is done on the host because the RISC has no
 
6600          * microsecond accurate timer.
 
6602         udelay(ASC_SCSI_RESET_HOLD_TIME_US);
 
6605          * Send the SCSI Bus Reset end idle command which de-asserts
 
6606          * the SCSI Bus Reset signal and purges any pending requests.
 
6608         status = AdvSendIdleCmd(asc_dvc, (ushort)IDLE_CMD_SCSI_RESET_END, 0L);
 
6609         if (status != ADV_TRUE) {
 
6613         mdelay(asc_dvc->scsi_reset_wait * 1000);        /* XXX: msleep? */
 
6619  * Initialize the ASC-3550.
 
6621  * On failure set the ADV_DVC_VAR field 'err_code' and return ADV_ERROR.
 
6623  * For a non-fatal error return a warning code. If there are no warnings
 
6624  * then 0 is returned.
 
6626  * Needed after initialization for error recovery.
 
6628 static int AdvInitAsc3550Driver(ADV_DVC_VAR *asc_dvc)
 
6630         AdvPortAddr iop_base;
 
6639         ushort bios_mem[ASC_MC_BIOSLEN / 2];    /* BIOS RISC Memory 0x40-0x8F. */
 
6640         ushort wdtr_able = 0, sdtr_able, tagqng_able;
 
6641         uchar max_cmd[ADV_MAX_TID + 1];
 
6643         /* If there is already an error, don't continue. */
 
6644         if (asc_dvc->err_code != 0)
 
6648          * The caller must set 'chip_type' to ADV_CHIP_ASC3550.
 
6650         if (asc_dvc->chip_type != ADV_CHIP_ASC3550) {
 
6651                 asc_dvc->err_code = ASC_IERR_BAD_CHIPTYPE;
 
6656         iop_base = asc_dvc->iop_base;
 
6659          * Save the RISC memory BIOS region before writing the microcode.
 
6660          * The BIOS may already be loaded and using its RISC LRAM region
 
6661          * so its region must be saved and restored.
 
6663          * Note: This code makes the assumption, which is currently true,
 
6664          * that a chip reset does not clear RISC LRAM.
 
6666         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
6667                 AdvReadWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
6672          * Save current per TID negotiated values.
 
6674         if (bios_mem[(ASC_MC_BIOS_SIGNATURE - ASC_MC_BIOSMEM) / 2] == 0x55AA) {
 
6675                 ushort bios_version, major, minor;
 
6678                     bios_mem[(ASC_MC_BIOS_VERSION - ASC_MC_BIOSMEM) / 2];
 
6679                 major = (bios_version >> 12) & 0xF;
 
6680                 minor = (bios_version >> 8) & 0xF;
 
6681                 if (major < 3 || (major == 3 && minor == 1)) {
 
6682                         /* BIOS 3.1 and earlier location of 'wdtr_able' variable. */
 
6683                         AdvReadWordLram(iop_base, 0x120, wdtr_able);
 
6685                         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
6688         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
6689         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
6690         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
6691                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
6695         asc_dvc->err_code = AdvLoadMicrocode(iop_base, _adv_asc3550_buf,
 
6696                                         _adv_asc3550_size, ADV_3550_MEMSIZE,
 
6697                                         _adv_asc3550_chksum);
 
6698         if (asc_dvc->err_code)
 
6702          * Restore the RISC memory BIOS region.
 
6704         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
6705                 AdvWriteWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
6710          * Calculate and write the microcode code checksum to the microcode
 
6711          * code checksum location ASC_MC_CODE_CHK_SUM (0x2C).
 
6713         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, begin_addr);
 
6714         AdvReadWordLram(iop_base, ASC_MC_CODE_END_ADDR, end_addr);
 
6716         AdvWriteWordRegister(iop_base, IOPW_RAM_ADDR, begin_addr);
 
6717         for (word = begin_addr; word < end_addr; word += 2) {
 
6718                 code_sum += AdvReadWordAutoIncLram(iop_base);
 
6720         AdvWriteWordLram(iop_base, ASC_MC_CODE_CHK_SUM, code_sum);
 
6723          * Read and save microcode version and date.
 
6725         AdvReadWordLram(iop_base, ASC_MC_VERSION_DATE,
 
6726                         asc_dvc->cfg->mcode_date);
 
6727         AdvReadWordLram(iop_base, ASC_MC_VERSION_NUM,
 
6728                         asc_dvc->cfg->mcode_version);
 
6731          * Set the chip type to indicate the ASC3550.
 
6733         AdvWriteWordLram(iop_base, ASC_MC_CHIP_TYPE, ADV_CHIP_ASC3550);
 
6736          * If the PCI Configuration Command Register "Parity Error Response
 
6737          * Control" Bit was clear (0), then set the microcode variable
 
6738          * 'control_flag' CONTROL_FLAG_IGNORE_PERR flag to tell the microcode
 
6739          * to ignore DMA parity errors.
 
6741         if (asc_dvc->cfg->control_flag & CONTROL_FLAG_IGNORE_PERR) {
 
6742                 AdvReadWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
6743                 word |= CONTROL_FLAG_IGNORE_PERR;
 
6744                 AdvWriteWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
6748          * For ASC-3550, setting the START_CTL_EMFU [3:2] bits sets a FIFO
 
6749          * threshold of 128 bytes. This register is only accessible to the host.
 
6751         AdvWriteByteRegister(iop_base, IOPB_DMA_CFG0,
 
6752                              START_CTL_EMFU | READ_CMD_MRM);
 
6755          * Microcode operating variables for WDTR, SDTR, and command tag
 
6756          * queuing will be set in slave_configure() based on what a
 
6757          * device reports it is capable of in Inquiry byte 7.
 
6759          * If SCSI Bus Resets have been disabled, then directly set
 
6760          * SDTR and WDTR from the EEPROM configuration. This will allow
 
6761          * the BIOS and warm boot to work without a SCSI bus hang on
 
6762          * the Inquiry caused by host and target mismatched DTR values.
 
6763          * Without the SCSI Bus Reset, before an Inquiry a device can't
 
6764          * be assumed to be in Asynchronous, Narrow mode.
 
6766         if ((asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) == 0) {
 
6767                 AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE,
 
6768                                  asc_dvc->wdtr_able);
 
6769                 AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE,
 
6770                                  asc_dvc->sdtr_able);
 
6774          * Set microcode operating variables for SDTR_SPEED1, SDTR_SPEED2,
 
6775          * SDTR_SPEED3, and SDTR_SPEED4 based on the ULTRA EEPROM per TID
 
6776          * bitmask. These values determine the maximum SDTR speed negotiated
 
6779          * The SDTR per TID bitmask overrides the SDTR_SPEED1, SDTR_SPEED2,
 
6780          * SDTR_SPEED3, and SDTR_SPEED4 values so it is safe to set them
 
6781          * without determining here whether the device supports SDTR.
 
6783          * 4-bit speed  SDTR speed name
 
6784          * ===========  ===============
 
6785          * 0000b (0x0)  SDTR disabled
 
6787          * 0010b (0x2)  10 Mhz
 
6788          * 0011b (0x3)  20 Mhz (Ultra)
 
6789          * 0100b (0x4)  40 Mhz (LVD/Ultra2)
 
6790          * 0101b (0x5)  80 Mhz (LVD2/Ultra3)
 
6791          * 0110b (0x6)  Undefined
 
6793          * 1111b (0xF)  Undefined
 
6796         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
6797                 if (ADV_TID_TO_TIDMASK(tid) & asc_dvc->ultra_able) {
 
6798                         /* Set Ultra speed for TID 'tid'. */
 
6799                         word |= (0x3 << (4 * (tid % 4)));
 
6801                         /* Set Fast speed for TID 'tid'. */
 
6802                         word |= (0x2 << (4 * (tid % 4)));
 
6804                 if (tid == 3) { /* Check if done with sdtr_speed1. */
 
6805                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED1, word);
 
6807                 } else if (tid == 7) {  /* Check if done with sdtr_speed2. */
 
6808                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED2, word);
 
6810                 } else if (tid == 11) { /* Check if done with sdtr_speed3. */
 
6811                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED3, word);
 
6813                 } else if (tid == 15) { /* Check if done with sdtr_speed4. */
 
6814                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED4, word);
 
6820          * Set microcode operating variable for the disconnect per TID bitmask.
 
6822         AdvWriteWordLram(iop_base, ASC_MC_DISC_ENABLE,
 
6823                          asc_dvc->cfg->disc_enable);
 
6826          * Set SCSI_CFG0 Microcode Default Value.
 
6828          * The microcode will set the SCSI_CFG0 register using this value
 
6829          * after it is started below.
 
6831         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG0,
 
6832                          PARITY_EN | QUEUE_128 | SEL_TMO_LONG | OUR_ID_EN |
 
6833                          asc_dvc->chip_scsi_id);
 
6836          * Determine SCSI_CFG1 Microcode Default Value.
 
6838          * The microcode will set the SCSI_CFG1 register using this value
 
6839          * after it is started below.
 
6842         /* Read current SCSI_CFG1 Register value. */
 
6843         scsi_cfg1 = AdvReadWordRegister(iop_base, IOPW_SCSI_CFG1);
 
6846          * If all three connectors are in use, return an error.
 
6848         if ((scsi_cfg1 & CABLE_ILLEGAL_A) == 0 ||
 
6849             (scsi_cfg1 & CABLE_ILLEGAL_B) == 0) {
 
6850                 asc_dvc->err_code |= ASC_IERR_ILLEGAL_CONNECTION;
 
6855          * If the internal narrow cable is reversed all of the SCSI_CTRL
 
6856          * register signals will be set. Check for and return an error if
 
6857          * this condition is found.
 
6859         if ((AdvReadWordRegister(iop_base, IOPW_SCSI_CTRL) & 0x3F07) == 0x3F07) {
 
6860                 asc_dvc->err_code |= ASC_IERR_REVERSED_CABLE;
 
6865          * If this is a differential board and a single-ended device
 
6866          * is attached to one of the connectors, return an error.
 
6868         if ((scsi_cfg1 & DIFF_MODE) && (scsi_cfg1 & DIFF_SENSE) == 0) {
 
6869                 asc_dvc->err_code |= ASC_IERR_SINGLE_END_DEVICE;
 
6874          * If automatic termination control is enabled, then set the
 
6875          * termination value based on a table listed in a_condor.h.
 
6877          * If manual termination was specified with an EEPROM setting
 
6878          * then 'termination' was set-up in AdvInitFrom3550EEPROM() and
 
6879          * is ready to be 'ored' into SCSI_CFG1.
 
6881         if (asc_dvc->cfg->termination == 0) {
 
6883                  * The software always controls termination by setting TERM_CTL_SEL.
 
6884                  * If TERM_CTL_SEL were set to 0, the hardware would set termination.
 
6886                 asc_dvc->cfg->termination |= TERM_CTL_SEL;
 
6888                 switch (scsi_cfg1 & CABLE_DETECT) {
 
6889                         /* TERM_CTL_H: on, TERM_CTL_L: on */
 
6896                         asc_dvc->cfg->termination |= (TERM_CTL_H | TERM_CTL_L);
 
6899                         /* TERM_CTL_H: on, TERM_CTL_L: off */
 
6905                         asc_dvc->cfg->termination |= TERM_CTL_H;
 
6908                         /* TERM_CTL_H: off, TERM_CTL_L: off */
 
6916          * Clear any set TERM_CTL_H and TERM_CTL_L bits.
 
6918         scsi_cfg1 &= ~TERM_CTL;
 
6921          * Invert the TERM_CTL_H and TERM_CTL_L bits and then
 
6922          * set 'scsi_cfg1'. The TERM_POL bit does not need to be
 
6923          * referenced, because the hardware internally inverts
 
6924          * the Termination High and Low bits if TERM_POL is set.
 
6926         scsi_cfg1 |= (TERM_CTL_SEL | (~asc_dvc->cfg->termination & TERM_CTL));
 
6929          * Set SCSI_CFG1 Microcode Default Value
 
6931          * Set filter value and possibly modified termination control
 
6932          * bits in the Microcode SCSI_CFG1 Register Value.
 
6934          * The microcode will set the SCSI_CFG1 register using this value
 
6935          * after it is started below.
 
6937         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG1,
 
6938                          FLTR_DISABLE | scsi_cfg1);
 
6941          * Set MEM_CFG Microcode Default Value
 
6943          * The microcode will set the MEM_CFG register using this value
 
6944          * after it is started below.
 
6946          * MEM_CFG may be accessed as a word or byte, but only bits 0-7
 
6949          * ASC-3550 has 8KB internal memory.
 
6951         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_MEM_CFG,
 
6952                          BIOS_EN | RAM_SZ_8KB);
 
6955          * Set SEL_MASK Microcode Default Value
 
6957          * The microcode will set the SEL_MASK register using this value
 
6958          * after it is started below.
 
6960         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SEL_MASK,
 
6961                          ADV_TID_TO_TIDMASK(asc_dvc->chip_scsi_id));
 
6963         AdvBuildCarrierFreelist(asc_dvc);
 
6966          * Set-up the Host->RISC Initiator Command Queue (ICQ).
 
6969         if ((asc_dvc->icq_sp = asc_dvc->carr_freelist) == NULL) {
 
6970                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
6973         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
6974             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->icq_sp->next_vpa));
 
6977          * The first command issued will be placed in the stopper carrier.
 
6979         asc_dvc->icq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
6982          * Set RISC ICQ physical address start value.
 
6984         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_ICQ, asc_dvc->icq_sp->carr_pa);
 
6987          * Set-up the RISC->Host Initiator Response Queue (IRQ).
 
6989         if ((asc_dvc->irq_sp = asc_dvc->carr_freelist) == NULL) {
 
6990                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
6993         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
6994             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->irq_sp->next_vpa));
 
6997          * The first command completed by the RISC will be placed in
 
7000          * Note: Set 'next_vpa' to ASC_CQ_STOPPER. When the request is
 
7001          * completed the RISC will set the ASC_RQ_STOPPER bit.
 
7003         asc_dvc->irq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
7006          * Set RISC IRQ physical address start value.
 
7008         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_IRQ, asc_dvc->irq_sp->carr_pa);
 
7009         asc_dvc->carr_pending_cnt = 0;
 
7011         AdvWriteByteRegister(iop_base, IOPB_INTR_ENABLES,
 
7012                              (ADV_INTR_ENABLE_HOST_INTR |
 
7013                               ADV_INTR_ENABLE_GLOBAL_INTR));
 
7015         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, word);
 
7016         AdvWriteWordRegister(iop_base, IOPW_PC, word);
 
7018         /* finally, finally, gentlemen, start your engine */
 
7019         AdvWriteWordRegister(iop_base, IOPW_RISC_CSR, ADV_RISC_CSR_RUN);
 
7022          * Reset the SCSI Bus if the EEPROM indicates that SCSI Bus
 
7023          * Resets should be performed. The RISC has to be running
 
7024          * to issue a SCSI Bus Reset.
 
7026         if (asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) {
 
7028                  * If the BIOS Signature is present in memory, restore the
 
7029                  * BIOS Handshake Configuration Table and do not perform
 
7032                 if (bios_mem[(ASC_MC_BIOS_SIGNATURE - ASC_MC_BIOSMEM) / 2] ==
 
7035                          * Restore per TID negotiated values.
 
7037                         AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
7038                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
7039                         AdvWriteWordLram(iop_base, ASC_MC_TAGQNG_ABLE,
 
7041                         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
7042                                 AdvWriteByteLram(iop_base,
 
7043                                                  ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
7047                         if (AdvResetSB(asc_dvc) != ADV_TRUE) {
 
7048                                 warn_code = ASC_WARN_BUSRESET_ERROR;
 
7057  * Initialize the ASC-38C0800.
 
7059  * On failure set the ADV_DVC_VAR field 'err_code' and return ADV_ERROR.
 
7061  * For a non-fatal error return a warning code. If there are no warnings
 
7062  * then 0 is returned.
 
7064  * Needed after initialization for error recovery.
 
7066 static int AdvInitAsc38C0800Driver(ADV_DVC_VAR *asc_dvc)
 
7068         AdvPortAddr iop_base;
 
7078         ushort bios_mem[ASC_MC_BIOSLEN / 2];    /* BIOS RISC Memory 0x40-0x8F. */
 
7079         ushort wdtr_able, sdtr_able, tagqng_able;
 
7080         uchar max_cmd[ADV_MAX_TID + 1];
 
7082         /* If there is already an error, don't continue. */
 
7083         if (asc_dvc->err_code != 0)
 
7087          * The caller must set 'chip_type' to ADV_CHIP_ASC38C0800.
 
7089         if (asc_dvc->chip_type != ADV_CHIP_ASC38C0800) {
 
7090                 asc_dvc->err_code = ASC_IERR_BAD_CHIPTYPE;
 
7095         iop_base = asc_dvc->iop_base;
 
7098          * Save the RISC memory BIOS region before writing the microcode.
 
7099          * The BIOS may already be loaded and using its RISC LRAM region
 
7100          * so its region must be saved and restored.
 
7102          * Note: This code makes the assumption, which is currently true,
 
7103          * that a chip reset does not clear RISC LRAM.
 
7105         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
7106                 AdvReadWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
7111          * Save current per TID negotiated values.
 
7113         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
7114         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
7115         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
7116         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
7117                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
7122          * RAM BIST (RAM Built-In Self Test)
 
7124          * Address : I/O base + offset 0x38h register (byte).
 
7125          * Function: Bit 7-6(RW) : RAM mode
 
7126          *                          Normal Mode   : 0x00
 
7127          *                          Pre-test Mode : 0x40
 
7128          *                          RAM Test Mode : 0x80
 
7130          *           Bit 4(RO)   : Done bit
 
7131          *           Bit 3-0(RO) : Status
 
7133          *                          Int_RAM Error : 0x04
 
7138          * Note: RAM BIST code should be put right here, before loading the
 
7139          * microcode and after saving the RISC memory BIOS region.
 
7145          * Write PRE_TEST_MODE (0x40) to register and wait for 10 milliseconds.
 
7146          * If Done bit not set or low nibble not PRE_TEST_VALUE (0x05), return
 
7147          * an error. Reset to NORMAL_MODE (0x00) and do again. If cannot reset
 
7148          * to NORMAL_MODE, return an error too.
 
7150         for (i = 0; i < 2; i++) {
 
7151                 AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, PRE_TEST_MODE);
 
7152                 mdelay(10);     /* Wait for 10ms before reading back. */
 
7153                 byte = AdvReadByteRegister(iop_base, IOPB_RAM_BIST);
 
7154                 if ((byte & RAM_TEST_DONE) == 0
 
7155                     || (byte & 0x0F) != PRE_TEST_VALUE) {
 
7156                         asc_dvc->err_code = ASC_IERR_BIST_PRE_TEST;
 
7160                 AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, NORMAL_MODE);
 
7161                 mdelay(10);     /* Wait for 10ms before reading back. */
 
7162                 if (AdvReadByteRegister(iop_base, IOPB_RAM_BIST)
 
7164                         asc_dvc->err_code = ASC_IERR_BIST_PRE_TEST;
 
7170          * LRAM Test - It takes about 1.5 ms to run through the test.
 
7172          * Write RAM_TEST_MODE (0x80) to register and wait for 10 milliseconds.
 
7173          * If Done bit not set or Status not 0, save register byte, set the
 
7174          * err_code, and return an error.
 
7176         AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, RAM_TEST_MODE);
 
7177         mdelay(10);     /* Wait for 10ms before checking status. */
 
7179         byte = AdvReadByteRegister(iop_base, IOPB_RAM_BIST);
 
7180         if ((byte & RAM_TEST_DONE) == 0 || (byte & RAM_TEST_STATUS) != 0) {
 
7181                 /* Get here if Done bit not set or Status not 0. */
 
7182                 asc_dvc->bist_err_code = byte;  /* for BIOS display message */
 
7183                 asc_dvc->err_code = ASC_IERR_BIST_RAM_TEST;
 
7187         /* We need to reset back to normal mode after LRAM test passes. */
 
7188         AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, NORMAL_MODE);
 
7190         asc_dvc->err_code = AdvLoadMicrocode(iop_base, _adv_asc38C0800_buf,
 
7191                                  _adv_asc38C0800_size, ADV_38C0800_MEMSIZE,
 
7192                                  _adv_asc38C0800_chksum);
 
7193         if (asc_dvc->err_code)
 
7197          * Restore the RISC memory BIOS region.
 
7199         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
7200                 AdvWriteWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
7205          * Calculate and write the microcode code checksum to the microcode
 
7206          * code checksum location ASC_MC_CODE_CHK_SUM (0x2C).
 
7208         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, begin_addr);
 
7209         AdvReadWordLram(iop_base, ASC_MC_CODE_END_ADDR, end_addr);
 
7211         AdvWriteWordRegister(iop_base, IOPW_RAM_ADDR, begin_addr);
 
7212         for (word = begin_addr; word < end_addr; word += 2) {
 
7213                 code_sum += AdvReadWordAutoIncLram(iop_base);
 
7215         AdvWriteWordLram(iop_base, ASC_MC_CODE_CHK_SUM, code_sum);
 
7218          * Read microcode version and date.
 
7220         AdvReadWordLram(iop_base, ASC_MC_VERSION_DATE,
 
7221                         asc_dvc->cfg->mcode_date);
 
7222         AdvReadWordLram(iop_base, ASC_MC_VERSION_NUM,
 
7223                         asc_dvc->cfg->mcode_version);
 
7226          * Set the chip type to indicate the ASC38C0800.
 
7228         AdvWriteWordLram(iop_base, ASC_MC_CHIP_TYPE, ADV_CHIP_ASC38C0800);
 
7231          * Write 1 to bit 14 'DIS_TERM_DRV' in the SCSI_CFG1 register.
 
7232          * When DIS_TERM_DRV set to 1, C_DET[3:0] will reflect current
 
7233          * cable detection and then we are able to read C_DET[3:0].
 
7235          * Note: We will reset DIS_TERM_DRV to 0 in the 'Set SCSI_CFG1
 
7236          * Microcode Default Value' section below.
 
7238         scsi_cfg1 = AdvReadWordRegister(iop_base, IOPW_SCSI_CFG1);
 
7239         AdvWriteWordRegister(iop_base, IOPW_SCSI_CFG1,
 
7240                              scsi_cfg1 | DIS_TERM_DRV);
 
7243          * If the PCI Configuration Command Register "Parity Error Response
 
7244          * Control" Bit was clear (0), then set the microcode variable
 
7245          * 'control_flag' CONTROL_FLAG_IGNORE_PERR flag to tell the microcode
 
7246          * to ignore DMA parity errors.
 
7248         if (asc_dvc->cfg->control_flag & CONTROL_FLAG_IGNORE_PERR) {
 
7249                 AdvReadWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7250                 word |= CONTROL_FLAG_IGNORE_PERR;
 
7251                 AdvWriteWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7255          * For ASC-38C0800, set FIFO_THRESH_80B [6:4] bits and START_CTL_TH [3:2]
 
7256          * bits for the default FIFO threshold.
 
7258          * Note: ASC-38C0800 FIFO threshold has been changed to 256 bytes.
 
7260          * For DMA Errata #4 set the BC_THRESH_ENB bit.
 
7262         AdvWriteByteRegister(iop_base, IOPB_DMA_CFG0,
 
7263                              BC_THRESH_ENB | FIFO_THRESH_80B | START_CTL_TH |
 
7267          * Microcode operating variables for WDTR, SDTR, and command tag
 
7268          * queuing will be set in slave_configure() based on what a
 
7269          * device reports it is capable of in Inquiry byte 7.
 
7271          * If SCSI Bus Resets have been disabled, then directly set
 
7272          * SDTR and WDTR from the EEPROM configuration. This will allow
 
7273          * the BIOS and warm boot to work without a SCSI bus hang on
 
7274          * the Inquiry caused by host and target mismatched DTR values.
 
7275          * Without the SCSI Bus Reset, before an Inquiry a device can't
 
7276          * be assumed to be in Asynchronous, Narrow mode.
 
7278         if ((asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) == 0) {
 
7279                 AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE,
 
7280                                  asc_dvc->wdtr_able);
 
7281                 AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE,
 
7282                                  asc_dvc->sdtr_able);
 
7286          * Set microcode operating variables for DISC and SDTR_SPEED1,
 
7287          * SDTR_SPEED2, SDTR_SPEED3, and SDTR_SPEED4 based on the EEPROM
 
7288          * configuration values.
 
7290          * The SDTR per TID bitmask overrides the SDTR_SPEED1, SDTR_SPEED2,
 
7291          * SDTR_SPEED3, and SDTR_SPEED4 values so it is safe to set them
 
7292          * without determining here whether the device supports SDTR.
 
7294         AdvWriteWordLram(iop_base, ASC_MC_DISC_ENABLE,
 
7295                          asc_dvc->cfg->disc_enable);
 
7296         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED1, asc_dvc->sdtr_speed1);
 
7297         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED2, asc_dvc->sdtr_speed2);
 
7298         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED3, asc_dvc->sdtr_speed3);
 
7299         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED4, asc_dvc->sdtr_speed4);
 
7302          * Set SCSI_CFG0 Microcode Default Value.
 
7304          * The microcode will set the SCSI_CFG0 register using this value
 
7305          * after it is started below.
 
7307         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG0,
 
7308                          PARITY_EN | QUEUE_128 | SEL_TMO_LONG | OUR_ID_EN |
 
7309                          asc_dvc->chip_scsi_id);
 
7312          * Determine SCSI_CFG1 Microcode Default Value.
 
7314          * The microcode will set the SCSI_CFG1 register using this value
 
7315          * after it is started below.
 
7318         /* Read current SCSI_CFG1 Register value. */
 
7319         scsi_cfg1 = AdvReadWordRegister(iop_base, IOPW_SCSI_CFG1);
 
7322          * If the internal narrow cable is reversed all of the SCSI_CTRL
 
7323          * register signals will be set. Check for and return an error if
 
7324          * this condition is found.
 
7326         if ((AdvReadWordRegister(iop_base, IOPW_SCSI_CTRL) & 0x3F07) == 0x3F07) {
 
7327                 asc_dvc->err_code |= ASC_IERR_REVERSED_CABLE;
 
7332          * All kind of combinations of devices attached to one of four
 
7333          * connectors are acceptable except HVD device attached. For example,
 
7334          * LVD device can be attached to SE connector while SE device attached
 
7335          * to LVD connector.  If LVD device attached to SE connector, it only
 
7336          * runs up to Ultra speed.
 
7338          * If an HVD device is attached to one of LVD connectors, return an
 
7339          * error.  However, there is no way to detect HVD device attached to
 
7342         if (scsi_cfg1 & HVD) {
 
7343                 asc_dvc->err_code = ASC_IERR_HVD_DEVICE;
 
7348          * If either SE or LVD automatic termination control is enabled, then
 
7349          * set the termination value based on a table listed in a_condor.h.
 
7351          * If manual termination was specified with an EEPROM setting then
 
7352          * 'termination' was set-up in AdvInitFrom38C0800EEPROM() and is ready
 
7353          * to be 'ored' into SCSI_CFG1.
 
7355         if ((asc_dvc->cfg->termination & TERM_SE) == 0) {
 
7356                 /* SE automatic termination control is enabled. */
 
7357                 switch (scsi_cfg1 & C_DET_SE) {
 
7358                         /* TERM_SE_HI: on, TERM_SE_LO: on */
 
7362                         asc_dvc->cfg->termination |= TERM_SE;
 
7365                         /* TERM_SE_HI: on, TERM_SE_LO: off */
 
7367                         asc_dvc->cfg->termination |= TERM_SE_HI;
 
7372         if ((asc_dvc->cfg->termination & TERM_LVD) == 0) {
 
7373                 /* LVD automatic termination control is enabled. */
 
7374                 switch (scsi_cfg1 & C_DET_LVD) {
 
7375                         /* TERM_LVD_HI: on, TERM_LVD_LO: on */
 
7379                         asc_dvc->cfg->termination |= TERM_LVD;
 
7382                         /* TERM_LVD_HI: off, TERM_LVD_LO: off */
 
7389          * Clear any set TERM_SE and TERM_LVD bits.
 
7391         scsi_cfg1 &= (~TERM_SE & ~TERM_LVD);
 
7394          * Invert the TERM_SE and TERM_LVD bits and then set 'scsi_cfg1'.
 
7396         scsi_cfg1 |= (~asc_dvc->cfg->termination & 0xF0);
 
7399          * Clear BIG_ENDIAN, DIS_TERM_DRV, Terminator Polarity and HVD/LVD/SE
 
7400          * bits and set possibly modified termination control bits in the
 
7401          * Microcode SCSI_CFG1 Register Value.
 
7403         scsi_cfg1 &= (~BIG_ENDIAN & ~DIS_TERM_DRV & ~TERM_POL & ~HVD_LVD_SE);
 
7406          * Set SCSI_CFG1 Microcode Default Value
 
7408          * Set possibly modified termination control and reset DIS_TERM_DRV
 
7409          * bits in the Microcode SCSI_CFG1 Register Value.
 
7411          * The microcode will set the SCSI_CFG1 register using this value
 
7412          * after it is started below.
 
7414         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG1, scsi_cfg1);
 
7417          * Set MEM_CFG Microcode Default Value
 
7419          * The microcode will set the MEM_CFG register using this value
 
7420          * after it is started below.
 
7422          * MEM_CFG may be accessed as a word or byte, but only bits 0-7
 
7425          * ASC-38C0800 has 16KB internal memory.
 
7427         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_MEM_CFG,
 
7428                          BIOS_EN | RAM_SZ_16KB);
 
7431          * Set SEL_MASK Microcode Default Value
 
7433          * The microcode will set the SEL_MASK register using this value
 
7434          * after it is started below.
 
7436         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SEL_MASK,
 
7437                          ADV_TID_TO_TIDMASK(asc_dvc->chip_scsi_id));
 
7439         AdvBuildCarrierFreelist(asc_dvc);
 
7442          * Set-up the Host->RISC Initiator Command Queue (ICQ).
 
7445         if ((asc_dvc->icq_sp = asc_dvc->carr_freelist) == NULL) {
 
7446                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
7449         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
7450             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->icq_sp->next_vpa));
 
7453          * The first command issued will be placed in the stopper carrier.
 
7455         asc_dvc->icq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
7458          * Set RISC ICQ physical address start value.
 
7459          * carr_pa is LE, must be native before write
 
7461         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_ICQ, asc_dvc->icq_sp->carr_pa);
 
7464          * Set-up the RISC->Host Initiator Response Queue (IRQ).
 
7466         if ((asc_dvc->irq_sp = asc_dvc->carr_freelist) == NULL) {
 
7467                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
7470         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
7471             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->irq_sp->next_vpa));
 
7474          * The first command completed by the RISC will be placed in
 
7477          * Note: Set 'next_vpa' to ASC_CQ_STOPPER. When the request is
 
7478          * completed the RISC will set the ASC_RQ_STOPPER bit.
 
7480         asc_dvc->irq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
7483          * Set RISC IRQ physical address start value.
 
7485          * carr_pa is LE, must be native before write *
 
7487         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_IRQ, asc_dvc->irq_sp->carr_pa);
 
7488         asc_dvc->carr_pending_cnt = 0;
 
7490         AdvWriteByteRegister(iop_base, IOPB_INTR_ENABLES,
 
7491                              (ADV_INTR_ENABLE_HOST_INTR |
 
7492                               ADV_INTR_ENABLE_GLOBAL_INTR));
 
7494         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, word);
 
7495         AdvWriteWordRegister(iop_base, IOPW_PC, word);
 
7497         /* finally, finally, gentlemen, start your engine */
 
7498         AdvWriteWordRegister(iop_base, IOPW_RISC_CSR, ADV_RISC_CSR_RUN);
 
7501          * Reset the SCSI Bus if the EEPROM indicates that SCSI Bus
 
7502          * Resets should be performed. The RISC has to be running
 
7503          * to issue a SCSI Bus Reset.
 
7505         if (asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) {
 
7507                  * If the BIOS Signature is present in memory, restore the
 
7508                  * BIOS Handshake Configuration Table and do not perform
 
7511                 if (bios_mem[(ASC_MC_BIOS_SIGNATURE - ASC_MC_BIOSMEM) / 2] ==
 
7514                          * Restore per TID negotiated values.
 
7516                         AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
7517                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
7518                         AdvWriteWordLram(iop_base, ASC_MC_TAGQNG_ABLE,
 
7520                         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
7521                                 AdvWriteByteLram(iop_base,
 
7522                                                  ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
7526                         if (AdvResetSB(asc_dvc) != ADV_TRUE) {
 
7527                                 warn_code = ASC_WARN_BUSRESET_ERROR;
 
7536  * Initialize the ASC-38C1600.
 
7538  * On failure set the ASC_DVC_VAR field 'err_code' and return ADV_ERROR.
 
7540  * For a non-fatal error return a warning code. If there are no warnings
 
7541  * then 0 is returned.
 
7543  * Needed after initialization for error recovery.
 
7545 static int AdvInitAsc38C1600Driver(ADV_DVC_VAR *asc_dvc)
 
7547         AdvPortAddr iop_base;
 
7557         ushort bios_mem[ASC_MC_BIOSLEN / 2];    /* BIOS RISC Memory 0x40-0x8F. */
 
7558         ushort wdtr_able, sdtr_able, ppr_able, tagqng_able;
 
7559         uchar max_cmd[ASC_MAX_TID + 1];
 
7561         /* If there is already an error, don't continue. */
 
7562         if (asc_dvc->err_code != 0) {
 
7567          * The caller must set 'chip_type' to ADV_CHIP_ASC38C1600.
 
7569         if (asc_dvc->chip_type != ADV_CHIP_ASC38C1600) {
 
7570                 asc_dvc->err_code = ASC_IERR_BAD_CHIPTYPE;
 
7575         iop_base = asc_dvc->iop_base;
 
7578          * Save the RISC memory BIOS region before writing the microcode.
 
7579          * The BIOS may already be loaded and using its RISC LRAM region
 
7580          * so its region must be saved and restored.
 
7582          * Note: This code makes the assumption, which is currently true,
 
7583          * that a chip reset does not clear RISC LRAM.
 
7585         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
7586                 AdvReadWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
7591          * Save current per TID negotiated values.
 
7593         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
7594         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
7595         AdvReadWordLram(iop_base, ASC_MC_PPR_ABLE, ppr_able);
 
7596         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
7597         for (tid = 0; tid <= ASC_MAX_TID; tid++) {
 
7598                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
7603          * RAM BIST (Built-In Self Test)
 
7605          * Address : I/O base + offset 0x38h register (byte).
 
7606          * Function: Bit 7-6(RW) : RAM mode
 
7607          *                          Normal Mode   : 0x00
 
7608          *                          Pre-test Mode : 0x40
 
7609          *                          RAM Test Mode : 0x80
 
7611          *           Bit 4(RO)   : Done bit
 
7612          *           Bit 3-0(RO) : Status
 
7614          *                          Int_RAM Error : 0x04
 
7619          * Note: RAM BIST code should be put right here, before loading the
 
7620          * microcode and after saving the RISC memory BIOS region.
 
7626          * Write PRE_TEST_MODE (0x40) to register and wait for 10 milliseconds.
 
7627          * If Done bit not set or low nibble not PRE_TEST_VALUE (0x05), return
 
7628          * an error. Reset to NORMAL_MODE (0x00) and do again. If cannot reset
 
7629          * to NORMAL_MODE, return an error too.
 
7631         for (i = 0; i < 2; i++) {
 
7632                 AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, PRE_TEST_MODE);
 
7633                 mdelay(10);     /* Wait for 10ms before reading back. */
 
7634                 byte = AdvReadByteRegister(iop_base, IOPB_RAM_BIST);
 
7635                 if ((byte & RAM_TEST_DONE) == 0
 
7636                     || (byte & 0x0F) != PRE_TEST_VALUE) {
 
7637                         asc_dvc->err_code = ASC_IERR_BIST_PRE_TEST;
 
7641                 AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, NORMAL_MODE);
 
7642                 mdelay(10);     /* Wait for 10ms before reading back. */
 
7643                 if (AdvReadByteRegister(iop_base, IOPB_RAM_BIST)
 
7645                         asc_dvc->err_code = ASC_IERR_BIST_PRE_TEST;
 
7651          * LRAM Test - It takes about 1.5 ms to run through the test.
 
7653          * Write RAM_TEST_MODE (0x80) to register and wait for 10 milliseconds.
 
7654          * If Done bit not set or Status not 0, save register byte, set the
 
7655          * err_code, and return an error.
 
7657         AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, RAM_TEST_MODE);
 
7658         mdelay(10);     /* Wait for 10ms before checking status. */
 
7660         byte = AdvReadByteRegister(iop_base, IOPB_RAM_BIST);
 
7661         if ((byte & RAM_TEST_DONE) == 0 || (byte & RAM_TEST_STATUS) != 0) {
 
7662                 /* Get here if Done bit not set or Status not 0. */
 
7663                 asc_dvc->bist_err_code = byte;  /* for BIOS display message */
 
7664                 asc_dvc->err_code = ASC_IERR_BIST_RAM_TEST;
 
7668         /* We need to reset back to normal mode after LRAM test passes. */
 
7669         AdvWriteByteRegister(iop_base, IOPB_RAM_BIST, NORMAL_MODE);
 
7671         asc_dvc->err_code = AdvLoadMicrocode(iop_base, _adv_asc38C1600_buf,
 
7672                                  _adv_asc38C1600_size, ADV_38C1600_MEMSIZE,
 
7673                                  _adv_asc38C1600_chksum);
 
7674         if (asc_dvc->err_code)
 
7678          * Restore the RISC memory BIOS region.
 
7680         for (i = 0; i < ASC_MC_BIOSLEN / 2; i++) {
 
7681                 AdvWriteWordLram(iop_base, ASC_MC_BIOSMEM + (2 * i),
 
7686          * Calculate and write the microcode code checksum to the microcode
 
7687          * code checksum location ASC_MC_CODE_CHK_SUM (0x2C).
 
7689         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, begin_addr);
 
7690         AdvReadWordLram(iop_base, ASC_MC_CODE_END_ADDR, end_addr);
 
7692         AdvWriteWordRegister(iop_base, IOPW_RAM_ADDR, begin_addr);
 
7693         for (word = begin_addr; word < end_addr; word += 2) {
 
7694                 code_sum += AdvReadWordAutoIncLram(iop_base);
 
7696         AdvWriteWordLram(iop_base, ASC_MC_CODE_CHK_SUM, code_sum);
 
7699          * Read microcode version and date.
 
7701         AdvReadWordLram(iop_base, ASC_MC_VERSION_DATE,
 
7702                         asc_dvc->cfg->mcode_date);
 
7703         AdvReadWordLram(iop_base, ASC_MC_VERSION_NUM,
 
7704                         asc_dvc->cfg->mcode_version);
 
7707          * Set the chip type to indicate the ASC38C1600.
 
7709         AdvWriteWordLram(iop_base, ASC_MC_CHIP_TYPE, ADV_CHIP_ASC38C1600);
 
7712          * Write 1 to bit 14 'DIS_TERM_DRV' in the SCSI_CFG1 register.
 
7713          * When DIS_TERM_DRV set to 1, C_DET[3:0] will reflect current
 
7714          * cable detection and then we are able to read C_DET[3:0].
 
7716          * Note: We will reset DIS_TERM_DRV to 0 in the 'Set SCSI_CFG1
 
7717          * Microcode Default Value' section below.
 
7719         scsi_cfg1 = AdvReadWordRegister(iop_base, IOPW_SCSI_CFG1);
 
7720         AdvWriteWordRegister(iop_base, IOPW_SCSI_CFG1,
 
7721                              scsi_cfg1 | DIS_TERM_DRV);
 
7724          * If the PCI Configuration Command Register "Parity Error Response
 
7725          * Control" Bit was clear (0), then set the microcode variable
 
7726          * 'control_flag' CONTROL_FLAG_IGNORE_PERR flag to tell the microcode
 
7727          * to ignore DMA parity errors.
 
7729         if (asc_dvc->cfg->control_flag & CONTROL_FLAG_IGNORE_PERR) {
 
7730                 AdvReadWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7731                 word |= CONTROL_FLAG_IGNORE_PERR;
 
7732                 AdvWriteWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7736          * If the BIOS control flag AIPP (Asynchronous Information
 
7737          * Phase Protection) disable bit is not set, then set the firmware
 
7738          * 'control_flag' CONTROL_FLAG_ENABLE_AIPP bit to enable
 
7739          * AIPP checking and encoding.
 
7741         if ((asc_dvc->bios_ctrl & BIOS_CTRL_AIPP_DIS) == 0) {
 
7742                 AdvReadWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7743                 word |= CONTROL_FLAG_ENABLE_AIPP;
 
7744                 AdvWriteWordLram(iop_base, ASC_MC_CONTROL_FLAG, word);
 
7748          * For ASC-38C1600 use DMA_CFG0 default values: FIFO_THRESH_80B [6:4],
 
7749          * and START_CTL_TH [3:2].
 
7751         AdvWriteByteRegister(iop_base, IOPB_DMA_CFG0,
 
7752                              FIFO_THRESH_80B | START_CTL_TH | READ_CMD_MRM);
 
7755          * Microcode operating variables for WDTR, SDTR, and command tag
 
7756          * queuing will be set in slave_configure() based on what a
 
7757          * device reports it is capable of in Inquiry byte 7.
 
7759          * If SCSI Bus Resets have been disabled, then directly set
 
7760          * SDTR and WDTR from the EEPROM configuration. This will allow
 
7761          * the BIOS and warm boot to work without a SCSI bus hang on
 
7762          * the Inquiry caused by host and target mismatched DTR values.
 
7763          * Without the SCSI Bus Reset, before an Inquiry a device can't
 
7764          * be assumed to be in Asynchronous, Narrow mode.
 
7766         if ((asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) == 0) {
 
7767                 AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE,
 
7768                                  asc_dvc->wdtr_able);
 
7769                 AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE,
 
7770                                  asc_dvc->sdtr_able);
 
7774          * Set microcode operating variables for DISC and SDTR_SPEED1,
 
7775          * SDTR_SPEED2, SDTR_SPEED3, and SDTR_SPEED4 based on the EEPROM
 
7776          * configuration values.
 
7778          * The SDTR per TID bitmask overrides the SDTR_SPEED1, SDTR_SPEED2,
 
7779          * SDTR_SPEED3, and SDTR_SPEED4 values so it is safe to set them
 
7780          * without determining here whether the device supports SDTR.
 
7782         AdvWriteWordLram(iop_base, ASC_MC_DISC_ENABLE,
 
7783                          asc_dvc->cfg->disc_enable);
 
7784         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED1, asc_dvc->sdtr_speed1);
 
7785         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED2, asc_dvc->sdtr_speed2);
 
7786         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED3, asc_dvc->sdtr_speed3);
 
7787         AdvWriteWordLram(iop_base, ASC_MC_SDTR_SPEED4, asc_dvc->sdtr_speed4);
 
7790          * Set SCSI_CFG0 Microcode Default Value.
 
7792          * The microcode will set the SCSI_CFG0 register using this value
 
7793          * after it is started below.
 
7795         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG0,
 
7796                          PARITY_EN | QUEUE_128 | SEL_TMO_LONG | OUR_ID_EN |
 
7797                          asc_dvc->chip_scsi_id);
 
7800          * Calculate SCSI_CFG1 Microcode Default Value.
 
7802          * The microcode will set the SCSI_CFG1 register using this value
 
7803          * after it is started below.
 
7805          * Each ASC-38C1600 function has only two cable detect bits.
 
7806          * The bus mode override bits are in IOPB_SOFT_OVER_WR.
 
7808         scsi_cfg1 = AdvReadWordRegister(iop_base, IOPW_SCSI_CFG1);
 
7811          * If the cable is reversed all of the SCSI_CTRL register signals
 
7812          * will be set. Check for and return an error if this condition is
 
7815         if ((AdvReadWordRegister(iop_base, IOPW_SCSI_CTRL) & 0x3F07) == 0x3F07) {
 
7816                 asc_dvc->err_code |= ASC_IERR_REVERSED_CABLE;
 
7821          * Each ASC-38C1600 function has two connectors. Only an HVD device
 
7822          * can not be connected to either connector. An LVD device or SE device
 
7823          * may be connected to either connecor. If an SE device is connected,
 
7824          * then at most Ultra speed (20 Mhz) can be used on both connectors.
 
7826          * If an HVD device is attached, return an error.
 
7828         if (scsi_cfg1 & HVD) {
 
7829                 asc_dvc->err_code |= ASC_IERR_HVD_DEVICE;
 
7834          * Each function in the ASC-38C1600 uses only the SE cable detect and
 
7835          * termination because there are two connectors for each function. Each
 
7836          * function may use either LVD or SE mode. Corresponding the SE automatic
 
7837          * termination control EEPROM bits are used for each function. Each
 
7838          * function has its own EEPROM. If SE automatic control is enabled for
 
7839          * the function, then set the termination value based on a table listed
 
7842          * If manual termination is specified in the EEPROM for the function,
 
7843          * then 'termination' was set-up in AscInitFrom38C1600EEPROM() and is
 
7844          * ready to be 'ored' into SCSI_CFG1.
 
7846         if ((asc_dvc->cfg->termination & TERM_SE) == 0) {
 
7847                 struct pci_dev *pdev = adv_dvc_to_pdev(asc_dvc);
 
7848                 /* SE automatic termination control is enabled. */
 
7849                 switch (scsi_cfg1 & C_DET_SE) {
 
7850                         /* TERM_SE_HI: on, TERM_SE_LO: on */
 
7854                         asc_dvc->cfg->termination |= TERM_SE;
 
7858                         if (PCI_FUNC(pdev->devfn) == 0) {
 
7859                                 /* Function 0 - TERM_SE_HI: off, TERM_SE_LO: off */
 
7861                                 /* Function 1 - TERM_SE_HI: on, TERM_SE_LO: off */
 
7862                                 asc_dvc->cfg->termination |= TERM_SE_HI;
 
7869          * Clear any set TERM_SE bits.
 
7871         scsi_cfg1 &= ~TERM_SE;
 
7874          * Invert the TERM_SE bits and then set 'scsi_cfg1'.
 
7876         scsi_cfg1 |= (~asc_dvc->cfg->termination & TERM_SE);
 
7879          * Clear Big Endian and Terminator Polarity bits and set possibly
 
7880          * modified termination control bits in the Microcode SCSI_CFG1
 
7883          * Big Endian bit is not used even on big endian machines.
 
7885         scsi_cfg1 &= (~BIG_ENDIAN & ~DIS_TERM_DRV & ~TERM_POL);
 
7888          * Set SCSI_CFG1 Microcode Default Value
 
7890          * Set possibly modified termination control bits in the Microcode
 
7891          * SCSI_CFG1 Register Value.
 
7893          * The microcode will set the SCSI_CFG1 register using this value
 
7894          * after it is started below.
 
7896         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SCSI_CFG1, scsi_cfg1);
 
7899          * Set MEM_CFG Microcode Default Value
 
7901          * The microcode will set the MEM_CFG register using this value
 
7902          * after it is started below.
 
7904          * MEM_CFG may be accessed as a word or byte, but only bits 0-7
 
7907          * ASC-38C1600 has 32KB internal memory.
 
7909          * XXX - Since ASC38C1600 Rev.3 has a Local RAM failure issue, we come
 
7910          * out a special 16K Adv Library and Microcode version. After the issue
 
7911          * resolved, we should turn back to the 32K support. Both a_condor.h and
 
7912          * mcode.sas files also need to be updated.
 
7914          * AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_MEM_CFG,
 
7915          *  BIOS_EN | RAM_SZ_32KB);
 
7917         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_MEM_CFG,
 
7918                          BIOS_EN | RAM_SZ_16KB);
 
7921          * Set SEL_MASK Microcode Default Value
 
7923          * The microcode will set the SEL_MASK register using this value
 
7924          * after it is started below.
 
7926         AdvWriteWordLram(iop_base, ASC_MC_DEFAULT_SEL_MASK,
 
7927                          ADV_TID_TO_TIDMASK(asc_dvc->chip_scsi_id));
 
7929         AdvBuildCarrierFreelist(asc_dvc);
 
7932          * Set-up the Host->RISC Initiator Command Queue (ICQ).
 
7934         if ((asc_dvc->icq_sp = asc_dvc->carr_freelist) == NULL) {
 
7935                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
7938         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
7939             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->icq_sp->next_vpa));
 
7942          * The first command issued will be placed in the stopper carrier.
 
7944         asc_dvc->icq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
7947          * Set RISC ICQ physical address start value. Initialize the
 
7948          * COMMA register to the same value otherwise the RISC will
 
7949          * prematurely detect a command is available.
 
7951         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_ICQ, asc_dvc->icq_sp->carr_pa);
 
7952         AdvWriteDWordRegister(iop_base, IOPDW_COMMA,
 
7953                               le32_to_cpu(asc_dvc->icq_sp->carr_pa));
 
7956          * Set-up the RISC->Host Initiator Response Queue (IRQ).
 
7958         if ((asc_dvc->irq_sp = asc_dvc->carr_freelist) == NULL) {
 
7959                 asc_dvc->err_code |= ASC_IERR_NO_CARRIER;
 
7962         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
7963             ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->irq_sp->next_vpa));
 
7966          * The first command completed by the RISC will be placed in
 
7969          * Note: Set 'next_vpa' to ASC_CQ_STOPPER. When the request is
 
7970          * completed the RISC will set the ASC_RQ_STOPPER bit.
 
7972         asc_dvc->irq_sp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
7975          * Set RISC IRQ physical address start value.
 
7977         AdvWriteDWordLramNoSwap(iop_base, ASC_MC_IRQ, asc_dvc->irq_sp->carr_pa);
 
7978         asc_dvc->carr_pending_cnt = 0;
 
7980         AdvWriteByteRegister(iop_base, IOPB_INTR_ENABLES,
 
7981                              (ADV_INTR_ENABLE_HOST_INTR |
 
7982                               ADV_INTR_ENABLE_GLOBAL_INTR));
 
7983         AdvReadWordLram(iop_base, ASC_MC_CODE_BEGIN_ADDR, word);
 
7984         AdvWriteWordRegister(iop_base, IOPW_PC, word);
 
7986         /* finally, finally, gentlemen, start your engine */
 
7987         AdvWriteWordRegister(iop_base, IOPW_RISC_CSR, ADV_RISC_CSR_RUN);
 
7990          * Reset the SCSI Bus if the EEPROM indicates that SCSI Bus
 
7991          * Resets should be performed. The RISC has to be running
 
7992          * to issue a SCSI Bus Reset.
 
7994         if (asc_dvc->bios_ctrl & BIOS_CTRL_RESET_SCSI_BUS) {
 
7996                  * If the BIOS Signature is present in memory, restore the
 
7997                  * per TID microcode operating variables.
 
7999                 if (bios_mem[(ASC_MC_BIOS_SIGNATURE - ASC_MC_BIOSMEM) / 2] ==
 
8002                          * Restore per TID negotiated values.
 
8004                         AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
8005                         AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
8006                         AdvWriteWordLram(iop_base, ASC_MC_PPR_ABLE, ppr_able);
 
8007                         AdvWriteWordLram(iop_base, ASC_MC_TAGQNG_ABLE,
 
8009                         for (tid = 0; tid <= ASC_MAX_TID; tid++) {
 
8010                                 AdvWriteByteLram(iop_base,
 
8011                                                  ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
8015                         if (AdvResetSB(asc_dvc) != ADV_TRUE) {
 
8016                                 warn_code = ASC_WARN_BUSRESET_ERROR;
 
8025  * Reset chip and SCSI Bus.
 
8028  *      ADV_TRUE(1) -   Chip re-initialization and SCSI Bus Reset successful.
 
8029  *      ADV_FALSE(0) -  Chip re-initialization and SCSI Bus Reset failure.
 
8031 static int AdvResetChipAndSB(ADV_DVC_VAR *asc_dvc)
 
8034         ushort wdtr_able, sdtr_able, tagqng_able;
 
8035         ushort ppr_able = 0;
 
8036         uchar tid, max_cmd[ADV_MAX_TID + 1];
 
8037         AdvPortAddr iop_base;
 
8040         iop_base = asc_dvc->iop_base;
 
8043          * Save current per TID negotiated values.
 
8045         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
8046         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
8047         if (asc_dvc->chip_type == ADV_CHIP_ASC38C1600) {
 
8048                 AdvReadWordLram(iop_base, ASC_MC_PPR_ABLE, ppr_able);
 
8050         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
8051         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
8052                 AdvReadByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
8057          * Force the AdvInitAsc3550/38C0800Driver() function to
 
8058          * perform a SCSI Bus Reset by clearing the BIOS signature word.
 
8059          * The initialization functions assumes a SCSI Bus Reset is not
 
8060          * needed if the BIOS signature word is present.
 
8062         AdvReadWordLram(iop_base, ASC_MC_BIOS_SIGNATURE, bios_sig);
 
8063         AdvWriteWordLram(iop_base, ASC_MC_BIOS_SIGNATURE, 0);
 
8066          * Stop chip and reset it.
 
8068         AdvWriteWordRegister(iop_base, IOPW_RISC_CSR, ADV_RISC_CSR_STOP);
 
8069         AdvWriteWordRegister(iop_base, IOPW_CTRL_REG, ADV_CTRL_REG_CMD_RESET);
 
8071         AdvWriteWordRegister(iop_base, IOPW_CTRL_REG,
 
8072                              ADV_CTRL_REG_CMD_WR_IO_REG);
 
8075          * Reset Adv Library error code, if any, and try
 
8076          * re-initializing the chip.
 
8078         asc_dvc->err_code = 0;
 
8079         if (asc_dvc->chip_type == ADV_CHIP_ASC38C1600) {
 
8080                 status = AdvInitAsc38C1600Driver(asc_dvc);
 
8081         } else if (asc_dvc->chip_type == ADV_CHIP_ASC38C0800) {
 
8082                 status = AdvInitAsc38C0800Driver(asc_dvc);
 
8084                 status = AdvInitAsc3550Driver(asc_dvc);
 
8087         /* Translate initialization return value to status value. */
 
8095          * Restore the BIOS signature word.
 
8097         AdvWriteWordLram(iop_base, ASC_MC_BIOS_SIGNATURE, bios_sig);
 
8100          * Restore per TID negotiated values.
 
8102         AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE, wdtr_able);
 
8103         AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE, sdtr_able);
 
8104         if (asc_dvc->chip_type == ADV_CHIP_ASC38C1600) {
 
8105                 AdvWriteWordLram(iop_base, ASC_MC_PPR_ABLE, ppr_able);
 
8107         AdvWriteWordLram(iop_base, ASC_MC_TAGQNG_ABLE, tagqng_able);
 
8108         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
8109                 AdvWriteByteLram(iop_base, ASC_MC_NUMBER_OF_MAX_CMD + tid,
 
8117  * adv_async_callback() - Adv Library asynchronous event callback function.
 
8119 static void adv_async_callback(ADV_DVC_VAR *adv_dvc_varp, uchar code)
 
8122         case ADV_ASYNC_SCSI_BUS_RESET_DET:
 
8124                  * The firmware detected a SCSI Bus reset.
 
8126                 ASC_DBG(0, "ADV_ASYNC_SCSI_BUS_RESET_DET\n");
 
8129         case ADV_ASYNC_RDMA_FAILURE:
 
8131                  * Handle RDMA failure by resetting the SCSI Bus and
 
8132                  * possibly the chip if it is unresponsive. Log the error
 
8133                  * with a unique code.
 
8135                 ASC_DBG(0, "ADV_ASYNC_RDMA_FAILURE\n");
 
8136                 AdvResetChipAndSB(adv_dvc_varp);
 
8139         case ADV_HOST_SCSI_BUS_RESET:
 
8141                  * Host generated SCSI bus reset occurred.
 
8143                 ASC_DBG(0, "ADV_HOST_SCSI_BUS_RESET\n");
 
8147                 ASC_DBG(0, "unknown code 0x%x\n", code);
 
8153  * adv_isr_callback() - Second Level Interrupt Handler called by AdvISR().
 
8155  * Callback function for the Wide SCSI Adv Library.
 
8157 static void adv_isr_callback(ADV_DVC_VAR *adv_dvc_varp, ADV_SCSI_REQ_Q *scsiqp)
 
8159         struct asc_board *boardp;
 
8161         adv_sgblk_t *sgblkp;
 
8162         struct scsi_cmnd *scp;
 
8163         struct Scsi_Host *shost;
 
8166         ASC_DBG(1, "adv_dvc_varp 0x%lx, scsiqp 0x%lx\n",
 
8167                  (ulong)adv_dvc_varp, (ulong)scsiqp);
 
8168         ASC_DBG_PRT_ADV_SCSI_REQ_Q(2, scsiqp);
 
8171          * Get the adv_req_t structure for the command that has been
 
8172          * completed. The adv_req_t structure actually contains the
 
8173          * completed ADV_SCSI_REQ_Q structure.
 
8175         reqp = (adv_req_t *)ADV_U32_TO_VADDR(scsiqp->srb_ptr);
 
8176         ASC_DBG(1, "reqp 0x%lx\n", (ulong)reqp);
 
8178                 ASC_PRINT("adv_isr_callback: reqp is NULL\n");
 
8183          * Get the struct scsi_cmnd structure and Scsi_Host structure for the
 
8184          * command that has been completed.
 
8186          * Note: The adv_req_t request structure and adv_sgblk_t structure,
 
8187          * if any, are dropped, because a board structure pointer can not be
 
8191         ASC_DBG(1, "scp 0x%p\n", scp);
 
8194                     ("adv_isr_callback: scp is NULL; adv_req_t dropped.\n");
 
8197         ASC_DBG_PRT_CDB(2, scp->cmnd, scp->cmd_len);
 
8199         shost = scp->device->host;
 
8200         ASC_STATS(shost, callback);
 
8201         ASC_DBG(1, "shost 0x%p\n", shost);
 
8203         boardp = shost_priv(shost);
 
8204         BUG_ON(adv_dvc_varp != &boardp->dvc_var.adv_dvc_var);
 
8207          * 'done_status' contains the command's ending status.
 
8209         switch (scsiqp->done_status) {
 
8211                 ASC_DBG(2, "QD_NO_ERROR\n");
 
8215                  * Check for an underrun condition.
 
8217                  * If there was no error and an underrun condition, then
 
8218                  * then return the number of underrun bytes.
 
8220                 resid_cnt = le32_to_cpu(scsiqp->data_cnt);
 
8221                 if (scsi_bufflen(scp) != 0 && resid_cnt != 0 &&
 
8222                     resid_cnt <= scsi_bufflen(scp)) {
 
8223                         ASC_DBG(1, "underrun condition %lu bytes\n",
 
8225                         scsi_set_resid(scp, resid_cnt);
 
8230                 ASC_DBG(2, "QD_WITH_ERROR\n");
 
8231                 switch (scsiqp->host_status) {
 
8232                 case QHSTA_NO_ERROR:
 
8233                         if (scsiqp->scsi_status == SAM_STAT_CHECK_CONDITION) {
 
8234                                 ASC_DBG(2, "SAM_STAT_CHECK_CONDITION\n");
 
8235                                 ASC_DBG_PRT_SENSE(2, scp->sense_buffer,
 
8236                                                   sizeof(scp->sense_buffer));
 
8238                                  * Note: The 'status_byte()' macro used by
 
8239                                  * target drivers defined in scsi.h shifts the
 
8240                                  * status byte returned by host drivers right
 
8241                                  * by 1 bit.  This is why target drivers also
 
8242                                  * use right shifted status byte definitions.
 
8243                                  * For instance target drivers use
 
8244                                  * CHECK_CONDITION, defined to 0x1, instead of
 
8245                                  * the SCSI defined check condition value of
 
8246                                  * 0x2. Host drivers are supposed to return
 
8247                                  * the status byte as it is defined by SCSI.
 
8249                                 scp->result = DRIVER_BYTE(DRIVER_SENSE) |
 
8250                                     STATUS_BYTE(scsiqp->scsi_status);
 
8252                                 scp->result = STATUS_BYTE(scsiqp->scsi_status);
 
8257                         /* Some other QHSTA error occurred. */
 
8258                         ASC_DBG(1, "host_status 0x%x\n", scsiqp->host_status);
 
8259                         scp->result = HOST_BYTE(DID_BAD_TARGET);
 
8264         case QD_ABORTED_BY_HOST:
 
8265                 ASC_DBG(1, "QD_ABORTED_BY_HOST\n");
 
8267                     HOST_BYTE(DID_ABORT) | STATUS_BYTE(scsiqp->scsi_status);
 
8271                 ASC_DBG(1, "done_status 0x%x\n", scsiqp->done_status);
 
8273                     HOST_BYTE(DID_ERROR) | STATUS_BYTE(scsiqp->scsi_status);
 
8278          * If the 'init_tidmask' bit isn't already set for the target and the
 
8279          * current request finished normally, then set the bit for the target
 
8280          * to indicate that a device is present.
 
8282         if ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(scp->device->id)) == 0 &&
 
8283             scsiqp->done_status == QD_NO_ERROR &&
 
8284             scsiqp->host_status == QHSTA_NO_ERROR) {
 
8285                 boardp->init_tidmask |= ADV_TID_TO_TIDMASK(scp->device->id);
 
8291          * Free all 'adv_sgblk_t' structures allocated for the request.
 
8293         while ((sgblkp = reqp->sgblkp) != NULL) {
 
8294                 /* Remove 'sgblkp' from the request list. */
 
8295                 reqp->sgblkp = sgblkp->next_sgblkp;
 
8297                 /* Add 'sgblkp' to the board free list. */
 
8298                 sgblkp->next_sgblkp = boardp->adv_sgblkp;
 
8299                 boardp->adv_sgblkp = sgblkp;
 
8303          * Free the adv_req_t structure used with the command by adding
 
8304          * it back to the board free list.
 
8306         reqp->next_reqp = boardp->adv_reqp;
 
8307         boardp->adv_reqp = reqp;
 
8309         ASC_DBG(1, "done\n");
 
8313  * Adv Library Interrupt Service Routine
 
8315  *  This function is called by a driver's interrupt service routine.
 
8316  *  The function disables and re-enables interrupts.
 
8318  *  When a microcode idle command is completed, the ADV_DVC_VAR
 
8319  *  'idle_cmd_done' field is set to ADV_TRUE.
 
8321  *  Note: AdvISR() can be called when interrupts are disabled or even
 
8322  *  when there is no hardware interrupt condition present. It will
 
8323  *  always check for completed idle commands and microcode requests.
 
8324  *  This is an important feature that shouldn't be changed because it
 
8325  *  allows commands to be completed from polling mode loops.
 
8328  *   ADV_TRUE(1) - interrupt was pending
 
8329  *   ADV_FALSE(0) - no interrupt was pending
 
8331 static int AdvISR(ADV_DVC_VAR *asc_dvc)
 
8333         AdvPortAddr iop_base;
 
8336         ADV_CARR_T *free_carrp;
 
8337         ADV_VADDR irq_next_vpa;
 
8338         ADV_SCSI_REQ_Q *scsiq;
 
8340         iop_base = asc_dvc->iop_base;
 
8342         /* Reading the register clears the interrupt. */
 
8343         int_stat = AdvReadByteRegister(iop_base, IOPB_INTR_STATUS_REG);
 
8345         if ((int_stat & (ADV_INTR_STATUS_INTRA | ADV_INTR_STATUS_INTRB |
 
8346                          ADV_INTR_STATUS_INTRC)) == 0) {
 
8351          * Notify the driver of an asynchronous microcode condition by
 
8352          * calling the adv_async_callback function. The function
 
8353          * is passed the microcode ASC_MC_INTRB_CODE byte value.
 
8355         if (int_stat & ADV_INTR_STATUS_INTRB) {
 
8358                 AdvReadByteLram(iop_base, ASC_MC_INTRB_CODE, intrb_code);
 
8360                 if (asc_dvc->chip_type == ADV_CHIP_ASC3550 ||
 
8361                     asc_dvc->chip_type == ADV_CHIP_ASC38C0800) {
 
8362                         if (intrb_code == ADV_ASYNC_CARRIER_READY_FAILURE &&
 
8363                             asc_dvc->carr_pending_cnt != 0) {
 
8364                                 AdvWriteByteRegister(iop_base, IOPB_TICKLE,
 
8366                                 if (asc_dvc->chip_type == ADV_CHIP_ASC3550) {
 
8367                                         AdvWriteByteRegister(iop_base,
 
8374                 adv_async_callback(asc_dvc, intrb_code);
 
8378          * Check if the IRQ stopper carrier contains a completed request.
 
8380         while (((irq_next_vpa =
 
8381                  le32_to_cpu(asc_dvc->irq_sp->next_vpa)) & ASC_RQ_DONE) != 0) {
 
8383                  * Get a pointer to the newly completed ADV_SCSI_REQ_Q structure.
 
8384                  * The RISC will have set 'areq_vpa' to a virtual address.
 
8386                  * The firmware will have copied the ASC_SCSI_REQ_Q.scsiq_ptr
 
8387                  * field to the carrier ADV_CARR_T.areq_vpa field. The conversion
 
8388                  * below complements the conversion of ASC_SCSI_REQ_Q.scsiq_ptr'
 
8389                  * in AdvExeScsiQueue().
 
8391                 scsiq = (ADV_SCSI_REQ_Q *)
 
8392                     ADV_U32_TO_VADDR(le32_to_cpu(asc_dvc->irq_sp->areq_vpa));
 
8395                  * Request finished with good status and the queue was not
 
8396                  * DMAed to host memory by the firmware. Set all status fields
 
8397                  * to indicate good status.
 
8399                 if ((irq_next_vpa & ASC_RQ_GOOD) != 0) {
 
8400                         scsiq->done_status = QD_NO_ERROR;
 
8401                         scsiq->host_status = scsiq->scsi_status = 0;
 
8402                         scsiq->data_cnt = 0L;
 
8406                  * Advance the stopper pointer to the next carrier
 
8407                  * ignoring the lower four bits. Free the previous
 
8410                 free_carrp = asc_dvc->irq_sp;
 
8411                 asc_dvc->irq_sp = (ADV_CARR_T *)
 
8412                     ADV_U32_TO_VADDR(ASC_GET_CARRP(irq_next_vpa));
 
8414                 free_carrp->next_vpa =
 
8415                     cpu_to_le32(ADV_VADDR_TO_U32(asc_dvc->carr_freelist));
 
8416                 asc_dvc->carr_freelist = free_carrp;
 
8417                 asc_dvc->carr_pending_cnt--;
 
8419                 target_bit = ADV_TID_TO_TIDMASK(scsiq->target_id);
 
8422                  * Clear request microcode control flag.
 
8427                  * Notify the driver of the completed request by passing
 
8428                  * the ADV_SCSI_REQ_Q pointer to its callback function.
 
8430                 scsiq->a_flag |= ADV_SCSIQ_DONE;
 
8431                 adv_isr_callback(asc_dvc, scsiq);
 
8433                  * Note: After the driver callback function is called, 'scsiq'
 
8434                  * can no longer be referenced.
 
8436                  * Fall through and continue processing other completed
 
8443 static int AscSetLibErrorCode(ASC_DVC_VAR *asc_dvc, ushort err_code)
 
8445         if (asc_dvc->err_code == 0) {
 
8446                 asc_dvc->err_code = err_code;
 
8447                 AscWriteLramWord(asc_dvc->iop_base, ASCV_ASCDVC_ERR_CODE_W,
 
8453 static void AscAckInterrupt(PortAddr iop_base)
 
8461                 risc_flag = AscReadLramByte(iop_base, ASCV_RISC_FLAG_B);
 
8462                 if (loop++ > 0x7FFF) {
 
8465         } while ((risc_flag & ASC_RISC_FLAG_GEN_INT) != 0);
 
8467             AscReadLramByte(iop_base,
 
8468                             ASCV_HOST_FLAG_B) & (~ASC_HOST_FLAG_ACK_INT);
 
8469         AscWriteLramByte(iop_base, ASCV_HOST_FLAG_B,
 
8470                          (uchar)(host_flag | ASC_HOST_FLAG_ACK_INT));
 
8471         AscSetChipStatus(iop_base, CIW_INT_ACK);
 
8473         while (AscGetChipStatus(iop_base) & CSW_INT_PENDING) {
 
8474                 AscSetChipStatus(iop_base, CIW_INT_ACK);
 
8479         AscWriteLramByte(iop_base, ASCV_HOST_FLAG_B, host_flag);
 
8482 static uchar AscGetSynPeriodIndex(ASC_DVC_VAR *asc_dvc, uchar syn_time)
 
8484         const uchar *period_table;
 
8489         period_table = asc_dvc->sdtr_period_tbl;
 
8490         max_index = (int)asc_dvc->max_sdtr_index;
 
8491         min_index = (int)asc_dvc->min_sdtr_index;
 
8492         if ((syn_time <= period_table[max_index])) {
 
8493                 for (i = min_index; i < (max_index - 1); i++) {
 
8494                         if (syn_time <= period_table[i]) {
 
8498                 return (uchar)max_index;
 
8500                 return (uchar)(max_index + 1);
 
8505 AscMsgOutSDTR(ASC_DVC_VAR *asc_dvc, uchar sdtr_period, uchar sdtr_offset)
 
8508         uchar sdtr_period_index;
 
8511         iop_base = asc_dvc->iop_base;
 
8512         sdtr_buf.msg_type = EXTENDED_MESSAGE;
 
8513         sdtr_buf.msg_len = MS_SDTR_LEN;
 
8514         sdtr_buf.msg_req = EXTENDED_SDTR;
 
8515         sdtr_buf.xfer_period = sdtr_period;
 
8516         sdtr_offset &= ASC_SYN_MAX_OFFSET;
 
8517         sdtr_buf.req_ack_offset = sdtr_offset;
 
8518         sdtr_period_index = AscGetSynPeriodIndex(asc_dvc, sdtr_period);
 
8519         if (sdtr_period_index <= asc_dvc->max_sdtr_index) {
 
8520                 AscMemWordCopyPtrToLram(iop_base, ASCV_MSGOUT_BEG,
 
8522                                         sizeof(EXT_MSG) >> 1);
 
8523                 return ((sdtr_period_index << 4) | sdtr_offset);
 
8525                 sdtr_buf.req_ack_offset = 0;
 
8526                 AscMemWordCopyPtrToLram(iop_base, ASCV_MSGOUT_BEG,
 
8528                                         sizeof(EXT_MSG) >> 1);
 
8534 AscCalSDTRData(ASC_DVC_VAR *asc_dvc, uchar sdtr_period, uchar syn_offset)
 
8537         uchar sdtr_period_ix;
 
8539         sdtr_period_ix = AscGetSynPeriodIndex(asc_dvc, sdtr_period);
 
8540         if (sdtr_period_ix > asc_dvc->max_sdtr_index)
 
8542         byte = (sdtr_period_ix << 4) | (syn_offset & ASC_SYN_MAX_OFFSET);
 
8546 static int AscSetChipSynRegAtID(PortAddr iop_base, uchar id, uchar sdtr_data)
 
8548         ASC_SCSI_BIT_ID_TYPE org_id;
 
8552         AscSetBank(iop_base, 1);
 
8553         org_id = AscReadChipDvcID(iop_base);
 
8554         for (i = 0; i <= ASC_MAX_TID; i++) {
 
8555                 if (org_id == (0x01 << i))
 
8558         org_id = (ASC_SCSI_BIT_ID_TYPE) i;
 
8559         AscWriteChipDvcID(iop_base, id);
 
8560         if (AscReadChipDvcID(iop_base) == (0x01 << id)) {
 
8561                 AscSetBank(iop_base, 0);
 
8562                 AscSetChipSyn(iop_base, sdtr_data);
 
8563                 if (AscGetChipSyn(iop_base) != sdtr_data) {
 
8569         AscSetBank(iop_base, 1);
 
8570         AscWriteChipDvcID(iop_base, org_id);
 
8571         AscSetBank(iop_base, 0);
 
8575 static void AscSetChipSDTR(PortAddr iop_base, uchar sdtr_data, uchar tid_no)
 
8577         AscSetChipSynRegAtID(iop_base, tid_no, sdtr_data);
 
8578         AscPutMCodeSDTRDoneAtID(iop_base, tid_no, sdtr_data);
 
8581 static int AscIsrChipHalted(ASC_DVC_VAR *asc_dvc)
 
8587         ushort int_halt_code;
 
8588         ASC_SCSI_BIT_ID_TYPE scsi_busy;
 
8589         ASC_SCSI_BIT_ID_TYPE target_id;
 
8596         uchar q_cntl, tid_no;
 
8600         struct asc_board *boardp;
 
8602         BUG_ON(!asc_dvc->drv_ptr);
 
8603         boardp = asc_dvc->drv_ptr;
 
8605         iop_base = asc_dvc->iop_base;
 
8606         int_halt_code = AscReadLramWord(iop_base, ASCV_HALTCODE_W);
 
8608         halt_qp = AscReadLramByte(iop_base, ASCV_CURCDB_B);
 
8609         halt_q_addr = ASC_QNO_TO_QADDR(halt_qp);
 
8610         target_ix = AscReadLramByte(iop_base,
 
8611                                     (ushort)(halt_q_addr +
 
8612                                              (ushort)ASC_SCSIQ_B_TARGET_IX));
 
8613         q_cntl = AscReadLramByte(iop_base,
 
8614                             (ushort)(halt_q_addr + (ushort)ASC_SCSIQ_B_CNTL));
 
8615         tid_no = ASC_TIX_TO_TID(target_ix);
 
8616         target_id = (uchar)ASC_TID_TO_TARGET_ID(tid_no);
 
8617         if (asc_dvc->pci_fix_asyn_xfer & target_id) {
 
8618                 asyn_sdtr = ASYN_SDTR_DATA_FIX_PCI_REV_AB;
 
8622         if (int_halt_code == ASC_HALT_DISABLE_ASYN_USE_SYN_FIX) {
 
8623                 if (asc_dvc->pci_fix_asyn_xfer & target_id) {
 
8624                         AscSetChipSDTR(iop_base, 0, tid_no);
 
8625                         boardp->sdtr_data[tid_no] = 0;
 
8627                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8629         } else if (int_halt_code == ASC_HALT_ENABLE_ASYN_USE_SYN_FIX) {
 
8630                 if (asc_dvc->pci_fix_asyn_xfer & target_id) {
 
8631                         AscSetChipSDTR(iop_base, asyn_sdtr, tid_no);
 
8632                         boardp->sdtr_data[tid_no] = asyn_sdtr;
 
8634                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8636         } else if (int_halt_code == ASC_HALT_EXTMSG_IN) {
 
8637                 AscMemWordCopyPtrFromLram(iop_base,
 
8640                                           sizeof(EXT_MSG) >> 1);
 
8642                 if (ext_msg.msg_type == EXTENDED_MESSAGE &&
 
8643                     ext_msg.msg_req == EXTENDED_SDTR &&
 
8644                     ext_msg.msg_len == MS_SDTR_LEN) {
 
8646                         if ((ext_msg.req_ack_offset > ASC_SYN_MAX_OFFSET)) {
 
8648                                 sdtr_accept = FALSE;
 
8649                                 ext_msg.req_ack_offset = ASC_SYN_MAX_OFFSET;
 
8651                         if ((ext_msg.xfer_period <
 
8652                              asc_dvc->sdtr_period_tbl[asc_dvc->min_sdtr_index])
 
8653                             || (ext_msg.xfer_period >
 
8654                                 asc_dvc->sdtr_period_tbl[asc_dvc->
 
8656                                 sdtr_accept = FALSE;
 
8657                                 ext_msg.xfer_period =
 
8658                                     asc_dvc->sdtr_period_tbl[asc_dvc->
 
8663                                     AscCalSDTRData(asc_dvc, ext_msg.xfer_period,
 
8664                                                    ext_msg.req_ack_offset);
 
8665                                 if ((sdtr_data == 0xFF)) {
 
8667                                         q_cntl |= QC_MSG_OUT;
 
8668                                         asc_dvc->init_sdtr &= ~target_id;
 
8669                                         asc_dvc->sdtr_done &= ~target_id;
 
8670                                         AscSetChipSDTR(iop_base, asyn_sdtr,
 
8672                                         boardp->sdtr_data[tid_no] = asyn_sdtr;
 
8675                         if (ext_msg.req_ack_offset == 0) {
 
8677                                 q_cntl &= ~QC_MSG_OUT;
 
8678                                 asc_dvc->init_sdtr &= ~target_id;
 
8679                                 asc_dvc->sdtr_done &= ~target_id;
 
8680                                 AscSetChipSDTR(iop_base, asyn_sdtr, tid_no);
 
8682                                 if (sdtr_accept && (q_cntl & QC_MSG_OUT)) {
 
8683                                         q_cntl &= ~QC_MSG_OUT;
 
8684                                         asc_dvc->sdtr_done |= target_id;
 
8685                                         asc_dvc->init_sdtr |= target_id;
 
8686                                         asc_dvc->pci_fix_asyn_xfer &=
 
8689                                             AscCalSDTRData(asc_dvc,
 
8690                                                            ext_msg.xfer_period,
 
8693                                         AscSetChipSDTR(iop_base, sdtr_data,
 
8695                                         boardp->sdtr_data[tid_no] = sdtr_data;
 
8697                                         q_cntl |= QC_MSG_OUT;
 
8698                                         AscMsgOutSDTR(asc_dvc,
 
8699                                                       ext_msg.xfer_period,
 
8700                                                       ext_msg.req_ack_offset);
 
8701                                         asc_dvc->pci_fix_asyn_xfer &=
 
8704                                             AscCalSDTRData(asc_dvc,
 
8705                                                            ext_msg.xfer_period,
 
8708                                         AscSetChipSDTR(iop_base, sdtr_data,
 
8710                                         boardp->sdtr_data[tid_no] = sdtr_data;
 
8711                                         asc_dvc->sdtr_done |= target_id;
 
8712                                         asc_dvc->init_sdtr |= target_id;
 
8716                         AscWriteLramByte(iop_base,
 
8717                                          (ushort)(halt_q_addr +
 
8718                                                   (ushort)ASC_SCSIQ_B_CNTL),
 
8720                         AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8722                 } else if (ext_msg.msg_type == EXTENDED_MESSAGE &&
 
8723                            ext_msg.msg_req == EXTENDED_WDTR &&
 
8724                            ext_msg.msg_len == MS_WDTR_LEN) {
 
8726                         ext_msg.wdtr_width = 0;
 
8727                         AscMemWordCopyPtrToLram(iop_base,
 
8730                                                 sizeof(EXT_MSG) >> 1);
 
8731                         q_cntl |= QC_MSG_OUT;
 
8732                         AscWriteLramByte(iop_base,
 
8733                                          (ushort)(halt_q_addr +
 
8734                                                   (ushort)ASC_SCSIQ_B_CNTL),
 
8736                         AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8740                         ext_msg.msg_type = MESSAGE_REJECT;
 
8741                         AscMemWordCopyPtrToLram(iop_base,
 
8744                                                 sizeof(EXT_MSG) >> 1);
 
8745                         q_cntl |= QC_MSG_OUT;
 
8746                         AscWriteLramByte(iop_base,
 
8747                                          (ushort)(halt_q_addr +
 
8748                                                   (ushort)ASC_SCSIQ_B_CNTL),
 
8750                         AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8753         } else if (int_halt_code == ASC_HALT_CHK_CONDITION) {
 
8755                 q_cntl |= QC_REQ_SENSE;
 
8757                 if ((asc_dvc->init_sdtr & target_id) != 0) {
 
8759                         asc_dvc->sdtr_done &= ~target_id;
 
8761                         sdtr_data = AscGetMCodeInitSDTRAtID(iop_base, tid_no);
 
8762                         q_cntl |= QC_MSG_OUT;
 
8763                         AscMsgOutSDTR(asc_dvc,
 
8765                                       sdtr_period_tbl[(sdtr_data >> 4) &
 
8769                                       (uchar)(sdtr_data & (uchar)
 
8770                                               ASC_SYN_MAX_OFFSET));
 
8773                 AscWriteLramByte(iop_base,
 
8774                                  (ushort)(halt_q_addr +
 
8775                                           (ushort)ASC_SCSIQ_B_CNTL), q_cntl);
 
8777                 tag_code = AscReadLramByte(iop_base,
 
8778                                            (ushort)(halt_q_addr + (ushort)
 
8779                                                     ASC_SCSIQ_B_TAG_CODE));
 
8781                 if ((asc_dvc->pci_fix_asyn_xfer & target_id)
 
8782                     && !(asc_dvc->pci_fix_asyn_xfer_always & target_id)
 
8785                         tag_code |= (ASC_TAG_FLAG_DISABLE_DISCONNECT
 
8786                                      | ASC_TAG_FLAG_DISABLE_ASYN_USE_SYN_FIX);
 
8789                 AscWriteLramByte(iop_base,
 
8790                                  (ushort)(halt_q_addr +
 
8791                                           (ushort)ASC_SCSIQ_B_TAG_CODE),
 
8794                 q_status = AscReadLramByte(iop_base,
 
8795                                            (ushort)(halt_q_addr + (ushort)
 
8796                                                     ASC_SCSIQ_B_STATUS));
 
8797                 q_status |= (QS_READY | QS_BUSY);
 
8798                 AscWriteLramByte(iop_base,
 
8799                                  (ushort)(halt_q_addr +
 
8800                                           (ushort)ASC_SCSIQ_B_STATUS),
 
8803                 scsi_busy = AscReadLramByte(iop_base, (ushort)ASCV_SCSIBUSY_B);
 
8804                 scsi_busy &= ~target_id;
 
8805                 AscWriteLramByte(iop_base, (ushort)ASCV_SCSIBUSY_B, scsi_busy);
 
8807                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8809         } else if (int_halt_code == ASC_HALT_SDTR_REJECTED) {
 
8811                 AscMemWordCopyPtrFromLram(iop_base,
 
8814                                           sizeof(EXT_MSG) >> 1);
 
8816                 if ((out_msg.msg_type == EXTENDED_MESSAGE) &&
 
8817                     (out_msg.msg_len == MS_SDTR_LEN) &&
 
8818                     (out_msg.msg_req == EXTENDED_SDTR)) {
 
8820                         asc_dvc->init_sdtr &= ~target_id;
 
8821                         asc_dvc->sdtr_done &= ~target_id;
 
8822                         AscSetChipSDTR(iop_base, asyn_sdtr, tid_no);
 
8823                         boardp->sdtr_data[tid_no] = asyn_sdtr;
 
8825                 q_cntl &= ~QC_MSG_OUT;
 
8826                 AscWriteLramByte(iop_base,
 
8827                                  (ushort)(halt_q_addr +
 
8828                                           (ushort)ASC_SCSIQ_B_CNTL), q_cntl);
 
8829                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8831         } else if (int_halt_code == ASC_HALT_SS_QUEUE_FULL) {
 
8833                 scsi_status = AscReadLramByte(iop_base,
 
8834                                               (ushort)((ushort)halt_q_addr +
 
8836                                                        ASC_SCSIQ_SCSI_STATUS));
 
8838                     AscReadLramByte(iop_base,
 
8839                                     (ushort)((ushort)ASC_QADR_BEG +
 
8840                                              (ushort)target_ix));
 
8841                 if ((cur_dvc_qng > 0) && (asc_dvc->cur_dvc_qng[tid_no] > 0)) {
 
8843                         scsi_busy = AscReadLramByte(iop_base,
 
8844                                                     (ushort)ASCV_SCSIBUSY_B);
 
8845                         scsi_busy |= target_id;
 
8846                         AscWriteLramByte(iop_base,
 
8847                                          (ushort)ASCV_SCSIBUSY_B, scsi_busy);
 
8848                         asc_dvc->queue_full_or_busy |= target_id;
 
8850                         if (scsi_status == SAM_STAT_TASK_SET_FULL) {
 
8851                                 if (cur_dvc_qng > ASC_MIN_TAGGED_CMD) {
 
8853                                         asc_dvc->max_dvc_qng[tid_no] =
 
8856                                         AscWriteLramByte(iop_base,
 
8858                                                                   ASCV_MAX_DVC_QNG_BEG
 
8864                                          * Set the device queue depth to the
 
8865                                          * number of active requests when the
 
8866                                          * QUEUE FULL condition was encountered.
 
8868                                         boardp->queue_full |= target_id;
 
8869                                         boardp->queue_full_cnt[tid_no] =
 
8874                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
8877 #if CC_VERY_LONG_SG_LIST
 
8878         else if (int_halt_code == ASC_HALT_HOST_COPY_SG_LIST_TO_RISC) {
 
8882                 uchar first_sg_wk_q_no;
 
8883                 ASC_SCSI_Q *scsiq;      /* Ptr to driver request. */
 
8884                 ASC_SG_HEAD *sg_head;   /* Ptr to driver SG request. */
 
8885                 ASC_SG_LIST_Q scsi_sg_q;        /* Structure written to queue. */
 
8886                 ushort sg_list_dwords;
 
8887                 ushort sg_entry_cnt;
 
8891                 q_no = AscReadLramByte(iop_base, (ushort)ASCV_REQ_SG_LIST_QP);
 
8892                 if (q_no == ASC_QLINK_END)
 
8895                 q_addr = ASC_QNO_TO_QADDR(q_no);
 
8898                  * Convert the request's SRB pointer to a host ASC_SCSI_REQ
 
8899                  * structure pointer using a macro provided by the driver.
 
8900                  * The ASC_SCSI_REQ pointer provides a pointer to the
 
8901                  * host ASC_SG_HEAD structure.
 
8903                 /* Read request's SRB pointer. */
 
8904                 scsiq = (ASC_SCSI_Q *)
 
8905                     ASC_SRB2SCSIQ(ASC_U32_TO_VADDR(AscReadLramDWord(iop_base,
 
8908                                                                      ASC_SCSIQ_D_SRBPTR))));
 
8911                  * Get request's first and working SG queue.
 
8913                 sg_wk_q_no = AscReadLramByte(iop_base,
 
8915                                                       ASC_SCSIQ_B_SG_WK_QP));
 
8917                 first_sg_wk_q_no = AscReadLramByte(iop_base,
 
8919                                                             ASC_SCSIQ_B_FIRST_SG_WK_QP));
 
8922                  * Reset request's working SG queue back to the
 
8925                 AscWriteLramByte(iop_base,
 
8927                                           (ushort)ASC_SCSIQ_B_SG_WK_QP),
 
8930                 sg_head = scsiq->sg_head;
 
8933                  * Set sg_entry_cnt to the number of SG elements
 
8934                  * that will be completed on this interrupt.
 
8936                  * Note: The allocated SG queues contain ASC_MAX_SG_LIST - 1
 
8937                  * SG elements. The data_cnt and data_addr fields which
 
8938                  * add 1 to the SG element capacity are not used when
 
8939                  * restarting SG handling after a halt.
 
8941                 if (scsiq->remain_sg_entry_cnt > (ASC_MAX_SG_LIST - 1)) {
 
8942                         sg_entry_cnt = ASC_MAX_SG_LIST - 1;
 
8945                          * Keep track of remaining number of SG elements that
 
8946                          * will need to be handled on the next interrupt.
 
8948                         scsiq->remain_sg_entry_cnt -= (ASC_MAX_SG_LIST - 1);
 
8950                         sg_entry_cnt = scsiq->remain_sg_entry_cnt;
 
8951                         scsiq->remain_sg_entry_cnt = 0;
 
8955                  * Copy SG elements into the list of allocated SG queues.
 
8957                  * Last index completed is saved in scsiq->next_sg_index.
 
8959                 next_qp = first_sg_wk_q_no;
 
8960                 q_addr = ASC_QNO_TO_QADDR(next_qp);
 
8961                 scsi_sg_q.sg_head_qp = q_no;
 
8962                 scsi_sg_q.cntl = QCSG_SG_XFER_LIST;
 
8963                 for (i = 0; i < sg_head->queue_cnt; i++) {
 
8964                         scsi_sg_q.seq_no = i + 1;
 
8965                         if (sg_entry_cnt > ASC_SG_LIST_PER_Q) {
 
8966                                 sg_list_dwords = (uchar)(ASC_SG_LIST_PER_Q * 2);
 
8967                                 sg_entry_cnt -= ASC_SG_LIST_PER_Q;
 
8969                                  * After very first SG queue RISC FW uses next
 
8970                                  * SG queue first element then checks sg_list_cnt
 
8971                                  * against zero and then decrements, so set
 
8972                                  * sg_list_cnt 1 less than number of SG elements
 
8975                                 scsi_sg_q.sg_list_cnt = ASC_SG_LIST_PER_Q - 1;
 
8976                                 scsi_sg_q.sg_cur_list_cnt =
 
8977                                     ASC_SG_LIST_PER_Q - 1;
 
8980                                  * This is the last SG queue in the list of
 
8981                                  * allocated SG queues. If there are more
 
8982                                  * SG elements than will fit in the allocated
 
8983                                  * queues, then set the QCSG_SG_XFER_MORE flag.
 
8985                                 if (scsiq->remain_sg_entry_cnt != 0) {
 
8986                                         scsi_sg_q.cntl |= QCSG_SG_XFER_MORE;
 
8988                                         scsi_sg_q.cntl |= QCSG_SG_XFER_END;
 
8990                                 /* equals sg_entry_cnt * 2 */
 
8991                                 sg_list_dwords = sg_entry_cnt << 1;
 
8992                                 scsi_sg_q.sg_list_cnt = sg_entry_cnt - 1;
 
8993                                 scsi_sg_q.sg_cur_list_cnt = sg_entry_cnt - 1;
 
8997                         scsi_sg_q.q_no = next_qp;
 
8998                         AscMemWordCopyPtrToLram(iop_base,
 
8999                                                 q_addr + ASC_SCSIQ_SGHD_CPY_BEG,
 
9000                                                 (uchar *)&scsi_sg_q,
 
9001                                                 sizeof(ASC_SG_LIST_Q) >> 1);
 
9003                         AscMemDWordCopyPtrToLram(iop_base,
 
9004                                                  q_addr + ASC_SGQ_LIST_BEG,
 
9006                                                  sg_list[scsiq->next_sg_index],
 
9009                         scsiq->next_sg_index += ASC_SG_LIST_PER_Q;
 
9012                          * If the just completed SG queue contained the
 
9013                          * last SG element, then no more SG queues need
 
9016                         if (scsi_sg_q.cntl & QCSG_SG_XFER_END) {
 
9020                         next_qp = AscReadLramByte(iop_base,
 
9023                         q_addr = ASC_QNO_TO_QADDR(next_qp);
 
9027                  * Clear the halt condition so the RISC will be restarted
 
9030                 AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0);
 
9033 #endif /* CC_VERY_LONG_SG_LIST */
 
9039  * DvcGetQinfo(PortAddr iop_base, ushort s_addr, uchar *inbuf, int words)
 
9041  * Calling/Exit State:
 
9045  *     Input an ASC_QDONE_INFO structure from the chip
 
9048 DvcGetQinfo(PortAddr iop_base, ushort s_addr, uchar *inbuf, int words)
 
9053         AscSetChipLramAddr(iop_base, s_addr);
 
9054         for (i = 0; i < 2 * words; i += 2) {
 
9058                 word = inpw(iop_base + IOP_RAM_DATA);
 
9059                 inbuf[i] = word & 0xff;
 
9060                 inbuf[i + 1] = (word >> 8) & 0xff;
 
9062         ASC_DBG_PRT_HEX(2, "DvcGetQinfo", inbuf, 2 * words);
 
9066 _AscCopyLramScsiDoneQ(PortAddr iop_base,
 
9068                       ASC_QDONE_INFO *scsiq, ASC_DCNT max_dma_count)
 
9073         DvcGetQinfo(iop_base,
 
9074                     q_addr + ASC_SCSIQ_DONE_INFO_BEG,
 
9076                     (sizeof(ASC_SCSIQ_2) + sizeof(ASC_SCSIQ_3)) / 2);
 
9078         _val = AscReadLramWord(iop_base,
 
9079                                (ushort)(q_addr + (ushort)ASC_SCSIQ_B_STATUS));
 
9080         scsiq->q_status = (uchar)_val;
 
9081         scsiq->q_no = (uchar)(_val >> 8);
 
9082         _val = AscReadLramWord(iop_base,
 
9083                                (ushort)(q_addr + (ushort)ASC_SCSIQ_B_CNTL));
 
9084         scsiq->cntl = (uchar)_val;
 
9085         sg_queue_cnt = (uchar)(_val >> 8);
 
9086         _val = AscReadLramWord(iop_base,
 
9088                                         (ushort)ASC_SCSIQ_B_SENSE_LEN));
 
9089         scsiq->sense_len = (uchar)_val;
 
9090         scsiq->extra_bytes = (uchar)(_val >> 8);
 
9093          * Read high word of remain bytes from alternate location.
 
9095         scsiq->remain_bytes = (((ADV_DCNT)AscReadLramWord(iop_base,
 
9098                                                                    ASC_SCSIQ_W_ALT_DC1)))
 
9101          * Read low word of remain bytes from original location.
 
9103         scsiq->remain_bytes += AscReadLramWord(iop_base,
 
9104                                                (ushort)(q_addr + (ushort)
 
9105                                                         ASC_SCSIQ_DW_REMAIN_XFER_CNT));
 
9107         scsiq->remain_bytes &= max_dma_count;
 
9108         return sg_queue_cnt;
 
9112  * asc_isr_callback() - Second Level Interrupt Handler called by AscISR().
 
9114  * Interrupt callback function for the Narrow SCSI Asc Library.
 
9116 static void asc_isr_callback(ASC_DVC_VAR *asc_dvc_varp, ASC_QDONE_INFO *qdonep)
 
9118         struct asc_board *boardp;
 
9119         struct scsi_cmnd *scp;
 
9120         struct Scsi_Host *shost;
 
9122         ASC_DBG(1, "asc_dvc_varp 0x%p, qdonep 0x%p\n", asc_dvc_varp, qdonep);
 
9123         ASC_DBG_PRT_ASC_QDONE_INFO(2, qdonep);
 
9125         scp = advansys_srb_to_ptr(asc_dvc_varp, qdonep->d2.srb_ptr);
 
9129         ASC_DBG_PRT_CDB(2, scp->cmnd, scp->cmd_len);
 
9131         shost = scp->device->host;
 
9132         ASC_STATS(shost, callback);
 
9133         ASC_DBG(1, "shost 0x%p\n", shost);
 
9135         boardp = shost_priv(shost);
 
9136         BUG_ON(asc_dvc_varp != &boardp->dvc_var.asc_dvc_var);
 
9138         dma_unmap_single(boardp->dev, scp->SCp.dma_handle,
 
9139                         sizeof(scp->sense_buffer), DMA_FROM_DEVICE);
 
9141          * 'qdonep' contains the command's ending status.
 
9143         switch (qdonep->d3.done_stat) {
 
9145                 ASC_DBG(2, "QD_NO_ERROR\n");
 
9149                  * Check for an underrun condition.
 
9151                  * If there was no error and an underrun condition, then
 
9152                  * return the number of underrun bytes.
 
9154                 if (scsi_bufflen(scp) != 0 && qdonep->remain_bytes != 0 &&
 
9155                     qdonep->remain_bytes <= scsi_bufflen(scp)) {
 
9156                         ASC_DBG(1, "underrun condition %u bytes\n",
 
9157                                  (unsigned)qdonep->remain_bytes);
 
9158                         scsi_set_resid(scp, qdonep->remain_bytes);
 
9163                 ASC_DBG(2, "QD_WITH_ERROR\n");
 
9164                 switch (qdonep->d3.host_stat) {
 
9165                 case QHSTA_NO_ERROR:
 
9166                         if (qdonep->d3.scsi_stat == SAM_STAT_CHECK_CONDITION) {
 
9167                                 ASC_DBG(2, "SAM_STAT_CHECK_CONDITION\n");
 
9168                                 ASC_DBG_PRT_SENSE(2, scp->sense_buffer,
 
9169                                                   sizeof(scp->sense_buffer));
 
9171                                  * Note: The 'status_byte()' macro used by
 
9172                                  * target drivers defined in scsi.h shifts the
 
9173                                  * status byte returned by host drivers right
 
9174                                  * by 1 bit.  This is why target drivers also
 
9175                                  * use right shifted status byte definitions.
 
9176                                  * For instance target drivers use
 
9177                                  * CHECK_CONDITION, defined to 0x1, instead of
 
9178                                  * the SCSI defined check condition value of
 
9179                                  * 0x2. Host drivers are supposed to return
 
9180                                  * the status byte as it is defined by SCSI.
 
9182                                 scp->result = DRIVER_BYTE(DRIVER_SENSE) |
 
9183                                     STATUS_BYTE(qdonep->d3.scsi_stat);
 
9185                                 scp->result = STATUS_BYTE(qdonep->d3.scsi_stat);
 
9190                         /* QHSTA error occurred */
 
9191                         ASC_DBG(1, "host_stat 0x%x\n", qdonep->d3.host_stat);
 
9192                         scp->result = HOST_BYTE(DID_BAD_TARGET);
 
9197         case QD_ABORTED_BY_HOST:
 
9198                 ASC_DBG(1, "QD_ABORTED_BY_HOST\n");
 
9200                     HOST_BYTE(DID_ABORT) | MSG_BYTE(qdonep->d3.
 
9202                     STATUS_BYTE(qdonep->d3.scsi_stat);
 
9206                 ASC_DBG(1, "done_stat 0x%x\n", qdonep->d3.done_stat);
 
9208                     HOST_BYTE(DID_ERROR) | MSG_BYTE(qdonep->d3.
 
9210                     STATUS_BYTE(qdonep->d3.scsi_stat);
 
9215          * If the 'init_tidmask' bit isn't already set for the target and the
 
9216          * current request finished normally, then set the bit for the target
 
9217          * to indicate that a device is present.
 
9219         if ((boardp->init_tidmask & ADV_TID_TO_TIDMASK(scp->device->id)) == 0 &&
 
9220             qdonep->d3.done_stat == QD_NO_ERROR &&
 
9221             qdonep->d3.host_stat == QHSTA_NO_ERROR) {
 
9222                 boardp->init_tidmask |= ADV_TID_TO_TIDMASK(scp->device->id);
 
9228 static int AscIsrQDone(ASC_DVC_VAR *asc_dvc)
 
9237         ASC_SCSI_BIT_ID_TYPE scsi_busy;
 
9238         ASC_SCSI_BIT_ID_TYPE target_id;
 
9242         uchar cur_target_qng;
 
9243         ASC_QDONE_INFO scsiq_buf;
 
9244         ASC_QDONE_INFO *scsiq;
 
9247         iop_base = asc_dvc->iop_base;
 
9249         scsiq = (ASC_QDONE_INFO *)&scsiq_buf;
 
9250         done_q_tail = (uchar)AscGetVarDoneQTail(iop_base);
 
9251         q_addr = ASC_QNO_TO_QADDR(done_q_tail);
 
9252         next_qp = AscReadLramByte(iop_base,
 
9253                                   (ushort)(q_addr + (ushort)ASC_SCSIQ_B_FWD));
 
9254         if (next_qp != ASC_QLINK_END) {
 
9255                 AscPutVarDoneQTail(iop_base, next_qp);
 
9256                 q_addr = ASC_QNO_TO_QADDR(next_qp);
 
9257                 sg_queue_cnt = _AscCopyLramScsiDoneQ(iop_base, q_addr, scsiq,
 
9258                                                      asc_dvc->max_dma_count);
 
9259                 AscWriteLramByte(iop_base,
 
9261                                           (ushort)ASC_SCSIQ_B_STATUS),
 
9263                                          q_status & (uchar)~(QS_READY |
 
9265                 tid_no = ASC_TIX_TO_TID(scsiq->d2.target_ix);
 
9266                 target_id = ASC_TIX_TO_TARGET_ID(scsiq->d2.target_ix);
 
9267                 if ((scsiq->cntl & QC_SG_HEAD) != 0) {
 
9269                         sg_list_qp = next_qp;
 
9270                         for (q_cnt = 0; q_cnt < sg_queue_cnt; q_cnt++) {
 
9271                                 sg_list_qp = AscReadLramByte(iop_base,
 
9275                                 sg_q_addr = ASC_QNO_TO_QADDR(sg_list_qp);
 
9276                                 if (sg_list_qp == ASC_QLINK_END) {
 
9277                                         AscSetLibErrorCode(asc_dvc,
 
9278                                                            ASCQ_ERR_SG_Q_LINKS);
 
9279                                         scsiq->d3.done_stat = QD_WITH_ERROR;
 
9280                                         scsiq->d3.host_stat =
 
9281                                             QHSTA_D_QDONE_SG_LIST_CORRUPTED;
 
9282                                         goto FATAL_ERR_QDONE;
 
9284                                 AscWriteLramByte(iop_base,
 
9285                                                  (ushort)(sg_q_addr + (ushort)
 
9286                                                           ASC_SCSIQ_B_STATUS),
 
9289                         n_q_used = sg_queue_cnt + 1;
 
9290                         AscPutVarDoneQTail(iop_base, sg_list_qp);
 
9292                 if (asc_dvc->queue_full_or_busy & target_id) {
 
9293                         cur_target_qng = AscReadLramByte(iop_base,
 
9299                         if (cur_target_qng < asc_dvc->max_dvc_qng[tid_no]) {
 
9300                                 scsi_busy = AscReadLramByte(iop_base, (ushort)
 
9302                                 scsi_busy &= ~target_id;
 
9303                                 AscWriteLramByte(iop_base,
 
9304                                                  (ushort)ASCV_SCSIBUSY_B,
 
9306                                 asc_dvc->queue_full_or_busy &= ~target_id;
 
9309                 if (asc_dvc->cur_total_qng >= n_q_used) {
 
9310                         asc_dvc->cur_total_qng -= n_q_used;
 
9311                         if (asc_dvc->cur_dvc_qng[tid_no] != 0) {
 
9312                                 asc_dvc->cur_dvc_qng[tid_no]--;
 
9315                         AscSetLibErrorCode(asc_dvc, ASCQ_ERR_CUR_QNG);
 
9316                         scsiq->d3.done_stat = QD_WITH_ERROR;
 
9317                         goto FATAL_ERR_QDONE;
 
9319                 if ((scsiq->d2.srb_ptr == 0UL) ||
 
9320                     ((scsiq->q_status & QS_ABORTED) != 0)) {
 
9322                 } else if (scsiq->q_status == QS_DONE) {
 
9323                         false_overrun = FALSE;
 
9324                         if (scsiq->extra_bytes != 0) {
 
9325                                 scsiq->remain_bytes +=
 
9326                                     (ADV_DCNT)scsiq->extra_bytes;
 
9328                         if (scsiq->d3.done_stat == QD_WITH_ERROR) {
 
9329                                 if (scsiq->d3.host_stat ==
 
9330                                     QHSTA_M_DATA_OVER_RUN) {
 
9332                                              cntl & (QC_DATA_IN | QC_DATA_OUT))
 
9334                                                 scsiq->d3.done_stat =
 
9336                                                 scsiq->d3.host_stat =
 
9338                                         } else if (false_overrun) {
 
9339                                                 scsiq->d3.done_stat =
 
9341                                                 scsiq->d3.host_stat =
 
9344                                 } else if (scsiq->d3.host_stat ==
 
9345                                            QHSTA_M_HUNG_REQ_SCSI_BUS_RESET) {
 
9346                                         AscStopChip(iop_base);
 
9347                                         AscSetChipControl(iop_base,
 
9348                                                           (uchar)(CC_SCSI_RESET
 
9351                                         AscSetChipControl(iop_base, CC_HALT);
 
9352                                         AscSetChipStatus(iop_base,
 
9353                                                          CIW_CLR_SCSI_RESET_INT);
 
9354                                         AscSetChipStatus(iop_base, 0);
 
9355                                         AscSetChipControl(iop_base, 0);
 
9358                         if ((scsiq->cntl & QC_NO_CALLBACK) == 0) {
 
9359                                 asc_isr_callback(asc_dvc, scsiq);
 
9361                                 if ((AscReadLramByte(iop_base,
 
9362                                                      (ushort)(q_addr + (ushort)
 
9365                                         asc_dvc->unit_not_ready &= ~target_id;
 
9366                                         if (scsiq->d3.done_stat != QD_NO_ERROR) {
 
9367                                                 asc_dvc->start_motor &=
 
9374                         AscSetLibErrorCode(asc_dvc, ASCQ_ERR_Q_STATUS);
 
9376                         if ((scsiq->cntl & QC_NO_CALLBACK) == 0) {
 
9377                                 asc_isr_callback(asc_dvc, scsiq);
 
9385 static int AscISR(ASC_DVC_VAR *asc_dvc)
 
9387         ASC_CS_TYPE chipstat;
 
9389         ushort saved_ram_addr;
 
9391         uchar saved_ctrl_reg;
 
9396         iop_base = asc_dvc->iop_base;
 
9397         int_pending = FALSE;
 
9399         if (AscIsIntPending(iop_base) == 0)
 
9402         if ((asc_dvc->init_state & ASC_INIT_STATE_END_LOAD_MC) == 0) {
 
9405         if (asc_dvc->in_critical_cnt != 0) {
 
9406                 AscSetLibErrorCode(asc_dvc, ASCQ_ERR_ISR_ON_CRITICAL);
 
9409         if (asc_dvc->is_in_int) {
 
9410                 AscSetLibErrorCode(asc_dvc, ASCQ_ERR_ISR_RE_ENTRY);
 
9413         asc_dvc->is_in_int = TRUE;
 
9414         ctrl_reg = AscGetChipControl(iop_base);
 
9415         saved_ctrl_reg = ctrl_reg & (~(CC_SCSI_RESET | CC_CHIP_RESET |
 
9416                                        CC_SINGLE_STEP | CC_DIAG | CC_TEST));
 
9417         chipstat = AscGetChipStatus(iop_base);
 
9418         if (chipstat & CSW_SCSI_RESET_LATCH) {
 
9419                 if (!(asc_dvc->bus_type & (ASC_IS_VL | ASC_IS_EISA))) {
 
9422                         asc_dvc->sdtr_done = 0;
 
9423                         saved_ctrl_reg &= (uchar)(~CC_HALT);
 
9424                         while ((AscGetChipStatus(iop_base) &
 
9425                                 CSW_SCSI_RESET_ACTIVE) && (i-- > 0)) {
 
9428                         AscSetChipControl(iop_base, (CC_CHIP_RESET | CC_HALT));
 
9429                         AscSetChipControl(iop_base, CC_HALT);
 
9430                         AscSetChipStatus(iop_base, CIW_CLR_SCSI_RESET_INT);
 
9431                         AscSetChipStatus(iop_base, 0);
 
9432                         chipstat = AscGetChipStatus(iop_base);
 
9435         saved_ram_addr = AscGetChipLramAddr(iop_base);
 
9436         host_flag = AscReadLramByte(iop_base,
 
9438             (uchar)(~ASC_HOST_FLAG_IN_ISR);
 
9439         AscWriteLramByte(iop_base, ASCV_HOST_FLAG_B,
 
9440                          (uchar)(host_flag | (uchar)ASC_HOST_FLAG_IN_ISR));
 
9441         if ((chipstat & CSW_INT_PENDING) || (int_pending)) {
 
9442                 AscAckInterrupt(iop_base);
 
9444                 if ((chipstat & CSW_HALTED) && (ctrl_reg & CC_SINGLE_STEP)) {
 
9445                         if (AscIsrChipHalted(asc_dvc) == ERR) {
 
9446                                 goto ISR_REPORT_QDONE_FATAL_ERROR;
 
9448                                 saved_ctrl_reg &= (uchar)(~CC_HALT);
 
9451  ISR_REPORT_QDONE_FATAL_ERROR:
 
9452                         if ((asc_dvc->dvc_cntl & ASC_CNTL_INT_MULTI_Q) != 0) {
 
9454                                          AscIsrQDone(asc_dvc)) & 0x01) != 0) {
 
9459                                              AscIsrQDone(asc_dvc)) == 1) {
 
9462                                 } while (status == 0x11);
 
9464                         if ((status & 0x80) != 0)
 
9468         AscWriteLramByte(iop_base, ASCV_HOST_FLAG_B, host_flag);
 
9469         AscSetChipLramAddr(iop_base, saved_ram_addr);
 
9470         AscSetChipControl(iop_base, saved_ctrl_reg);
 
9471         asc_dvc->is_in_int = FALSE;
 
9478  * Reset the bus associated with the command 'scp'.
 
9480  * This function runs its own thread. Interrupts must be blocked but
 
9481  * sleeping is allowed and no locking other than for host structures is
 
9482  * required. Returns SUCCESS or FAILED.
 
9484 static int advansys_reset(struct scsi_cmnd *scp)
 
9486         struct Scsi_Host *shost = scp->device->host;
 
9487         struct asc_board *boardp = shost_priv(shost);
 
9488         unsigned long flags;
 
9492         ASC_DBG(1, "0x%p\n", scp);
 
9494         ASC_STATS(shost, reset);
 
9496         scmd_printk(KERN_INFO, scp, "SCSI bus reset started...\n");
 
9498         if (ASC_NARROW_BOARD(boardp)) {
 
9499                 ASC_DVC_VAR *asc_dvc = &boardp->dvc_var.asc_dvc_var;
 
9501                 /* Reset the chip and SCSI bus. */
 
9502                 ASC_DBG(1, "before AscInitAsc1000Driver()\n");
 
9503                 status = AscInitAsc1000Driver(asc_dvc);
 
9505                 /* Refer to ASC_IERR_* defintions for meaning of 'err_code'. */
 
9506                 if (asc_dvc->err_code) {
 
9507                         scmd_printk(KERN_INFO, scp, "SCSI bus reset error: "
 
9508                                     "0x%x\n", asc_dvc->err_code);
 
9510                 } else if (status) {
 
9511                         scmd_printk(KERN_INFO, scp, "SCSI bus reset warning: "
 
9514                         scmd_printk(KERN_INFO, scp, "SCSI bus reset "
 
9518                 ASC_DBG(1, "after AscInitAsc1000Driver()\n");
 
9519                 spin_lock_irqsave(shost->host_lock, flags);
 
9522                  * If the suggest reset bus flags are set, then reset the bus.
 
9523                  * Otherwise only reset the device.
 
9525                 ADV_DVC_VAR *adv_dvc = &boardp->dvc_var.adv_dvc_var;
 
9528                  * Reset the target's SCSI bus.
 
9530                 ASC_DBG(1, "before AdvResetChipAndSB()\n");
 
9531                 switch (AdvResetChipAndSB(adv_dvc)) {
 
9533                         scmd_printk(KERN_INFO, scp, "SCSI bus reset "
 
9538                         scmd_printk(KERN_INFO, scp, "SCSI bus reset error\n");
 
9542                 spin_lock_irqsave(shost->host_lock, flags);
 
9546         /* Save the time of the most recently completed reset. */
 
9547         boardp->last_reset = jiffies;
 
9548         spin_unlock_irqrestore(shost->host_lock, flags);
 
9550         ASC_DBG(1, "ret %d\n", ret);
 
9556  * advansys_biosparam()
 
9558  * Translate disk drive geometry if the "BIOS greater than 1 GB"
 
9559  * support is enabled for a drive.
 
9561  * ip (information pointer) is an int array with the following definition:
 
9567 advansys_biosparam(struct scsi_device *sdev, struct block_device *bdev,
 
9568                    sector_t capacity, int ip[])
 
9570         struct asc_board *boardp = shost_priv(sdev->host);
 
9572         ASC_DBG(1, "begin\n");
 
9573         ASC_STATS(sdev->host, biosparam);
 
9574         if (ASC_NARROW_BOARD(boardp)) {
 
9575                 if ((boardp->dvc_var.asc_dvc_var.dvc_cntl &
 
9576                      ASC_CNTL_BIOS_GT_1GB) && capacity > 0x200000) {
 
9584                 if ((boardp->dvc_var.adv_dvc_var.bios_ctrl &
 
9585                      BIOS_CTRL_EXTENDED_XLAT) && capacity > 0x200000) {
 
9593         ip[2] = (unsigned long)capacity / (ip[0] * ip[1]);
 
9594         ASC_DBG(1, "end\n");
 
9599  * First-level interrupt handler.
 
9601  * 'dev_id' is a pointer to the interrupting adapter's Scsi_Host.
 
9603 static irqreturn_t advansys_interrupt(int irq, void *dev_id)
 
9605         struct Scsi_Host *shost = dev_id;
 
9606         struct asc_board *boardp = shost_priv(shost);
 
9607         irqreturn_t result = IRQ_NONE;
 
9609         ASC_DBG(2, "boardp 0x%p\n", boardp);
 
9610         spin_lock(shost->host_lock);
 
9611         if (ASC_NARROW_BOARD(boardp)) {
 
9612                 if (AscIsIntPending(shost->io_port)) {
 
9613                         result = IRQ_HANDLED;
 
9614                         ASC_STATS(shost, interrupt);
 
9615                         ASC_DBG(1, "before AscISR()\n");
 
9616                         AscISR(&boardp->dvc_var.asc_dvc_var);
 
9619                 ASC_DBG(1, "before AdvISR()\n");
 
9620                 if (AdvISR(&boardp->dvc_var.adv_dvc_var)) {
 
9621                         result = IRQ_HANDLED;
 
9622                         ASC_STATS(shost, interrupt);
 
9625         spin_unlock(shost->host_lock);
 
9627         ASC_DBG(1, "end\n");
 
9631 static int AscHostReqRiscHalt(PortAddr iop_base)
 
9635         uchar saved_stop_code;
 
9637         if (AscIsChipHalted(iop_base))
 
9639         saved_stop_code = AscReadLramByte(iop_base, ASCV_STOP_CODE_B);
 
9640         AscWriteLramByte(iop_base, ASCV_STOP_CODE_B,
 
9641                          ASC_STOP_HOST_REQ_RISC_HALT | ASC_STOP_REQ_RISC_STOP);
 
9643                 if (AscIsChipHalted(iop_base)) {
 
9648         } while (count++ < 20);
 
9649         AscWriteLramByte(iop_base, ASCV_STOP_CODE_B, saved_stop_code);
 
9654 AscSetRunChipSynRegAtID(PortAddr iop_base, uchar tid_no, uchar sdtr_data)
 
9658         if (AscHostReqRiscHalt(iop_base)) {
 
9659                 sta = AscSetChipSynRegAtID(iop_base, tid_no, sdtr_data);
 
9660                 AscStartChip(iop_base);
 
9665 static void AscAsyncFix(ASC_DVC_VAR *asc_dvc, struct scsi_device *sdev)
 
9667         char type = sdev->type;
 
9668         ASC_SCSI_BIT_ID_TYPE tid_bits = 1 << sdev->id;
 
9670         if (!(asc_dvc->bug_fix_cntl & ASC_BUG_FIX_ASYN_USE_SYN))
 
9672         if (asc_dvc->init_sdtr & tid_bits)
 
9675         if ((type == TYPE_ROM) && (strncmp(sdev->vendor, "HP ", 3) == 0))
 
9676                 asc_dvc->pci_fix_asyn_xfer_always |= tid_bits;
 
9678         asc_dvc->pci_fix_asyn_xfer |= tid_bits;
 
9679         if ((type == TYPE_PROCESSOR) || (type == TYPE_SCANNER) ||
 
9680             (type == TYPE_ROM) || (type == TYPE_TAPE))
 
9681                 asc_dvc->pci_fix_asyn_xfer &= ~tid_bits;
 
9683         if (asc_dvc->pci_fix_asyn_xfer & tid_bits)
 
9684                 AscSetRunChipSynRegAtID(asc_dvc->iop_base, sdev->id,
 
9685                                         ASYN_SDTR_DATA_FIX_PCI_REV_AB);
 
9689 advansys_narrow_slave_configure(struct scsi_device *sdev, ASC_DVC_VAR *asc_dvc)
 
9691         ASC_SCSI_BIT_ID_TYPE tid_bit = 1 << sdev->id;
 
9692         ASC_SCSI_BIT_ID_TYPE orig_use_tagged_qng = asc_dvc->use_tagged_qng;
 
9694         if (sdev->lun == 0) {
 
9695                 ASC_SCSI_BIT_ID_TYPE orig_init_sdtr = asc_dvc->init_sdtr;
 
9696                 if ((asc_dvc->cfg->sdtr_enable & tid_bit) && sdev->sdtr) {
 
9697                         asc_dvc->init_sdtr |= tid_bit;
 
9699                         asc_dvc->init_sdtr &= ~tid_bit;
 
9702                 if (orig_init_sdtr != asc_dvc->init_sdtr)
 
9703                         AscAsyncFix(asc_dvc, sdev);
 
9706         if (sdev->tagged_supported) {
 
9707                 if (asc_dvc->cfg->cmd_qng_enabled & tid_bit) {
 
9708                         if (sdev->lun == 0) {
 
9709                                 asc_dvc->cfg->can_tagged_qng |= tid_bit;
 
9710                                 asc_dvc->use_tagged_qng |= tid_bit;
 
9712                         scsi_adjust_queue_depth(sdev, MSG_ORDERED_TAG,
 
9713                                                 asc_dvc->max_dvc_qng[sdev->id]);
 
9716                 if (sdev->lun == 0) {
 
9717                         asc_dvc->cfg->can_tagged_qng &= ~tid_bit;
 
9718                         asc_dvc->use_tagged_qng &= ~tid_bit;
 
9720                 scsi_adjust_queue_depth(sdev, 0, sdev->host->cmd_per_lun);
 
9723         if ((sdev->lun == 0) &&
 
9724             (orig_use_tagged_qng != asc_dvc->use_tagged_qng)) {
 
9725                 AscWriteLramByte(asc_dvc->iop_base, ASCV_DISC_ENABLE_B,
 
9726                                  asc_dvc->cfg->disc_enable);
 
9727                 AscWriteLramByte(asc_dvc->iop_base, ASCV_USE_TAGGED_QNG_B,
 
9728                                  asc_dvc->use_tagged_qng);
 
9729                 AscWriteLramByte(asc_dvc->iop_base, ASCV_CAN_TAGGED_QNG_B,
 
9730                                  asc_dvc->cfg->can_tagged_qng);
 
9732                 asc_dvc->max_dvc_qng[sdev->id] =
 
9733                                         asc_dvc->cfg->max_tag_qng[sdev->id];
 
9734                 AscWriteLramByte(asc_dvc->iop_base,
 
9735                                  (ushort)(ASCV_MAX_DVC_QNG_BEG + sdev->id),
 
9736                                  asc_dvc->max_dvc_qng[sdev->id]);
 
9743  * If the EEPROM enabled WDTR for the device and the device supports wide
 
9744  * bus (16 bit) transfers, then turn on the device's 'wdtr_able' bit and
 
9745  * write the new value to the microcode.
 
9748 advansys_wide_enable_wdtr(AdvPortAddr iop_base, unsigned short tidmask)
 
9750         unsigned short cfg_word;
 
9751         AdvReadWordLram(iop_base, ASC_MC_WDTR_ABLE, cfg_word);
 
9752         if ((cfg_word & tidmask) != 0)
 
9755         cfg_word |= tidmask;
 
9756         AdvWriteWordLram(iop_base, ASC_MC_WDTR_ABLE, cfg_word);
 
9759          * Clear the microcode SDTR and WDTR negotiation done indicators for
 
9760          * the target to cause it to negotiate with the new setting set above.
 
9761          * WDTR when accepted causes the target to enter asynchronous mode, so
 
9762          * SDTR must be negotiated.
 
9764         AdvReadWordLram(iop_base, ASC_MC_SDTR_DONE, cfg_word);
 
9765         cfg_word &= ~tidmask;
 
9766         AdvWriteWordLram(iop_base, ASC_MC_SDTR_DONE, cfg_word);
 
9767         AdvReadWordLram(iop_base, ASC_MC_WDTR_DONE, cfg_word);
 
9768         cfg_word &= ~tidmask;
 
9769         AdvWriteWordLram(iop_base, ASC_MC_WDTR_DONE, cfg_word);
 
9773  * Synchronous Transfers
 
9775  * If the EEPROM enabled SDTR for the device and the device
 
9776  * supports synchronous transfers, then turn on the device's
 
9777  * 'sdtr_able' bit. Write the new value to the microcode.
 
9780 advansys_wide_enable_sdtr(AdvPortAddr iop_base, unsigned short tidmask)
 
9782         unsigned short cfg_word;
 
9783         AdvReadWordLram(iop_base, ASC_MC_SDTR_ABLE, cfg_word);
 
9784         if ((cfg_word & tidmask) != 0)
 
9787         cfg_word |= tidmask;
 
9788         AdvWriteWordLram(iop_base, ASC_MC_SDTR_ABLE, cfg_word);
 
9791          * Clear the microcode "SDTR negotiation" done indicator for the
 
9792          * target to cause it to negotiate with the new setting set above.
 
9794         AdvReadWordLram(iop_base, ASC_MC_SDTR_DONE, cfg_word);
 
9795         cfg_word &= ~tidmask;
 
9796         AdvWriteWordLram(iop_base, ASC_MC_SDTR_DONE, cfg_word);
 
9800  * PPR (Parallel Protocol Request) Capable
 
9802  * If the device supports DT mode, then it must be PPR capable.
 
9803  * The PPR message will be used in place of the SDTR and WDTR
 
9804  * messages to negotiate synchronous speed and offset, transfer
 
9805  * width, and protocol options.
 
9807 static void advansys_wide_enable_ppr(ADV_DVC_VAR *adv_dvc,
 
9808                                 AdvPortAddr iop_base, unsigned short tidmask)
 
9810         AdvReadWordLram(iop_base, ASC_MC_PPR_ABLE, adv_dvc->ppr_able);
 
9811         adv_dvc->ppr_able |= tidmask;
 
9812         AdvWriteWordLram(iop_base, ASC_MC_PPR_ABLE, adv_dvc->ppr_able);
 
9816 advansys_wide_slave_configure(struct scsi_device *sdev, ADV_DVC_VAR *adv_dvc)
 
9818         AdvPortAddr iop_base = adv_dvc->iop_base;
 
9819         unsigned short tidmask = 1 << sdev->id;
 
9821         if (sdev->lun == 0) {
 
9823                  * Handle WDTR, SDTR, and Tag Queuing. If the feature
 
9824                  * is enabled in the EEPROM and the device supports the
 
9825                  * feature, then enable it in the microcode.
 
9828                 if ((adv_dvc->wdtr_able & tidmask) && sdev->wdtr)
 
9829                         advansys_wide_enable_wdtr(iop_base, tidmask);
 
9830                 if ((adv_dvc->sdtr_able & tidmask) && sdev->sdtr)
 
9831                         advansys_wide_enable_sdtr(iop_base, tidmask);
 
9832                 if (adv_dvc->chip_type == ADV_CHIP_ASC38C1600 && sdev->ppr)
 
9833                         advansys_wide_enable_ppr(adv_dvc, iop_base, tidmask);
 
9836                  * Tag Queuing is disabled for the BIOS which runs in polled
 
9837                  * mode and would see no benefit from Tag Queuing. Also by
 
9838                  * disabling Tag Queuing in the BIOS devices with Tag Queuing
 
9839                  * bugs will at least work with the BIOS.
 
9841                 if ((adv_dvc->tagqng_able & tidmask) &&
 
9842                     sdev->tagged_supported) {
 
9843                         unsigned short cfg_word;
 
9844                         AdvReadWordLram(iop_base, ASC_MC_TAGQNG_ABLE, cfg_word);
 
9845                         cfg_word |= tidmask;
 
9846                         AdvWriteWordLram(iop_base, ASC_MC_TAGQNG_ABLE,
 
9848                         AdvWriteByteLram(iop_base,
 
9849                                          ASC_MC_NUMBER_OF_MAX_CMD + sdev->id,
 
9850                                          adv_dvc->max_dvc_qng);
 
9854         if ((adv_dvc->tagqng_able & tidmask) && sdev->tagged_supported) {
 
9855                 scsi_adjust_queue_depth(sdev, MSG_ORDERED_TAG,
 
9856                                         adv_dvc->max_dvc_qng);
 
9858                 scsi_adjust_queue_depth(sdev, 0, sdev->host->cmd_per_lun);
 
9863  * Set the number of commands to queue per device for the
 
9864  * specified host adapter.
 
9866 static int advansys_slave_configure(struct scsi_device *sdev)
 
9868         struct asc_board *boardp = shost_priv(sdev->host);
 
9870         if (ASC_NARROW_BOARD(boardp))
 
9871                 advansys_narrow_slave_configure(sdev,
 
9872                                                 &boardp->dvc_var.asc_dvc_var);
 
9874                 advansys_wide_slave_configure(sdev,
 
9875                                                 &boardp->dvc_var.adv_dvc_var);
 
9880 static __le32 advansys_get_sense_buffer_dma(struct scsi_cmnd *scp)
 
9882         struct asc_board *board = shost_priv(scp->device->host);
 
9883         scp->SCp.dma_handle = dma_map_single(board->dev, scp->sense_buffer,
 
9884                                 sizeof(scp->sense_buffer), DMA_FROM_DEVICE);
 
9885         dma_cache_sync(board->dev, scp->sense_buffer,
 
9886                                 sizeof(scp->sense_buffer), DMA_FROM_DEVICE);
 
9887         return cpu_to_le32(scp->SCp.dma_handle);
 
9890 static int asc_build_req(struct asc_board *boardp, struct scsi_cmnd *scp,
 
9891                         struct asc_scsi_q *asc_scsi_q)
 
9893         struct asc_dvc_var *asc_dvc = &boardp->dvc_var.asc_dvc_var;
 
9896         memset(asc_scsi_q, 0, sizeof(*asc_scsi_q));
 
9899          * Point the ASC_SCSI_Q to the 'struct scsi_cmnd'.
 
9901         asc_scsi_q->q2.srb_ptr = advansys_ptr_to_srb(asc_dvc, scp);
 
9902         if (asc_scsi_q->q2.srb_ptr == BAD_SRB) {
 
9903                 scp->result = HOST_BYTE(DID_SOFT_ERROR);
 
9908          * Build the ASC_SCSI_Q request.
 
9910         asc_scsi_q->cdbptr = &scp->cmnd[0];
 
9911         asc_scsi_q->q2.cdb_len = scp->cmd_len;
 
9912         asc_scsi_q->q1.target_id = ASC_TID_TO_TARGET_ID(scp->device->id);
 
9913         asc_scsi_q->q1.target_lun = scp->device->lun;
 
9914         asc_scsi_q->q2.target_ix =
 
9915             ASC_TIDLUN_TO_IX(scp->device->id, scp->device->lun);
 
9916         asc_scsi_q->q1.sense_addr = advansys_get_sense_buffer_dma(scp);
 
9917         asc_scsi_q->q1.sense_len = sizeof(scp->sense_buffer);
 
9920          * If there are any outstanding requests for the current target,
 
9921          * then every 255th request send an ORDERED request. This heuristic
 
9922          * tries to retain the benefit of request sorting while preventing
 
9923          * request starvation. 255 is the max number of tags or pending commands
 
9924          * a device may have outstanding.
 
9926          * The request count is incremented below for every successfully
 
9930         if ((asc_dvc->cur_dvc_qng[scp->device->id] > 0) &&
 
9931             (boardp->reqcnt[scp->device->id] % 255) == 0) {
 
9932                 asc_scsi_q->q2.tag_code = MSG_ORDERED_TAG;
 
9934                 asc_scsi_q->q2.tag_code = MSG_SIMPLE_TAG;
 
9937         /* Build ASC_SCSI_Q */
 
9938         use_sg = scsi_dma_map(scp);
 
9941                 struct scatterlist *slp;
 
9942                 struct asc_sg_head *asc_sg_head;
 
9944                 if (use_sg > scp->device->host->sg_tablesize) {
 
9945                         scmd_printk(KERN_ERR, scp, "use_sg %d > "
 
9946                                 "sg_tablesize %d\n", use_sg,
 
9947                                 scp->device->host->sg_tablesize);
 
9948                         scsi_dma_unmap(scp);
 
9949                         scp->result = HOST_BYTE(DID_ERROR);
 
9953                 asc_sg_head = kzalloc(sizeof(asc_scsi_q->sg_head) +
 
9954                         use_sg * sizeof(struct asc_sg_list), GFP_ATOMIC);
 
9956                         scsi_dma_unmap(scp);
 
9957                         scp->result = HOST_BYTE(DID_SOFT_ERROR);
 
9961                 asc_scsi_q->q1.cntl |= QC_SG_HEAD;
 
9962                 asc_scsi_q->sg_head = asc_sg_head;
 
9963                 asc_scsi_q->q1.data_cnt = 0;
 
9964                 asc_scsi_q->q1.data_addr = 0;
 
9965                 /* This is a byte value, otherwise it would need to be swapped. */
 
9966                 asc_sg_head->entry_cnt = asc_scsi_q->q1.sg_queue_cnt = use_sg;
 
9967                 ASC_STATS_ADD(scp->device->host, xfer_elem,
 
9968                               asc_sg_head->entry_cnt);
 
9971                  * Convert scatter-gather list into ASC_SG_HEAD list.
 
9973                 scsi_for_each_sg(scp, slp, use_sg, sgcnt) {
 
9974                         asc_sg_head->sg_list[sgcnt].addr =
 
9975                             cpu_to_le32(sg_dma_address(slp));
 
9976                         asc_sg_head->sg_list[sgcnt].bytes =
 
9977                             cpu_to_le32(sg_dma_len(slp));
 
9978                         ASC_STATS_ADD(scp->device->host, xfer_sect,
 
9979                                       DIV_ROUND_UP(sg_dma_len(slp), 512));
 
9983         ASC_STATS(scp->device->host, xfer_cnt);
 
9985         ASC_DBG_PRT_ASC_SCSI_Q(2, asc_scsi_q);
 
9986         ASC_DBG_PRT_CDB(1, scp->cmnd, scp->cmd_len);
 
9992  * Build scatter-gather list for Adv Library (Wide Board).
 
9994  * Additional ADV_SG_BLOCK structures will need to be allocated
 
9995  * if the total number of scatter-gather elements exceeds
 
9996  * NO_OF_SG_PER_BLOCK (15). The ADV_SG_BLOCK structures are
 
9997  * assumed to be physically contiguous.
 
10000  *      ADV_SUCCESS(1) - SG List successfully created
 
10001  *      ADV_ERROR(-1) - SG List creation failed
 
10004 adv_get_sglist(struct asc_board *boardp, adv_req_t *reqp, struct scsi_cmnd *scp,
 
10007         adv_sgblk_t *sgblkp;
 
10008         ADV_SCSI_REQ_Q *scsiqp;
 
10009         struct scatterlist *slp;
 
10011         ADV_SG_BLOCK *sg_block, *prev_sg_block;
 
10012         ADV_PADDR sg_block_paddr;
 
10015         scsiqp = (ADV_SCSI_REQ_Q *)ADV_32BALIGN(&reqp->scsi_req_q);
 
10016         slp = scsi_sglist(scp);
 
10017         sg_elem_cnt = use_sg;
 
10018         prev_sg_block = NULL;
 
10019         reqp->sgblkp = NULL;
 
10023                  * Allocate a 'adv_sgblk_t' structure from the board free
 
10024                  * list. One 'adv_sgblk_t' structure holds NO_OF_SG_PER_BLOCK
 
10025                  * (15) scatter-gather elements.
 
10027                 if ((sgblkp = boardp->adv_sgblkp) == NULL) {
 
10028                         ASC_DBG(1, "no free adv_sgblk_t\n");
 
10029                         ASC_STATS(scp->device->host, adv_build_nosg);
 
10032                          * Allocation failed. Free 'adv_sgblk_t' structures
 
10033                          * already allocated for the request.
 
10035                         while ((sgblkp = reqp->sgblkp) != NULL) {
 
10036                                 /* Remove 'sgblkp' from the request list. */
 
10037                                 reqp->sgblkp = sgblkp->next_sgblkp;
 
10039                                 /* Add 'sgblkp' to the board free list. */
 
10040                                 sgblkp->next_sgblkp = boardp->adv_sgblkp;
 
10041                                 boardp->adv_sgblkp = sgblkp;
 
10046                 /* Complete 'adv_sgblk_t' board allocation. */
 
10047                 boardp->adv_sgblkp = sgblkp->next_sgblkp;
 
10048                 sgblkp->next_sgblkp = NULL;
 
10051                  * Get 8 byte aligned virtual and physical addresses
 
10052                  * for the allocated ADV_SG_BLOCK structure.
 
10054                 sg_block = (ADV_SG_BLOCK *)ADV_8BALIGN(&sgblkp->sg_block);
 
10055                 sg_block_paddr = virt_to_bus(sg_block);
 
10058                  * Check if this is the first 'adv_sgblk_t' for the
 
10061                 if (reqp->sgblkp == NULL) {
 
10062                         /* Request's first scatter-gather block. */
 
10063                         reqp->sgblkp = sgblkp;
 
10066                          * Set ADV_SCSI_REQ_T ADV_SG_BLOCK virtual and physical
 
10067                          * address pointers.
 
10069                         scsiqp->sg_list_ptr = sg_block;
 
10070                         scsiqp->sg_real_addr = cpu_to_le32(sg_block_paddr);
 
10072                         /* Request's second or later scatter-gather block. */
 
10073                         sgblkp->next_sgblkp = reqp->sgblkp;
 
10074                         reqp->sgblkp = sgblkp;
 
10077                          * Point the previous ADV_SG_BLOCK structure to
 
10078                          * the newly allocated ADV_SG_BLOCK structure.
 
10080                         prev_sg_block->sg_ptr = cpu_to_le32(sg_block_paddr);
 
10083                 for (i = 0; i < NO_OF_SG_PER_BLOCK; i++) {
 
10084                         sg_block->sg_list[i].sg_addr =
 
10085                                         cpu_to_le32(sg_dma_address(slp));
 
10086                         sg_block->sg_list[i].sg_count =
 
10087                                         cpu_to_le32(sg_dma_len(slp));
 
10088                         ASC_STATS_ADD(scp->device->host, xfer_sect,
 
10089                                       DIV_ROUND_UP(sg_dma_len(slp), 512));
 
10091                         if (--sg_elem_cnt == 0) {       /* Last ADV_SG_BLOCK and scatter-gather entry. */
 
10092                                 sg_block->sg_cnt = i + 1;
 
10093                                 sg_block->sg_ptr = 0L;  /* Last ADV_SG_BLOCK in list. */
 
10094                                 return ADV_SUCCESS;
 
10098                 sg_block->sg_cnt = NO_OF_SG_PER_BLOCK;
 
10099                 prev_sg_block = sg_block;
 
10104  * Build a request structure for the Adv Library (Wide Board).
 
10106  * If an adv_req_t can not be allocated to issue the request,
 
10107  * then return ASC_BUSY. If an error occurs, then return ASC_ERROR.
 
10109  * Multi-byte fields in the ASC_SCSI_REQ_Q that are used by the
 
10110  * microcode for DMA addresses or math operations are byte swapped
 
10111  * to little-endian order.
 
10114 adv_build_req(struct asc_board *boardp, struct scsi_cmnd *scp,
 
10115               ADV_SCSI_REQ_Q **adv_scsiqpp)
 
10118         ADV_SCSI_REQ_Q *scsiqp;
 
10124          * Allocate an adv_req_t structure from the board to execute
 
10127         if (boardp->adv_reqp == NULL) {
 
10128                 ASC_DBG(1, "no free adv_req_t\n");
 
10129                 ASC_STATS(scp->device->host, adv_build_noreq);
 
10132                 reqp = boardp->adv_reqp;
 
10133                 boardp->adv_reqp = reqp->next_reqp;
 
10134                 reqp->next_reqp = NULL;
 
10138          * Get 32-byte aligned ADV_SCSI_REQ_Q and ADV_SG_BLOCK pointers.
 
10140         scsiqp = (ADV_SCSI_REQ_Q *)ADV_32BALIGN(&reqp->scsi_req_q);
 
10143          * Initialize the structure.
 
10145         scsiqp->cntl = scsiqp->scsi_cntl = scsiqp->done_status = 0;
 
10148          * Set the ADV_SCSI_REQ_Q 'srb_ptr' to point to the adv_req_t structure.
 
10150         scsiqp->srb_ptr = ADV_VADDR_TO_U32(reqp);
 
10153          * Set the adv_req_t 'cmndp' to point to the struct scsi_cmnd structure.
 
10158          * Build the ADV_SCSI_REQ_Q request.
 
10161         /* Set CDB length and copy it to the request structure.  */
 
10162         scsiqp->cdb_len = scp->cmd_len;
 
10163         /* Copy first 12 CDB bytes to cdb[]. */
 
10164         for (i = 0; i < scp->cmd_len && i < 12; i++) {
 
10165                 scsiqp->cdb[i] = scp->cmnd[i];
 
10167         /* Copy last 4 CDB bytes, if present, to cdb16[]. */
 
10168         for (; i < scp->cmd_len; i++) {
 
10169                 scsiqp->cdb16[i - 12] = scp->cmnd[i];
 
10172         scsiqp->target_id = scp->device->id;
 
10173         scsiqp->target_lun = scp->device->lun;
 
10175         scsiqp->sense_addr = cpu_to_le32(virt_to_bus(&scp->sense_buffer[0]));
 
10176         scsiqp->sense_len = sizeof(scp->sense_buffer);
 
10178         /* Build ADV_SCSI_REQ_Q */
 
10180         use_sg = scsi_dma_map(scp);
 
10182                 /* Zero-length transfer */
 
10183                 reqp->sgblkp = NULL;
 
10184                 scsiqp->data_cnt = 0;
 
10185                 scsiqp->vdata_addr = NULL;
 
10187                 scsiqp->data_addr = 0;
 
10188                 scsiqp->sg_list_ptr = NULL;
 
10189                 scsiqp->sg_real_addr = 0;
 
10191                 if (use_sg > ADV_MAX_SG_LIST) {
 
10192                         scmd_printk(KERN_ERR, scp, "use_sg %d > "
 
10193                                    "ADV_MAX_SG_LIST %d\n", use_sg,
 
10194                                    scp->device->host->sg_tablesize);
 
10195                         scsi_dma_unmap(scp);
 
10196                         scp->result = HOST_BYTE(DID_ERROR);
 
10199                          * Free the 'adv_req_t' structure by adding it back
 
10200                          * to the board free list.
 
10202                         reqp->next_reqp = boardp->adv_reqp;
 
10203                         boardp->adv_reqp = reqp;
 
10208                 scsiqp->data_cnt = cpu_to_le32(scsi_bufflen(scp));
 
10210                 ret = adv_get_sglist(boardp, reqp, scp, use_sg);
 
10211                 if (ret != ADV_SUCCESS) {
 
10213                          * Free the adv_req_t structure by adding it back to
 
10214                          * the board free list.
 
10216                         reqp->next_reqp = boardp->adv_reqp;
 
10217                         boardp->adv_reqp = reqp;
 
10222                 ASC_STATS_ADD(scp->device->host, xfer_elem, use_sg);
 
10225         ASC_STATS(scp->device->host, xfer_cnt);
 
10227         ASC_DBG_PRT_ADV_SCSI_REQ_Q(2, scsiqp);
 
10228         ASC_DBG_PRT_CDB(1, scp->cmnd, scp->cmd_len);
 
10230         *adv_scsiqpp = scsiqp;
 
10232         return ASC_NOERROR;
 
10235 static int AscSgListToQueue(int sg_list)
 
10239         n_sg_list_qs = ((sg_list - 1) / ASC_SG_LIST_PER_Q);
 
10240         if (((sg_list - 1) % ASC_SG_LIST_PER_Q) != 0)
 
10242         return n_sg_list_qs + 1;
 
10246 AscGetNumOfFreeQueue(ASC_DVC_VAR *asc_dvc, uchar target_ix, uchar n_qs)
 
10250         ASC_SCSI_BIT_ID_TYPE target_id;
 
10253         target_id = ASC_TIX_TO_TARGET_ID(target_ix);
 
10254         tid_no = ASC_TIX_TO_TID(target_ix);
 
10255         if ((asc_dvc->unit_not_ready & target_id) ||
 
10256             (asc_dvc->queue_full_or_busy & target_id)) {
 
10260                 cur_used_qs = (uint) asc_dvc->cur_total_qng +
 
10261                     (uint) asc_dvc->last_q_shortage + (uint) ASC_MIN_FREE_Q;
 
10263                 cur_used_qs = (uint) asc_dvc->cur_total_qng +
 
10264                     (uint) ASC_MIN_FREE_Q;
 
10266         if ((uint) (cur_used_qs + n_qs) <= (uint) asc_dvc->max_total_qng) {
 
10267                 cur_free_qs = (uint) asc_dvc->max_total_qng - cur_used_qs;
 
10268                 if (asc_dvc->cur_dvc_qng[tid_no] >=
 
10269                     asc_dvc->max_dvc_qng[tid_no]) {
 
10272                 return cur_free_qs;
 
10275                 if ((n_qs > asc_dvc->last_q_shortage)
 
10276                     && (n_qs <= (asc_dvc->max_total_qng - ASC_MIN_FREE_Q))) {
 
10277                         asc_dvc->last_q_shortage = n_qs;
 
10283 static uchar AscAllocFreeQueue(PortAddr iop_base, uchar free_q_head)
 
10289         q_addr = ASC_QNO_TO_QADDR(free_q_head);
 
10290         q_status = (uchar)AscReadLramByte(iop_base,
 
10292                                                    ASC_SCSIQ_B_STATUS));
 
10293         next_qp = AscReadLramByte(iop_base, (ushort)(q_addr + ASC_SCSIQ_B_FWD));
 
10294         if (((q_status & QS_READY) == 0) && (next_qp != ASC_QLINK_END))
 
10296         return ASC_QLINK_END;
 
10300 AscAllocMultipleFreeQueue(PortAddr iop_base, uchar free_q_head, uchar n_free_q)
 
10304         for (i = 0; i < n_free_q; i++) {
 
10305                 free_q_head = AscAllocFreeQueue(iop_base, free_q_head);
 
10306                 if (free_q_head == ASC_QLINK_END)
 
10309         return free_q_head;
 
10314  * DvcPutScsiQ(PortAddr iop_base, ushort s_addr, uchar *outbuf, int words)
 
10316  * Calling/Exit State:
 
10320  *     Output an ASC_SCSI_Q structure to the chip
 
10323 DvcPutScsiQ(PortAddr iop_base, ushort s_addr, uchar *outbuf, int words)
 
10327         ASC_DBG_PRT_HEX(2, "DvcPutScsiQ", outbuf, 2 * words);
 
10328         AscSetChipLramAddr(iop_base, s_addr);
 
10329         for (i = 0; i < 2 * words; i += 2) {
 
10330                 if (i == 4 || i == 20) {
 
10333                 outpw(iop_base + IOP_RAM_DATA,
 
10334                       ((ushort)outbuf[i + 1] << 8) | outbuf[i]);
 
10338 static int AscPutReadyQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar q_no)
 
10343         uchar syn_period_ix;
 
10347         iop_base = asc_dvc->iop_base;
 
10348         if (((asc_dvc->init_sdtr & scsiq->q1.target_id) != 0) &&
 
10349             ((asc_dvc->sdtr_done & scsiq->q1.target_id) == 0)) {
 
10350                 tid_no = ASC_TIX_TO_TID(scsiq->q2.target_ix);
 
10351                 sdtr_data = AscGetMCodeInitSDTRAtID(iop_base, tid_no);
 
10353                     (sdtr_data >> 4) & (asc_dvc->max_sdtr_index - 1);
 
10354                 syn_offset = sdtr_data & ASC_SYN_MAX_OFFSET;
 
10355                 AscMsgOutSDTR(asc_dvc,
 
10356                               asc_dvc->sdtr_period_tbl[syn_period_ix],
 
10358                 scsiq->q1.cntl |= QC_MSG_OUT;
 
10360         q_addr = ASC_QNO_TO_QADDR(q_no);
 
10361         if ((scsiq->q1.target_id & asc_dvc->use_tagged_qng) == 0) {
 
10362                 scsiq->q2.tag_code &= ~MSG_SIMPLE_TAG;
 
10364         scsiq->q1.status = QS_FREE;
 
10365         AscMemWordCopyPtrToLram(iop_base,
 
10366                                 q_addr + ASC_SCSIQ_CDB_BEG,
 
10367                                 (uchar *)scsiq->cdbptr, scsiq->q2.cdb_len >> 1);
 
10369         DvcPutScsiQ(iop_base,
 
10370                     q_addr + ASC_SCSIQ_CPY_BEG,
 
10371                     (uchar *)&scsiq->q1.cntl,
 
10372                     ((sizeof(ASC_SCSIQ_1) + sizeof(ASC_SCSIQ_2)) / 2) - 1);
 
10373         AscWriteLramWord(iop_base,
 
10374                          (ushort)(q_addr + (ushort)ASC_SCSIQ_B_STATUS),
 
10375                          (ushort)(((ushort)scsiq->q1.
 
10376                                    q_no << 8) | (ushort)QS_READY));
 
10381 AscPutReadySgListQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar q_no)
 
10385         ASC_SG_HEAD *sg_head;
 
10386         ASC_SG_LIST_Q scsi_sg_q;
 
10387         ASC_DCNT saved_data_addr;
 
10388         ASC_DCNT saved_data_cnt;
 
10390         ushort sg_list_dwords;
 
10392         ushort sg_entry_cnt;
 
10396         iop_base = asc_dvc->iop_base;
 
10397         sg_head = scsiq->sg_head;
 
10398         saved_data_addr = scsiq->q1.data_addr;
 
10399         saved_data_cnt = scsiq->q1.data_cnt;
 
10400         scsiq->q1.data_addr = (ASC_PADDR) sg_head->sg_list[0].addr;
 
10401         scsiq->q1.data_cnt = (ASC_DCNT) sg_head->sg_list[0].bytes;
 
10402 #if CC_VERY_LONG_SG_LIST
 
10404          * If sg_head->entry_cnt is greater than ASC_MAX_SG_LIST
 
10405          * then not all SG elements will fit in the allocated queues.
 
10406          * The rest of the SG elements will be copied when the RISC
 
10407          * completes the SG elements that fit and halts.
 
10409         if (sg_head->entry_cnt > ASC_MAX_SG_LIST) {
 
10411                  * Set sg_entry_cnt to be the number of SG elements that
 
10412                  * will fit in the allocated SG queues. It is minus 1, because
 
10413                  * the first SG element is handled above. ASC_MAX_SG_LIST is
 
10414                  * already inflated by 1 to account for this. For example it
 
10415                  * may be 50 which is 1 + 7 queues * 7 SG elements.
 
10417                 sg_entry_cnt = ASC_MAX_SG_LIST - 1;
 
10420                  * Keep track of remaining number of SG elements that will
 
10421                  * need to be handled from a_isr.c.
 
10423                 scsiq->remain_sg_entry_cnt =
 
10424                     sg_head->entry_cnt - ASC_MAX_SG_LIST;
 
10426 #endif /* CC_VERY_LONG_SG_LIST */
 
10428                  * Set sg_entry_cnt to be the number of SG elements that
 
10429                  * will fit in the allocated SG queues. It is minus 1, because
 
10430                  * the first SG element is handled above.
 
10432                 sg_entry_cnt = sg_head->entry_cnt - 1;
 
10433 #if CC_VERY_LONG_SG_LIST
 
10435 #endif /* CC_VERY_LONG_SG_LIST */
 
10436         if (sg_entry_cnt != 0) {
 
10437                 scsiq->q1.cntl |= QC_SG_HEAD;
 
10438                 q_addr = ASC_QNO_TO_QADDR(q_no);
 
10440                 scsiq->q1.sg_queue_cnt = sg_head->queue_cnt;
 
10441                 scsi_sg_q.sg_head_qp = q_no;
 
10442                 scsi_sg_q.cntl = QCSG_SG_XFER_LIST;
 
10443                 for (i = 0; i < sg_head->queue_cnt; i++) {
 
10444                         scsi_sg_q.seq_no = i + 1;
 
10445                         if (sg_entry_cnt > ASC_SG_LIST_PER_Q) {
 
10446                                 sg_list_dwords = (uchar)(ASC_SG_LIST_PER_Q * 2);
 
10447                                 sg_entry_cnt -= ASC_SG_LIST_PER_Q;
 
10449                                         scsi_sg_q.sg_list_cnt =
 
10451                                         scsi_sg_q.sg_cur_list_cnt =
 
10454                                         scsi_sg_q.sg_list_cnt =
 
10455                                             ASC_SG_LIST_PER_Q - 1;
 
10456                                         scsi_sg_q.sg_cur_list_cnt =
 
10457                                             ASC_SG_LIST_PER_Q - 1;
 
10460 #if CC_VERY_LONG_SG_LIST
 
10462                                  * This is the last SG queue in the list of
 
10463                                  * allocated SG queues. If there are more
 
10464                                  * SG elements than will fit in the allocated
 
10465                                  * queues, then set the QCSG_SG_XFER_MORE flag.
 
10467                                 if (sg_head->entry_cnt > ASC_MAX_SG_LIST) {
 
10468                                         scsi_sg_q.cntl |= QCSG_SG_XFER_MORE;
 
10470 #endif /* CC_VERY_LONG_SG_LIST */
 
10471                                         scsi_sg_q.cntl |= QCSG_SG_XFER_END;
 
10472 #if CC_VERY_LONG_SG_LIST
 
10474 #endif /* CC_VERY_LONG_SG_LIST */
 
10475                                 sg_list_dwords = sg_entry_cnt << 1;
 
10477                                         scsi_sg_q.sg_list_cnt = sg_entry_cnt;
 
10478                                         scsi_sg_q.sg_cur_list_cnt =
 
10481                                         scsi_sg_q.sg_list_cnt =
 
10483                                         scsi_sg_q.sg_cur_list_cnt =
 
10488                         next_qp = AscReadLramByte(iop_base,
 
10491                         scsi_sg_q.q_no = next_qp;
 
10492                         q_addr = ASC_QNO_TO_QADDR(next_qp);
 
10493                         AscMemWordCopyPtrToLram(iop_base,
 
10494                                                 q_addr + ASC_SCSIQ_SGHD_CPY_BEG,
 
10495                                                 (uchar *)&scsi_sg_q,
 
10496                                                 sizeof(ASC_SG_LIST_Q) >> 1);
 
10497                         AscMemDWordCopyPtrToLram(iop_base,
 
10498                                                  q_addr + ASC_SGQ_LIST_BEG,
 
10499                                                  (uchar *)&sg_head->
 
10502                         sg_index += ASC_SG_LIST_PER_Q;
 
10503                         scsiq->next_sg_index = sg_index;
 
10506                 scsiq->q1.cntl &= ~QC_SG_HEAD;
 
10508         sta = AscPutReadyQueue(asc_dvc, scsiq, q_no);
 
10509         scsiq->q1.data_addr = saved_data_addr;
 
10510         scsiq->q1.data_cnt = saved_data_cnt;
 
10515 AscSendScsiQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq, uchar n_q_required)
 
10524         iop_base = asc_dvc->iop_base;
 
10525         target_ix = scsiq->q2.target_ix;
 
10526         tid_no = ASC_TIX_TO_TID(target_ix);
 
10528         free_q_head = (uchar)AscGetVarFreeQHead(iop_base);
 
10529         if (n_q_required > 1) {
 
10530                 next_qp = AscAllocMultipleFreeQueue(iop_base, free_q_head,
 
10531                                                     (uchar)n_q_required);
 
10532                 if (next_qp != ASC_QLINK_END) {
 
10533                         asc_dvc->last_q_shortage = 0;
 
10534                         scsiq->sg_head->queue_cnt = n_q_required - 1;
 
10535                         scsiq->q1.q_no = free_q_head;
 
10536                         sta = AscPutReadySgListQueue(asc_dvc, scsiq,
 
10539         } else if (n_q_required == 1) {
 
10540                 next_qp = AscAllocFreeQueue(iop_base, free_q_head);
 
10541                 if (next_qp != ASC_QLINK_END) {
 
10542                         scsiq->q1.q_no = free_q_head;
 
10543                         sta = AscPutReadyQueue(asc_dvc, scsiq, free_q_head);
 
10547                 AscPutVarFreeQHead(iop_base, next_qp);
 
10548                 asc_dvc->cur_total_qng += n_q_required;
 
10549                 asc_dvc->cur_dvc_qng[tid_no]++;
 
10554 #define ASC_SYN_OFFSET_ONE_DISABLE_LIST  16
 
10555 static uchar _syn_offset_one_disable_cmd[ASC_SYN_OFFSET_ONE_DISABLE_LIST] = {
 
10574 static int AscExeScsiQueue(ASC_DVC_VAR *asc_dvc, ASC_SCSI_Q *scsiq)
 
10579         int disable_syn_offset_one_fix;
 
10582         ushort sg_entry_cnt = 0;
 
10583         ushort sg_entry_cnt_minus_one = 0;
 
10590         ASC_SG_HEAD *sg_head;
 
10593         iop_base = asc_dvc->iop_base;
 
10594         sg_head = scsiq->sg_head;
 
10595         if (asc_dvc->err_code != 0)
 
10597         scsiq->q1.q_no = 0;
 
10598         if ((scsiq->q2.tag_code & ASC_TAG_FLAG_EXTRA_BYTES) == 0) {
 
10599                 scsiq->q1.extra_bytes = 0;
 
10602         target_ix = scsiq->q2.target_ix;
 
10603         tid_no = ASC_TIX_TO_TID(target_ix);
 
10605         if (scsiq->cdbptr[0] == REQUEST_SENSE) {
 
10606                 if ((asc_dvc->init_sdtr & scsiq->q1.target_id) != 0) {
 
10607                         asc_dvc->sdtr_done &= ~scsiq->q1.target_id;
 
10608                         sdtr_data = AscGetMCodeInitSDTRAtID(iop_base, tid_no);
 
10609                         AscMsgOutSDTR(asc_dvc,
 
10611                                       sdtr_period_tbl[(sdtr_data >> 4) &
 
10615                                       (uchar)(sdtr_data & (uchar)
 
10616                                               ASC_SYN_MAX_OFFSET));
 
10617                         scsiq->q1.cntl |= (QC_MSG_OUT | QC_URGENT);
 
10620         if (asc_dvc->in_critical_cnt != 0) {
 
10621                 AscSetLibErrorCode(asc_dvc, ASCQ_ERR_CRITICAL_RE_ENTRY);
 
10624         asc_dvc->in_critical_cnt++;
 
10625         if ((scsiq->q1.cntl & QC_SG_HEAD) != 0) {
 
10626                 if ((sg_entry_cnt = sg_head->entry_cnt) == 0) {
 
10627                         asc_dvc->in_critical_cnt--;
 
10630 #if !CC_VERY_LONG_SG_LIST
 
10631                 if (sg_entry_cnt > ASC_MAX_SG_LIST) {
 
10632                         asc_dvc->in_critical_cnt--;
 
10635 #endif /* !CC_VERY_LONG_SG_LIST */
 
10636                 if (sg_entry_cnt == 1) {
 
10637                         scsiq->q1.data_addr =
 
10638                             (ADV_PADDR)sg_head->sg_list[0].addr;
 
10639                         scsiq->q1.data_cnt =
 
10640                             (ADV_DCNT)sg_head->sg_list[0].bytes;
 
10641                         scsiq->q1.cntl &= ~(QC_SG_HEAD | QC_SG_SWAP_QUEUE);
 
10643                 sg_entry_cnt_minus_one = sg_entry_cnt - 1;
 
10645         scsi_cmd = scsiq->cdbptr[0];
 
10646         disable_syn_offset_one_fix = FALSE;
 
10647         if ((asc_dvc->pci_fix_asyn_xfer & scsiq->q1.target_id) &&
 
10648             !(asc_dvc->pci_fix_asyn_xfer_always & scsiq->q1.target_id)) {
 
10649                 if (scsiq->q1.cntl & QC_SG_HEAD) {
 
10651                         for (i = 0; i < sg_entry_cnt; i++) {
 
10653                                     (ADV_DCNT)le32_to_cpu(sg_head->sg_list[i].
 
10657                         data_cnt = le32_to_cpu(scsiq->q1.data_cnt);
 
10659                 if (data_cnt != 0UL) {
 
10660                         if (data_cnt < 512UL) {
 
10661                                 disable_syn_offset_one_fix = TRUE;
 
10663                                 for (i = 0; i < ASC_SYN_OFFSET_ONE_DISABLE_LIST;
 
10666                                             _syn_offset_one_disable_cmd[i];
 
10667                                         if (disable_cmd == 0xFF) {
 
10670                                         if (scsi_cmd == disable_cmd) {
 
10671                                                 disable_syn_offset_one_fix =
 
10679         if (disable_syn_offset_one_fix) {
 
10680                 scsiq->q2.tag_code &= ~MSG_SIMPLE_TAG;
 
10681                 scsiq->q2.tag_code |= (ASC_TAG_FLAG_DISABLE_ASYN_USE_SYN_FIX |
 
10682                                        ASC_TAG_FLAG_DISABLE_DISCONNECT);
 
10684                 scsiq->q2.tag_code &= 0x27;
 
10686         if ((scsiq->q1.cntl & QC_SG_HEAD) != 0) {
 
10687                 if (asc_dvc->bug_fix_cntl) {
 
10688                         if (asc_dvc->bug_fix_cntl & ASC_BUG_FIX_IF_NOT_DWB) {
 
10689                                 if ((scsi_cmd == READ_6) ||
 
10690                                     (scsi_cmd == READ_10)) {
 
10692                                             (ADV_PADDR)le32_to_cpu(sg_head->
 
10694                                                                    [sg_entry_cnt_minus_one].
 
10696                                             (ADV_DCNT)le32_to_cpu(sg_head->
 
10698                                                                   [sg_entry_cnt_minus_one].
 
10701                                             (uchar)((ushort)addr & 0x0003);
 
10702                                         if ((extra_bytes != 0)
 
10706                                               ASC_TAG_FLAG_EXTRA_BYTES)
 
10708                                                 scsiq->q2.tag_code |=
 
10709                                                     ASC_TAG_FLAG_EXTRA_BYTES;
 
10710                                                 scsiq->q1.extra_bytes =
 
10713                                                     le32_to_cpu(sg_head->
 
10715                                                                 [sg_entry_cnt_minus_one].
 
10718                                                     (ASC_DCNT) extra_bytes;
 
10721                                                     [sg_entry_cnt_minus_one].
 
10723                                                     cpu_to_le32(data_cnt);
 
10728                 sg_head->entry_to_copy = sg_head->entry_cnt;
 
10729 #if CC_VERY_LONG_SG_LIST
 
10731                  * Set the sg_entry_cnt to the maximum possible. The rest of
 
10732                  * the SG elements will be copied when the RISC completes the
 
10733                  * SG elements that fit and halts.
 
10735                 if (sg_entry_cnt > ASC_MAX_SG_LIST) {
 
10736                         sg_entry_cnt = ASC_MAX_SG_LIST;
 
10738 #endif /* CC_VERY_LONG_SG_LIST */
 
10739                 n_q_required = AscSgListToQueue(sg_entry_cnt);
 
10740                 if ((AscGetNumOfFreeQueue(asc_dvc, target_ix, n_q_required) >=
 
10741                      (uint) n_q_required)
 
10742                     || ((scsiq->q1.cntl & QC_URGENT) != 0)) {
 
10744                              AscSendScsiQueue(asc_dvc, scsiq,
 
10745                                               n_q_required)) == 1) {
 
10746                                 asc_dvc->in_critical_cnt--;
 
10751                 if (asc_dvc->bug_fix_cntl) {
 
10752                         if (asc_dvc->bug_fix_cntl & ASC_BUG_FIX_IF_NOT_DWB) {
 
10753                                 if ((scsi_cmd == READ_6) ||
 
10754                                     (scsi_cmd == READ_10)) {
 
10756                                             le32_to_cpu(scsiq->q1.data_addr) +
 
10757                                             le32_to_cpu(scsiq->q1.data_cnt);
 
10759                                             (uchar)((ushort)addr & 0x0003);
 
10760                                         if ((extra_bytes != 0)
 
10764                                               ASC_TAG_FLAG_EXTRA_BYTES)
 
10767                                                     le32_to_cpu(scsiq->q1.
 
10769                                                 if (((ushort)data_cnt & 0x01FF)
 
10771                                                         scsiq->q2.tag_code |=
 
10772                                                             ASC_TAG_FLAG_EXTRA_BYTES;
 
10773                                                         data_cnt -= (ASC_DCNT)
 
10775                                                         scsiq->q1.data_cnt =
 
10778                                                         scsiq->q1.extra_bytes =
 
10786                 if ((AscGetNumOfFreeQueue(asc_dvc, target_ix, 1) >= 1) ||
 
10787                     ((scsiq->q1.cntl & QC_URGENT) != 0)) {
 
10788                         if ((sta = AscSendScsiQueue(asc_dvc, scsiq,
 
10789                                                     n_q_required)) == 1) {
 
10790                                 asc_dvc->in_critical_cnt--;
 
10795         asc_dvc->in_critical_cnt--;
 
10800  * AdvExeScsiQueue() - Send a request to the RISC microcode program.
 
10802  *   Allocate a carrier structure, point the carrier to the ADV_SCSI_REQ_Q,
 
10803  *   add the carrier to the ICQ (Initiator Command Queue), and tickle the
 
10804  *   RISC to notify it a new command is ready to be executed.
 
10806  * If 'done_status' is not set to QD_DO_RETRY, then 'error_retry' will be
 
10807  * set to SCSI_MAX_RETRY.
 
10809  * Multi-byte fields in the ASC_SCSI_REQ_Q that are used by the microcode
 
10810  * for DMA addresses or math operations are byte swapped to little-endian
 
10814  *      ADV_SUCCESS(1) - The request was successfully queued.
 
10815  *      ADV_BUSY(0) -    Resource unavailable; Retry again after pending
 
10816  *                       request completes.
 
10817  *      ADV_ERROR(-1) -  Invalid ADV_SCSI_REQ_Q request structure
 
10820 static int AdvExeScsiQueue(ADV_DVC_VAR *asc_dvc, ADV_SCSI_REQ_Q *scsiq)
 
10822         AdvPortAddr iop_base;
 
10823         ADV_PADDR req_paddr;
 
10824         ADV_CARR_T *new_carrp;
 
10827          * The ADV_SCSI_REQ_Q 'target_id' field should never exceed ADV_MAX_TID.
 
10829         if (scsiq->target_id > ADV_MAX_TID) {
 
10830                 scsiq->host_status = QHSTA_M_INVALID_DEVICE;
 
10831                 scsiq->done_status = QD_WITH_ERROR;
 
10835         iop_base = asc_dvc->iop_base;
 
10838          * Allocate a carrier ensuring at least one carrier always
 
10839          * remains on the freelist and initialize fields.
 
10841         if ((new_carrp = asc_dvc->carr_freelist) == NULL) {
 
10844         asc_dvc->carr_freelist = (ADV_CARR_T *)
 
10845             ADV_U32_TO_VADDR(le32_to_cpu(new_carrp->next_vpa));
 
10846         asc_dvc->carr_pending_cnt++;
 
10849          * Set the carrier to be a stopper by setting 'next_vpa'
 
10850          * to the stopper value. The current stopper will be changed
 
10851          * below to point to the new stopper.
 
10853         new_carrp->next_vpa = cpu_to_le32(ASC_CQ_STOPPER);
 
10856          * Clear the ADV_SCSI_REQ_Q done flag.
 
10858         scsiq->a_flag &= ~ADV_SCSIQ_DONE;
 
10860         req_paddr = virt_to_bus(scsiq);
 
10861         BUG_ON(req_paddr & 31);
 
10862         /* Wait for assertion before making little-endian */
 
10863         req_paddr = cpu_to_le32(req_paddr);
 
10865         /* Save virtual and physical address of ADV_SCSI_REQ_Q and carrier. */
 
10866         scsiq->scsiq_ptr = cpu_to_le32(ADV_VADDR_TO_U32(scsiq));
 
10867         scsiq->scsiq_rptr = req_paddr;
 
10869         scsiq->carr_va = cpu_to_le32(ADV_VADDR_TO_U32(asc_dvc->icq_sp));
 
10871          * Every ADV_CARR_T.carr_pa is byte swapped to little-endian
 
10872          * order during initialization.
 
10874         scsiq->carr_pa = asc_dvc->icq_sp->carr_pa;
 
10877          * Use the current stopper to send the ADV_SCSI_REQ_Q command to
 
10878          * the microcode. The newly allocated stopper will become the new
 
10881         asc_dvc->icq_sp->areq_vpa = req_paddr;
 
10884          * Set the 'next_vpa' pointer for the old stopper to be the
 
10885          * physical address of the new stopper. The RISC can only
 
10886          * follow physical addresses.
 
10888         asc_dvc->icq_sp->next_vpa = new_carrp->carr_pa;
 
10891          * Set the host adapter stopper pointer to point to the new carrier.
 
10893         asc_dvc->icq_sp = new_carrp;
 
10895         if (asc_dvc->chip_type == ADV_CHIP_ASC3550 ||
 
10896             asc_dvc->chip_type == ADV_CHIP_ASC38C0800) {
 
10898                  * Tickle the RISC to tell it to read its Command Queue Head pointer.
 
10900                 AdvWriteByteRegister(iop_base, IOPB_TICKLE, ADV_TICKLE_A);
 
10901                 if (asc_dvc->chip_type == ADV_CHIP_ASC3550) {
 
10903                          * Clear the tickle value. In the ASC-3550 the RISC flag
 
10904                          * command 'clr_tickle_a' does not work unless the host
 
10905                          * value is cleared.
 
10907                         AdvWriteByteRegister(iop_base, IOPB_TICKLE,
 
10910         } else if (asc_dvc->chip_type == ADV_CHIP_ASC38C1600) {
 
10912                  * Notify the RISC a carrier is ready by writing the physical
 
10913                  * address of the new carrier stopper to the COMMA register.
 
10915                 AdvWriteDWordRegister(iop_base, IOPDW_COMMA,
 
10916                                       le32_to_cpu(new_carrp->carr_pa));
 
10919         return ADV_SUCCESS;
 
10923  * Execute a single 'Scsi_Cmnd'.
 
10925 static int asc_execute_scsi_cmnd(struct scsi_cmnd *scp)
 
10928         struct asc_board *boardp = shost_priv(scp->device->host);
 
10930         ASC_DBG(1, "scp 0x%p\n", scp);
 
10932         if (ASC_NARROW_BOARD(boardp)) {
 
10933                 ASC_DVC_VAR *asc_dvc = &boardp->dvc_var.asc_dvc_var;
 
10934                 struct asc_scsi_q asc_scsi_q;
 
10936                 /* asc_build_req() can not return ASC_BUSY. */
 
10937                 ret = asc_build_req(boardp, scp, &asc_scsi_q);
 
10938                 if (ret == ASC_ERROR) {
 
10939                         ASC_STATS(scp->device->host, build_error);
 
10943                 ret = AscExeScsiQueue(asc_dvc, &asc_scsi_q);
 
10944                 kfree(asc_scsi_q.sg_head);
 
10945                 err_code = asc_dvc->err_code;
 
10947                 ADV_DVC_VAR *adv_dvc = &boardp->dvc_var.adv_dvc_var;
 
10948                 ADV_SCSI_REQ_Q *adv_scsiqp;
 
10950                 switch (adv_build_req(boardp, scp, &adv_scsiqp)) {
 
10952                         ASC_DBG(3, "adv_build_req ASC_NOERROR\n");
 
10955                         ASC_DBG(1, "adv_build_req ASC_BUSY\n");
 
10957                          * The asc_stats fields 'adv_build_noreq' and
 
10958                          * 'adv_build_nosg' count wide board busy conditions.
 
10959                          * They are updated in adv_build_req and
 
10960                          * adv_get_sglist, respectively.
 
10965                         ASC_DBG(1, "adv_build_req ASC_ERROR\n");
 
10966                         ASC_STATS(scp->device->host, build_error);
 
10970                 ret = AdvExeScsiQueue(adv_dvc, adv_scsiqp);
 
10971                 err_code = adv_dvc->err_code;
 
10976                 ASC_STATS(scp->device->host, exe_noerror);
 
10978                  * Increment monotonically increasing per device
 
10979                  * successful request counter. Wrapping doesn't matter.
 
10981                 boardp->reqcnt[scp->device->id]++;
 
10982                 ASC_DBG(1, "ExeScsiQueue() ASC_NOERROR\n");
 
10985                 ASC_STATS(scp->device->host, exe_busy);
 
10988                 scmd_printk(KERN_ERR, scp, "ExeScsiQueue() ASC_ERROR, "
 
10989                         "err_code 0x%x\n", err_code);
 
10990                 ASC_STATS(scp->device->host, exe_error);
 
10991                 scp->result = HOST_BYTE(DID_ERROR);
 
10994                 scmd_printk(KERN_ERR, scp, "ExeScsiQueue() unknown, "
 
10995                         "err_code 0x%x\n", err_code);
 
10996                 ASC_STATS(scp->device->host, exe_unknown);
 
10997                 scp->result = HOST_BYTE(DID_ERROR);
 
11001         ASC_DBG(1, "end\n");
 
11006  * advansys_queuecommand() - interrupt-driven I/O entrypoint.
 
11008  * This function always returns 0. Command return status is saved
 
11009  * in the 'scp' result field.
 
11012 advansys_queuecommand(struct scsi_cmnd *scp, void (*done)(struct scsi_cmnd *))
 
11014         struct Scsi_Host *shost = scp->device->host;
 
11015         int asc_res, result = 0;
 
11017         ASC_STATS(shost, queuecommand);
 
11018         scp->scsi_done = done;
 
11020         asc_res = asc_execute_scsi_cmnd(scp);
 
11026                 result = SCSI_MLQUEUE_HOST_BUSY;
 
11030                 asc_scsi_done(scp);
 
11037 static ushort __devinit AscGetEisaChipCfg(PortAddr iop_base)
 
11039         PortAddr eisa_cfg_iop = (PortAddr) ASC_GET_EISA_SLOT(iop_base) |
 
11040             (PortAddr) (ASC_EISA_CFG_IOP_MASK);
 
11041         return inpw(eisa_cfg_iop);
 
11045  * Return the BIOS address of the adapter at the specified
 
11046  * I/O port and with the specified bus type.
 
11048 static unsigned short __devinit
 
11049 AscGetChipBiosAddress(PortAddr iop_base, unsigned short bus_type)
 
11051         unsigned short cfg_lsw;
 
11052         unsigned short bios_addr;
 
11055          * The PCI BIOS is re-located by the motherboard BIOS. Because
 
11056          * of this the driver can not determine where a PCI BIOS is
 
11057          * loaded and executes.
 
11059         if (bus_type & ASC_IS_PCI)
 
11062         if ((bus_type & ASC_IS_EISA) != 0) {
 
11063                 cfg_lsw = AscGetEisaChipCfg(iop_base);
 
11065                 bios_addr = ASC_BIOS_MIN_ADDR + cfg_lsw * ASC_BIOS_BANK_SIZE;
 
11069         cfg_lsw = AscGetChipCfgLsw(iop_base);
 
11072          *  ISA PnP uses the top bit as the 32K BIOS flag
 
11074         if (bus_type == ASC_IS_ISAPNP)
 
11076         bios_addr = ASC_BIOS_MIN_ADDR + (cfg_lsw >> 12) * ASC_BIOS_BANK_SIZE;
 
11080 static uchar __devinit AscSetChipScsiID(PortAddr iop_base, uchar new_host_id)
 
11084         if (AscGetChipScsiID(iop_base) == new_host_id) {
 
11085                 return (new_host_id);
 
11087         cfg_lsw = AscGetChipCfgLsw(iop_base);
 
11089         cfg_lsw |= (ushort)((new_host_id & ASC_MAX_TID) << 8);
 
11090         AscSetChipCfgLsw(iop_base, cfg_lsw);
 
11091         return (AscGetChipScsiID(iop_base));
 
11094 static unsigned char __devinit AscGetChipScsiCtrl(PortAddr iop_base)
 
11098         AscSetBank(iop_base, 1);
 
11099         sc = inp(iop_base + IOP_REG_SC);
 
11100         AscSetBank(iop_base, 0);
 
11104 static unsigned char __devinit
 
11105 AscGetChipVersion(PortAddr iop_base, unsigned short bus_type)
 
11107         if (bus_type & ASC_IS_EISA) {
 
11109                 unsigned char revision;
 
11110                 eisa_iop = (PortAddr) ASC_GET_EISA_SLOT(iop_base) |
 
11111                     (PortAddr) ASC_EISA_REV_IOP_MASK;
 
11112                 revision = inp(eisa_iop);
 
11113                 return ASC_CHIP_MIN_VER_EISA - 1 + revision;
 
11115         return AscGetChipVerNo(iop_base);
 
11119 static void __devinit AscEnableIsaDma(uchar dma_channel)
 
11121         if (dma_channel < 4) {
 
11122                 outp(0x000B, (ushort)(0xC0 | dma_channel));
 
11123                 outp(0x000A, dma_channel);
 
11124         } else if (dma_channel < 8) {
 
11125                 outp(0x00D6, (ushort)(0xC0 | (dma_channel - 4)));
 
11126                 outp(0x00D4, (ushort)(dma_channel - 4));
 
11129 #endif /* CONFIG_ISA */
 
11131 static int AscStopQueueExe(PortAddr iop_base)
 
11135         if (AscReadLramByte(iop_base, ASCV_STOP_CODE_B) == 0) {
 
11136                 AscWriteLramByte(iop_base, ASCV_STOP_CODE_B,
 
11137                                  ASC_STOP_REQ_RISC_STOP);
 
11139                         if (AscReadLramByte(iop_base, ASCV_STOP_CODE_B) &
 
11140                             ASC_STOP_ACK_RISC_STOP) {
 
11144                 } while (count++ < 20);
 
11149 static ASC_DCNT __devinit AscGetMaxDmaCount(ushort bus_type)
 
11151         if (bus_type & ASC_IS_ISA)
 
11152                 return ASC_MAX_ISA_DMA_COUNT;
 
11153         else if (bus_type & (ASC_IS_EISA | ASC_IS_VL))
 
11154                 return ASC_MAX_VL_DMA_COUNT;
 
11155         return ASC_MAX_PCI_DMA_COUNT;
 
11159 static ushort __devinit AscGetIsaDmaChannel(PortAddr iop_base)
 
11163         channel = AscGetChipCfgLsw(iop_base) & 0x0003;
 
11164         if (channel == 0x03)
 
11166         else if (channel == 0x00)
 
11168         return (channel + 4);
 
11171 static ushort __devinit AscSetIsaDmaChannel(PortAddr iop_base, ushort dma_channel)
 
11176         if ((dma_channel >= 5) && (dma_channel <= 7)) {
 
11177                 if (dma_channel == 7)
 
11180                         value = dma_channel - 4;
 
11181                 cfg_lsw = AscGetChipCfgLsw(iop_base) & 0xFFFC;
 
11183                 AscSetChipCfgLsw(iop_base, cfg_lsw);
 
11184                 return (AscGetIsaDmaChannel(iop_base));
 
11189 static uchar __devinit AscGetIsaDmaSpeed(PortAddr iop_base)
 
11193         AscSetBank(iop_base, 1);
 
11194         speed_value = AscReadChipDmaSpeed(iop_base);
 
11195         speed_value &= 0x07;
 
11196         AscSetBank(iop_base, 0);
 
11197         return speed_value;
 
11200 static uchar __devinit AscSetIsaDmaSpeed(PortAddr iop_base, uchar speed_value)
 
11202         speed_value &= 0x07;
 
11203         AscSetBank(iop_base, 1);
 
11204         AscWriteChipDmaSpeed(iop_base, speed_value);
 
11205         AscSetBank(iop_base, 0);
 
11206         return AscGetIsaDmaSpeed(iop_base);
 
11208 #endif /* CONFIG_ISA */
 
11210 static ushort __devinit AscInitAscDvcVar(ASC_DVC_VAR *asc_dvc)
 
11215         uchar chip_version;
 
11217         iop_base = asc_dvc->iop_base;
 
11219         asc_dvc->err_code = 0;
 
11220         if ((asc_dvc->bus_type &
 
11221              (ASC_IS_ISA | ASC_IS_PCI | ASC_IS_EISA | ASC_IS_VL)) == 0) {
 
11222                 asc_dvc->err_code |= ASC_IERR_NO_BUS_TYPE;
 
11224         AscSetChipControl(iop_base, CC_HALT);
 
11225         AscSetChipStatus(iop_base, 0);
 
11226         asc_dvc->bug_fix_cntl = 0;
 
11227         asc_dvc->pci_fix_asyn_xfer = 0;
 
11228         asc_dvc->pci_fix_asyn_xfer_always = 0;
 
11229         /* asc_dvc->init_state initalized in AscInitGetConfig(). */
 
11230         asc_dvc->sdtr_done = 0;
 
11231         asc_dvc->cur_total_qng = 0;
 
11232         asc_dvc->is_in_int = 0;
 
11233         asc_dvc->in_critical_cnt = 0;
 
11234         asc_dvc->last_q_shortage = 0;
 
11235         asc_dvc->use_tagged_qng = 0;
 
11236         asc_dvc->no_scam = 0;
 
11237         asc_dvc->unit_not_ready = 0;
 
11238         asc_dvc->queue_full_or_busy = 0;
 
11239         asc_dvc->redo_scam = 0;
 
11241         asc_dvc->min_sdtr_index = 0;
 
11242         asc_dvc->cfg->can_tagged_qng = 0;
 
11243         asc_dvc->cfg->cmd_qng_enabled = 0;
 
11244         asc_dvc->dvc_cntl = ASC_DEF_DVC_CNTL;
 
11245         asc_dvc->init_sdtr = 0;
 
11246         asc_dvc->max_total_qng = ASC_DEF_MAX_TOTAL_QNG;
 
11247         asc_dvc->scsi_reset_wait = 3;
 
11248         asc_dvc->start_motor = ASC_SCSI_WIDTH_BIT_SET;
 
11249         asc_dvc->max_dma_count = AscGetMaxDmaCount(asc_dvc->bus_type);
 
11250         asc_dvc->cfg->sdtr_enable = ASC_SCSI_WIDTH_BIT_SET;
 
11251         asc_dvc->cfg->disc_enable = ASC_SCSI_WIDTH_BIT_SET;
 
11252         asc_dvc->cfg->chip_scsi_id = ASC_DEF_CHIP_SCSI_ID;
 
11253         chip_version = AscGetChipVersion(iop_base, asc_dvc->bus_type);
 
11254         asc_dvc->cfg->chip_version = chip_version;
 
11255         asc_dvc->sdtr_period_tbl = asc_syn_xfer_period;
 
11256         asc_dvc->max_sdtr_index = 7;
 
11257         if ((asc_dvc->bus_type & ASC_IS_PCI) &&
 
11258             (chip_version >= ASC_CHIP_VER_PCI_ULTRA_3150)) {
 
11259                 asc_dvc->bus_type = ASC_IS_PCI_ULTRA;
 
11260                 asc_dvc->sdtr_period_tbl = asc_syn_ultra_xfer_period;
 
11261                 asc_dvc->max_sdtr_index = 15;
 
11262                 if (chip_version == ASC_CHIP_VER_PCI_ULTRA_3150) {
 
11263                         AscSetExtraControl(iop_base,
 
11264                                            (SEC_ACTIVE_NEGATE | SEC_SLEW_RATE));
 
11265                 } else if (chip_version >= ASC_CHIP_VER_PCI_ULTRA_3050) {
 
11266                         AscSetExtraControl(iop_base,
 
11267                                            (SEC_ACTIVE_NEGATE |
 
11268                                             SEC_ENABLE_FILTER));
 
11271         if (asc_dvc->bus_type == ASC_IS_PCI) {
 
11272                 AscSetExtraControl(iop_base,
 
11273                                    (SEC_ACTIVE_NEGATE | SEC_SLEW_RATE));
 
11276         asc_dvc->cfg->isa_dma_speed = ASC_DEF_ISA_DMA_SPEED;
 
11278         if ((asc_dvc->bus_type & ASC_IS_ISA) != 0) {
 
11279                 if (chip_version >= ASC_CHIP_MIN_VER_ISA_PNP) {
 
11280                         AscSetChipIFC(iop_base, IFC_INIT_DEFAULT);
 
11281                         asc_dvc->bus_type = ASC_IS_ISAPNP;
 
11283                 asc_dvc->cfg->isa_dma_channel =
 
11284                     (uchar)AscGetIsaDmaChannel(iop_base);
 
11286 #endif /* CONFIG_ISA */
 
11287         for (i = 0; i <= ASC_MAX_TID; i++) {
 
11288                 asc_dvc->cur_dvc_qng[i] = 0;
 
11289                 asc_dvc->max_dvc_qng[i] = ASC_MAX_SCSI1_QNG;
 
11290                 asc_dvc->scsiq_busy_head[i] = (ASC_SCSI_Q *)0L;
 
11291                 asc_dvc->scsiq_busy_tail[i] = (ASC_SCSI_Q *)0L;
 
11292                 asc_dvc->cfg->max_tag_qng[i] = ASC_MAX_INRAM_TAG_QNG;
 
11297 static int __devinit AscWriteEEPCmdReg(PortAddr iop_base, uchar cmd_reg)
 
11301         for (retry = 0; retry < ASC_EEP_MAX_RETRY; retry++) {
 
11302                 unsigned char read_back;
 
11303                 AscSetChipEEPCmd(iop_base, cmd_reg);
 
11305                 read_back = AscGetChipEEPCmd(iop_base);
 
11306                 if (read_back == cmd_reg)
 
11312 static void __devinit AscWaitEEPRead(void)
 
11317 static ushort __devinit AscReadEEPWord(PortAddr iop_base, uchar addr)
 
11322         AscWriteEEPCmdReg(iop_base, ASC_EEP_CMD_WRITE_DISABLE);
 
11324         cmd_reg = addr | ASC_EEP_CMD_READ;
 
11325         AscWriteEEPCmdReg(iop_base, cmd_reg);
 
11327         read_wval = AscGetChipEEPData(iop_base);
 
11332 static ushort __devinit
 
11333 AscGetEEPConfig(PortAddr iop_base, ASCEEP_CONFIG *cfg_buf, ushort bus_type)
 
11340         int uchar_end_in_config = ASC_EEP_MAX_DVC_ADDR - 2;
 
11343         wbuf = (ushort *)cfg_buf;
 
11345         /* Read two config words; Byte-swapping done by AscReadEEPWord(). */
 
11346         for (s_addr = 0; s_addr < 2; s_addr++, wbuf++) {
 
11347                 *wbuf = AscReadEEPWord(iop_base, (uchar)s_addr);
 
11350         if (bus_type & ASC_IS_VL) {
 
11351                 cfg_beg = ASC_EEP_DVC_CFG_BEG_VL;
 
11352                 cfg_end = ASC_EEP_MAX_DVC_ADDR_VL;
 
11354                 cfg_beg = ASC_EEP_DVC_CFG_BEG;
 
11355                 cfg_end = ASC_EEP_MAX_DVC_ADDR;
 
11357         for (s_addr = cfg_beg; s_addr <= (cfg_end - 1); s_addr++, wbuf++) {
 
11358                 wval = AscReadEEPWord(iop_base, (uchar)s_addr);
 
11359                 if (s_addr <= uchar_end_in_config) {
 
11361                          * Swap all char fields - must unswap bytes already swapped
 
11362                          * by AscReadEEPWord().
 
11364                         *wbuf = le16_to_cpu(wval);
 
11366                         /* Don't swap word field at the end - cntl field. */
 
11369                 sum += wval;    /* Checksum treats all EEPROM data as words. */
 
11372          * Read the checksum word which will be compared against 'sum'
 
11373          * by the caller. Word field already swapped.
 
11375         *wbuf = AscReadEEPWord(iop_base, (uchar)s_addr);
 
11379 static int __devinit AscTestExternalLram(ASC_DVC_VAR *asc_dvc)
 
11386         iop_base = asc_dvc->iop_base;
 
11388         q_addr = ASC_QNO_TO_QADDR(241);
 
11389         saved_word = AscReadLramWord(iop_base, q_addr);
 
11390         AscSetChipLramAddr(iop_base, q_addr);
 
11391         AscSetChipLramData(iop_base, 0x55AA);
 
11393         AscSetChipLramAddr(iop_base, q_addr);
 
11394         if (AscGetChipLramData(iop_base) == 0x55AA) {
 
11396                 AscWriteLramWord(iop_base, q_addr, saved_word);
 
11401 static void __devinit AscWaitEEPWrite(void)
 
11406 static int __devinit AscWriteEEPDataReg(PortAddr iop_base, ushort data_reg)
 
11413                 AscSetChipEEPData(iop_base, data_reg);
 
11415                 read_back = AscGetChipEEPData(iop_base);
 
11416                 if (read_back == data_reg) {
 
11419                 if (retry++ > ASC_EEP_MAX_RETRY) {
 
11425 static ushort __devinit
 
11426 AscWriteEEPWord(PortAddr iop_base, uchar addr, ushort word_val)
 
11430         read_wval = AscReadEEPWord(iop_base, addr);
 
11431         if (read_wval != word_val) {
 
11432                 AscWriteEEPCmdReg(iop_base, ASC_EEP_CMD_WRITE_ABLE);
 
11434                 AscWriteEEPDataReg(iop_base, word_val);
 
11436                 AscWriteEEPCmdReg(iop_base,
 
11437                                   (uchar)((uchar)ASC_EEP_CMD_WRITE | addr));
 
11439                 AscWriteEEPCmdReg(iop_base, ASC_EEP_CMD_WRITE_DISABLE);
 
11441                 return (AscReadEEPWord(iop_base, addr));
 
11443         return (read_wval);
 
11446 static int __devinit
 
11447 AscSetEEPConfigOnce(PortAddr iop_base, ASCEEP_CONFIG *cfg_buf, ushort bus_type)
 
11456         int uchar_end_in_config = ASC_EEP_MAX_DVC_ADDR - 2;
 
11458         wbuf = (ushort *)cfg_buf;
 
11461         /* Write two config words; AscWriteEEPWord() will swap bytes. */
 
11462         for (s_addr = 0; s_addr < 2; s_addr++, wbuf++) {
 
11464                 if (*wbuf != AscWriteEEPWord(iop_base, (uchar)s_addr, *wbuf)) {
 
11468         if (bus_type & ASC_IS_VL) {
 
11469                 cfg_beg = ASC_EEP_DVC_CFG_BEG_VL;
 
11470                 cfg_end = ASC_EEP_MAX_DVC_ADDR_VL;
 
11472                 cfg_beg = ASC_EEP_DVC_CFG_BEG;
 
11473                 cfg_end = ASC_EEP_MAX_DVC_ADDR;
 
11475         for (s_addr = cfg_beg; s_addr <= (cfg_end - 1); s_addr++, wbuf++) {
 
11476                 if (s_addr <= uchar_end_in_config) {
 
11478                          * This is a char field. Swap char fields before they are
 
11479                          * swapped again by AscWriteEEPWord().
 
11481                         word = cpu_to_le16(*wbuf);
 
11483                             AscWriteEEPWord(iop_base, (uchar)s_addr, word)) {
 
11487                         /* Don't swap word field at the end - cntl field. */
 
11489                             AscWriteEEPWord(iop_base, (uchar)s_addr, *wbuf)) {
 
11493                 sum += *wbuf;   /* Checksum calculated from word values. */
 
11495         /* Write checksum word. It will be swapped by AscWriteEEPWord(). */
 
11497         if (sum != AscWriteEEPWord(iop_base, (uchar)s_addr, sum)) {
 
11501         /* Read EEPROM back again. */
 
11502         wbuf = (ushort *)cfg_buf;
 
11504          * Read two config words; Byte-swapping done by AscReadEEPWord().
 
11506         for (s_addr = 0; s_addr < 2; s_addr++, wbuf++) {
 
11507                 if (*wbuf != AscReadEEPWord(iop_base, (uchar)s_addr)) {
 
11511         if (bus_type & ASC_IS_VL) {
 
11512                 cfg_beg = ASC_EEP_DVC_CFG_BEG_VL;
 
11513                 cfg_end = ASC_EEP_MAX_DVC_ADDR_VL;
 
11515                 cfg_beg = ASC_EEP_DVC_CFG_BEG;
 
11516                 cfg_end = ASC_EEP_MAX_DVC_ADDR;
 
11518         for (s_addr = cfg_beg; s_addr <= (cfg_end - 1); s_addr++, wbuf++) {
 
11519                 if (s_addr <= uchar_end_in_config) {
 
11521                          * Swap all char fields. Must unswap bytes already swapped
 
11522                          * by AscReadEEPWord().
 
11525                             le16_to_cpu(AscReadEEPWord
 
11526                                         (iop_base, (uchar)s_addr));
 
11528                         /* Don't swap word field at the end - cntl field. */
 
11529                         word = AscReadEEPWord(iop_base, (uchar)s_addr);
 
11531                 if (*wbuf != word) {
 
11535         /* Read checksum; Byte swapping not needed. */
 
11536         if (AscReadEEPWord(iop_base, (uchar)s_addr) != sum) {
 
11542 static int __devinit
 
11543 AscSetEEPConfig(PortAddr iop_base, ASCEEP_CONFIG *cfg_buf, ushort bus_type)
 
11550                 if ((n_error = AscSetEEPConfigOnce(iop_base, cfg_buf,
 
11554                 if (++retry > ASC_EEP_MAX_RETRY) {
 
11561 static ushort __devinit AscInitFromEEP(ASC_DVC_VAR *asc_dvc)
 
11563         ASCEEP_CONFIG eep_config_buf;
 
11564         ASCEEP_CONFIG *eep_config;
 
11568         ushort cfg_msw, cfg_lsw;
 
11572         iop_base = asc_dvc->iop_base;
 
11574         AscWriteLramWord(iop_base, ASCV_HALTCODE_W, 0x00FE);
 
11575         AscStopQueueExe(iop_base);
 
11576         if ((AscStopChip(iop_base) == FALSE) ||
 
11577             (AscGetChipScsiCtrl(iop_base) != 0)) {
 
11578                 asc_dvc->init_state |= ASC_INIT_RESET_SCSI_DONE;
 
11579                 AscResetChipAndScsiBus(asc_dvc);
 
11580                 mdelay(asc_dvc->scsi_reset_wait * 1000); /* XXX: msleep? */
 
11582         if (AscIsChipHalted(iop_base) == FALSE) {
 
11583                 asc_dvc->err_code |= ASC_IERR_START_STOP_CHIP;
 
11584                 return (warn_code);
 
11586         AscSetPCAddr(iop_base, ASC_MCODE_START_ADDR);
 
11587         if (AscGetPCAddr(iop_base) != ASC_MCODE_START_ADDR) {
 
11588                 asc_dvc->err_code |= ASC_IERR_SET_PC_ADDR;
 
11589                 return (warn_code);
 
11591         eep_config = (ASCEEP_CONFIG *)&eep_config_buf;
 
11592         cfg_msw = AscGetChipCfgMsw(iop_base);
 
11593         cfg_lsw = AscGetChipCfgLsw(iop_base);
 
11594         if ((cfg_msw & ASC_CFG_MSW_CLR_MASK) != 0) {
 
11595                 cfg_msw &= ~ASC_CFG_MSW_CLR_MASK;
 
11596                 warn_code |= ASC_WARN_CFG_MSW_RECOVER;
 
11597                 AscSetChipCfgMsw(iop_base, cfg_msw);
 
11599         chksum = AscGetEEPConfig(iop_base, eep_config, asc_dvc->bus_type);
 
11600         ASC_DBG(1, "chksum 0x%x\n", chksum);
 
11604         if (AscGetChipStatus(iop_base) & CSW_AUTO_CONFIG) {
 
11605                 warn_code |= ASC_WARN_AUTO_CONFIG;
 
11606                 if (asc_dvc->cfg->chip_version == 3) {
 
11607                         if (eep_config->cfg_lsw != cfg_lsw) {
 
11608                                 warn_code |= ASC_WARN_EEPROM_RECOVER;
 
11609                                 eep_config->cfg_lsw =
 
11610                                     AscGetChipCfgLsw(iop_base);
 
11612                         if (eep_config->cfg_msw != cfg_msw) {
 
11613                                 warn_code |= ASC_WARN_EEPROM_RECOVER;
 
11614                                 eep_config->cfg_msw =
 
11615                                     AscGetChipCfgMsw(iop_base);
 
11619         eep_config->cfg_msw &= ~ASC_CFG_MSW_CLR_MASK;
 
11620         eep_config->cfg_lsw |= ASC_CFG0_HOST_INT_ON;
 
11621         ASC_DBG(1, "eep_config->chksum 0x%x\n", eep_config->chksum);
 
11622         if (chksum != eep_config->chksum) {
 
11623                 if (AscGetChipVersion(iop_base, asc_dvc->bus_type) ==
 
11624                     ASC_CHIP_VER_PCI_ULTRA_3050) {
 
11625                         ASC_DBG(1, "chksum error ignored; EEPROM-less board\n");
 
11626                         eep_config->init_sdtr = 0xFF;
 
11627                         eep_config->disc_enable = 0xFF;
 
11628                         eep_config->start_motor = 0xFF;
 
11629                         eep_config->use_cmd_qng = 0;
 
11630                         eep_config->max_total_qng = 0xF0;
 
11631                         eep_config->max_tag_qng = 0x20;
 
11632                         eep_config->cntl = 0xBFFF;
 
11633                         ASC_EEP_SET_CHIP_ID(eep_config, 7);
 
11634                         eep_config->no_scam = 0;
 
11635                         eep_config->adapter_info[0] = 0;
 
11636                         eep_config->adapter_info[1] = 0;
 
11637                         eep_config->adapter_info[2] = 0;
 
11638                         eep_config->adapter_info[3] = 0;
 
11639                         eep_config->adapter_info[4] = 0;
 
11640                         /* Indicate EEPROM-less board. */
 
11641                         eep_config->adapter_info[5] = 0xBB;
 
11644                             ("AscInitFromEEP: EEPROM checksum error; Will try to re-write EEPROM.\n");
 
11646                         warn_code |= ASC_WARN_EEPROM_CHKSUM;
 
11649         asc_dvc->cfg->sdtr_enable = eep_config->init_sdtr;
 
11650         asc_dvc->cfg->disc_enable = eep_config->disc_enable;
 
11651         asc_dvc->cfg->cmd_qng_enabled = eep_config->use_cmd_qng;
 
11652         asc_dvc->cfg->isa_dma_speed = ASC_EEP_GET_DMA_SPD(eep_config);
 
11653         asc_dvc->start_motor = eep_config->start_motor;
 
11654         asc_dvc->dvc_cntl = eep_config->cntl;
 
11655         asc_dvc->no_scam = eep_config->no_scam;
 
11656         asc_dvc->cfg->adapter_info[0] = eep_config->adapter_info[0];
 
11657         asc_dvc->cfg->adapter_info[1] = eep_config->adapter_info[1];
 
11658         asc_dvc->cfg->adapter_info[2] = eep_config->adapter_info[2];
 
11659         asc_dvc->cfg->adapter_info[3] = eep_config->adapter_info[3];
 
11660         asc_dvc->cfg->adapter_info[4] = eep_config->adapter_info[4];
 
11661         asc_dvc->cfg->adapter_info[5] = eep_config->adapter_info[5];
 
11662         if (!AscTestExternalLram(asc_dvc)) {
 
11663                 if (((asc_dvc->bus_type & ASC_IS_PCI_ULTRA) ==
 
11664                      ASC_IS_PCI_ULTRA)) {
 
11665                         eep_config->max_total_qng =
 
11666                             ASC_MAX_PCI_ULTRA_INRAM_TOTAL_QNG;
 
11667                         eep_config->max_tag_qng =
 
11668                             ASC_MAX_PCI_ULTRA_INRAM_TAG_QNG;
 
11670                         eep_config->cfg_msw |= 0x0800;
 
11672                         AscSetChipCfgMsw(iop_base, cfg_msw);
 
11673                         eep_config->max_total_qng = ASC_MAX_PCI_INRAM_TOTAL_QNG;
 
11674                         eep_config->max_tag_qng = ASC_MAX_INRAM_TAG_QNG;
 
11678         if (eep_config->max_total_qng < ASC_MIN_TOTAL_QNG) {
 
11679                 eep_config->max_total_qng = ASC_MIN_TOTAL_QNG;
 
11681         if (eep_config->max_total_qng > ASC_MAX_TOTAL_QNG) {
 
11682                 eep_config->max_total_qng = ASC_MAX_TOTAL_QNG;
 
11684         if (eep_config->max_tag_qng > eep_config->max_total_qng) {
 
11685                 eep_config->max_tag_qng = eep_config->max_total_qng;
 
11687         if (eep_config->max_tag_qng < ASC_MIN_TAG_Q_PER_DVC) {
 
11688                 eep_config->max_tag_qng = ASC_MIN_TAG_Q_PER_DVC;
 
11690         asc_dvc->max_total_qng = eep_config->max_total_qng;
 
11691         if ((eep_config->use_cmd_qng & eep_config->disc_enable) !=
 
11692             eep_config->use_cmd_qng) {
 
11693                 eep_config->disc_enable = eep_config->use_cmd_qng;
 
11694                 warn_code |= ASC_WARN_CMD_QNG_CONFLICT;
 
11696         ASC_EEP_SET_CHIP_ID(eep_config,
 
11697                             ASC_EEP_GET_CHIP_ID(eep_config) & ASC_MAX_TID);
 
11698         asc_dvc->cfg->chip_scsi_id = ASC_EEP_GET_CHIP_ID(eep_config);
 
11699         if (((asc_dvc->bus_type & ASC_IS_PCI_ULTRA) == ASC_IS_PCI_ULTRA) &&
 
11700             !(asc_dvc->dvc_cntl & ASC_CNTL_SDTR_ENABLE_ULTRA)) {
 
11701                 asc_dvc->min_sdtr_index = ASC_SDTR_ULTRA_PCI_10MB_INDEX;
 
11704         for (i = 0; i <= ASC_MAX_TID; i++) {
 
11705                 asc_dvc->dos_int13_table[i] = eep_config->dos_int13_table[i];
 
11706                 asc_dvc->cfg->max_tag_qng[i] = eep_config->max_tag_qng;
 
11707                 asc_dvc->cfg->sdtr_period_offset[i] =
 
11708                     (uchar)(ASC_DEF_SDTR_OFFSET |
 
11709                             (asc_dvc->min_sdtr_index << 4));
 
11711         eep_config->cfg_msw = AscGetChipCfgMsw(iop_base);
 
11713                 if ((i = AscSetEEPConfig(iop_base, eep_config,
 
11714                                      asc_dvc->bus_type)) != 0) {
 
11716                             ("AscInitFromEEP: Failed to re-write EEPROM with %d errors.\n",
 
11720                             ("AscInitFromEEP: Successfully re-wrote EEPROM.\n");
 
11723         return (warn_code);
 
11726 static int __devinit AscInitGetConfig(struct Scsi_Host *shost)
 
11728         struct asc_board *board = shost_priv(shost);
 
11729         ASC_DVC_VAR *asc_dvc = &board->dvc_var.asc_dvc_var;
 
11730         unsigned short warn_code = 0;
 
11732         asc_dvc->init_state = ASC_INIT_STATE_BEG_GET_CFG;
 
11733         if (asc_dvc->err_code != 0)
 
11734                 return asc_dvc->err_code;
 
11736         if (AscFindSignature(asc_dvc->iop_base)) {
 
11737                 warn_code |= AscInitAscDvcVar(asc_dvc);
 
11738                 warn_code |= AscInitFromEEP(asc_dvc);
 
11739                 asc_dvc->init_state |= ASC_INIT_STATE_END_GET_CFG;
 
11740                 if (asc_dvc->scsi_reset_wait > ASC_MAX_SCSI_RESET_WAIT)
 
11741                         asc_dvc->scsi_reset_wait = ASC_MAX_SCSI_RESET_WAIT;
 
11743                 asc_dvc->err_code = ASC_IERR_BAD_SIGNATURE;
 
11746         switch (warn_code) {
 
11747         case 0: /* No error */
 
11749         case ASC_WARN_IO_PORT_ROTATE:
 
11750                 shost_printk(KERN_WARNING, shost, "I/O port address "
 
11753         case ASC_WARN_AUTO_CONFIG:
 
11754                 shost_printk(KERN_WARNING, shost, "I/O port increment switch "
 
11757         case ASC_WARN_EEPROM_CHKSUM:
 
11758                 shost_printk(KERN_WARNING, shost, "EEPROM checksum error\n");
 
11760         case ASC_WARN_IRQ_MODIFIED:
 
11761                 shost_printk(KERN_WARNING, shost, "IRQ modified\n");
 
11763         case ASC_WARN_CMD_QNG_CONFLICT:
 
11764                 shost_printk(KERN_WARNING, shost, "tag queuing enabled w/o "
 
11768                 shost_printk(KERN_WARNING, shost, "unknown warning: 0x%x\n",
 
11773         if (asc_dvc->err_code != 0)
 
11774                 shost_printk(KERN_ERR, shost, "error 0x%x at init_state "
 
11775                         "0x%x\n", asc_dvc->err_code, asc_dvc->init_state);
 
11777         return asc_dvc->err_code;
 
11780 static int __devinit AscInitSetConfig(struct pci_dev *pdev, struct Scsi_Host *shost)
 
11782         struct asc_board *board = shost_priv(shost);
 
11783         ASC_DVC_VAR *asc_dvc = &board->dvc_var.asc_dvc_var;
 
11784         PortAddr iop_base = asc_dvc->iop_base;
 
11785         unsigned short cfg_msw;
 
11786         unsigned short warn_code = 0;
 
11788         asc_dvc->init_state |= ASC_INIT_STATE_BEG_SET_CFG;
 
11789         if (asc_dvc->err_code != 0)
 
11790                 return asc_dvc->err_code;
 
11791         if (!AscFindSignature(asc_dvc->iop_base)) {
 
11792                 asc_dvc->err_code = ASC_IERR_BAD_SIGNATURE;
 
11793                 return asc_dvc->err_code;
 
11796         cfg_msw = AscGetChipCfgMsw(iop_base);
 
11797         if ((cfg_msw & ASC_CFG_MSW_CLR_MASK) != 0) {
 
11798                 cfg_msw &= ~ASC_CFG_MSW_CLR_MASK;
 
11799                 warn_code |= ASC_WARN_CFG_MSW_RECOVER;
 
11800                 AscSetChipCfgMsw(iop_base, cfg_msw);
 
11802         if ((asc_dvc->cfg->cmd_qng_enabled & asc_dvc->cfg->disc_enable) !=
 
11803             asc_dvc->cfg->cmd_qng_enabled) {
 
11804                 asc_dvc->cfg->disc_enable = asc_dvc->cfg->cmd_qng_enabled;
 
11805                 warn_code |= ASC_WARN_CMD_QNG_CONFLICT;
 
11807         if (AscGetChipStatus(iop_base) & CSW_AUTO_CONFIG) {
 
11808                 warn_code |= ASC_WARN_AUTO_CONFIG;
 
11811         if (asc_dvc->bus_type & ASC_IS_PCI) {
 
11813                 AscSetChipCfgMsw(iop_base, cfg_msw);
 
11814                 if ((asc_dvc->bus_type & ASC_IS_PCI_ULTRA) == ASC_IS_PCI_ULTRA) {
 
11816                         if ((pdev->device == PCI_DEVICE_ID_ASP_1200A) ||
 
11817                             (pdev->device == PCI_DEVICE_ID_ASP_ABP940)) {
 
11818                                 asc_dvc->bug_fix_cntl |= ASC_BUG_FIX_IF_NOT_DWB;
 
11819                                 asc_dvc->bug_fix_cntl |=
 
11820                                     ASC_BUG_FIX_ASYN_USE_SYN;
 
11824 #endif /* CONFIG_PCI */
 
11825         if (asc_dvc->bus_type == ASC_IS_ISAPNP) {
 
11826                 if (AscGetChipVersion(iop_base, asc_dvc->bus_type)
 
11827                     == ASC_CHIP_VER_ASYN_BUG) {
 
11828                         asc_dvc->bug_fix_cntl |= ASC_BUG_FIX_ASYN_USE_SYN;
 
11831         if (AscSetChipScsiID(iop_base, asc_dvc->cfg->chip_scsi_id) !=
 
11832             asc_dvc->cfg->chip_scsi_id) {
 
11833                 asc_dvc->err_code |= ASC_IERR_SET_SCSI_ID;
 
11836         if (asc_dvc->bus_type & ASC_IS_ISA) {
 
11837                 AscSetIsaDmaChannel(iop_base, asc_dvc->cfg->isa_dma_channel);
 
11838                 AscSetIsaDmaSpeed(iop_base, asc_dvc->cfg->isa_dma_speed);
 
11840 #endif /* CONFIG_ISA */
 
11842         asc_dvc->init_state |= ASC_INIT_STATE_END_SET_CFG;
 
11844         switch (warn_code) {
 
11845         case 0: /* No error. */
 
11847         case ASC_WARN_IO_PORT_ROTATE:
 
11848                 shost_printk(KERN_WARNING, shost, "I/O port address "
 
11851         case ASC_WARN_AUTO_CONFIG:
 
11852                 shost_printk(KERN_WARNING, shost, "I/O port increment switch "
 
11855         case ASC_WARN_EEPROM_CHKSUM:
 
11856                 shost_printk(KERN_WARNING, shost, "EEPROM checksum error\n");
 
11858         case ASC_WARN_IRQ_MODIFIED:
 
11859                 shost_printk(KERN_WARNING, shost, "IRQ modified\n");
 
11861         case ASC_WARN_CMD_QNG_CONFLICT:
 
11862                 shost_printk(KERN_WARNING, shost, "tag queuing w/o "
 
11866                 shost_printk(KERN_WARNING, shost, "unknown warning: 0x%x\n",
 
11871         if (asc_dvc->err_code != 0)
 
11872                 shost_printk(KERN_ERR, shost, "error 0x%x at init_state "
 
11873                         "0x%x\n", asc_dvc->err_code, asc_dvc->init_state);
 
11875         return asc_dvc->err_code;
 
11879  * EEPROM Configuration.
 
11881  * All drivers should use this structure to set the default EEPROM
 
11882  * configuration. The BIOS now uses this structure when it is built.
 
11883  * Additional structure information can be found in a_condor.h where
 
11884  * the structure is defined.
 
11886  * The *_Field_IsChar structs are needed to correct for endianness.
 
11887  * These values are read from the board 16 bits at a time directly
 
11888  * into the structs. Because some fields are char, the values will be
 
11889  * in the wrong order. The *_Field_IsChar tells when to flip the
 
11890  * bytes. Data read and written to PCI memory is automatically swapped
 
11891  * on big-endian platforms so char fields read as words are actually being
 
11892  * unswapped on big-endian platforms.
 
11894 static ADVEEP_3550_CONFIG Default_3550_EEPROM_Config __devinitdata = {
 
11895         ADV_EEPROM_BIOS_ENABLE, /* cfg_lsw */
 
11896         0x0000,                 /* cfg_msw */
 
11897         0xFFFF,                 /* disc_enable */
 
11898         0xFFFF,                 /* wdtr_able */
 
11899         0xFFFF,                 /* sdtr_able */
 
11900         0xFFFF,                 /* start_motor */
 
11901         0xFFFF,                 /* tagqng_able */
 
11902         0xFFFF,                 /* bios_scan */
 
11903         0,                      /* scam_tolerant */
 
11904         7,                      /* adapter_scsi_id */
 
11905         0,                      /* bios_boot_delay */
 
11906         3,                      /* scsi_reset_delay */
 
11907         0,                      /* bios_id_lun */
 
11908         0,                      /* termination */
 
11910         0xFFE7,                 /* bios_ctrl */
 
11911         0xFFFF,                 /* ultra_able */
 
11913         ASC_DEF_MAX_HOST_QNG,   /* max_host_qng */
 
11914         ASC_DEF_MAX_DVC_QNG,    /* max_dvc_qng */
 
11917         0,                      /* serial_number_word1 */
 
11918         0,                      /* serial_number_word2 */
 
11919         0,                      /* serial_number_word3 */
 
11921         {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
 
11922         ,                       /* oem_name[16] */
 
11923         0,                      /* dvc_err_code */
 
11924         0,                      /* adv_err_code */
 
11925         0,                      /* adv_err_addr */
 
11926         0,                      /* saved_dvc_err_code */
 
11927         0,                      /* saved_adv_err_code */
 
11928         0,                      /* saved_adv_err_addr */
 
11932 static ADVEEP_3550_CONFIG ADVEEP_3550_Config_Field_IsChar __devinitdata = {
 
11935         0,                      /* -disc_enable */
 
11938         0,                      /* start_motor */
 
11939         0,                      /* tagqng_able */
 
11941         0,                      /* scam_tolerant */
 
11942         1,                      /* adapter_scsi_id */
 
11943         1,                      /* bios_boot_delay */
 
11944         1,                      /* scsi_reset_delay */
 
11945         1,                      /* bios_id_lun */
 
11946         1,                      /* termination */
 
11949         0,                      /* ultra_able */
 
11951         1,                      /* max_host_qng */
 
11952         1,                      /* max_dvc_qng */
 
11955         0,                      /* serial_number_word1 */
 
11956         0,                      /* serial_number_word2 */
 
11957         0,                      /* serial_number_word3 */
 
11959         {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
 
11960         ,                       /* oem_name[16] */
 
11961         0,                      /* dvc_err_code */
 
11962         0,                      /* adv_err_code */
 
11963         0,                      /* adv_err_addr */
 
11964         0,                      /* saved_dvc_err_code */
 
11965         0,                      /* saved_adv_err_code */
 
11966         0,                      /* saved_adv_err_addr */
 
11970 static ADVEEP_38C0800_CONFIG Default_38C0800_EEPROM_Config __devinitdata = {
 
11971         ADV_EEPROM_BIOS_ENABLE, /* 00 cfg_lsw */
 
11972         0x0000,                 /* 01 cfg_msw */
 
11973         0xFFFF,                 /* 02 disc_enable */
 
11974         0xFFFF,                 /* 03 wdtr_able */
 
11975         0x4444,                 /* 04 sdtr_speed1 */
 
11976         0xFFFF,                 /* 05 start_motor */
 
11977         0xFFFF,                 /* 06 tagqng_able */
 
11978         0xFFFF,                 /* 07 bios_scan */
 
11979         0,                      /* 08 scam_tolerant */
 
11980         7,                      /* 09 adapter_scsi_id */
 
11981         0,                      /*    bios_boot_delay */
 
11982         3,                      /* 10 scsi_reset_delay */
 
11983         0,                      /*    bios_id_lun */
 
11984         0,                      /* 11 termination_se */
 
11985         0,                      /*    termination_lvd */
 
11986         0xFFE7,                 /* 12 bios_ctrl */
 
11987         0x4444,                 /* 13 sdtr_speed2 */
 
11988         0x4444,                 /* 14 sdtr_speed3 */
 
11989         ASC_DEF_MAX_HOST_QNG,   /* 15 max_host_qng */
 
11990         ASC_DEF_MAX_DVC_QNG,    /*    max_dvc_qng */
 
11991         0,                      /* 16 dvc_cntl */
 
11992         0x4444,                 /* 17 sdtr_speed4 */
 
11993         0,                      /* 18 serial_number_word1 */
 
11994         0,                      /* 19 serial_number_word2 */
 
11995         0,                      /* 20 serial_number_word3 */
 
11996         0,                      /* 21 check_sum */
 
11997         {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
 
11998         ,                       /* 22-29 oem_name[16] */
 
11999         0,                      /* 30 dvc_err_code */
 
12000         0,                      /* 31 adv_err_code */
 
12001         0,                      /* 32 adv_err_addr */
 
12002         0,                      /* 33 saved_dvc_err_code */
 
12003         0,                      /* 34 saved_adv_err_code */
 
12004         0,                      /* 35 saved_adv_err_addr */
 
12005         0,                      /* 36 reserved */
 
12006         0,                      /* 37 reserved */
 
12007         0,                      /* 38 reserved */
 
12008         0,                      /* 39 reserved */
 
12009         0,                      /* 40 reserved */
 
12010         0,                      /* 41 reserved */
 
12011         0,                      /* 42 reserved */
 
12012         0,                      /* 43 reserved */
 
12013         0,                      /* 44 reserved */
 
12014         0,                      /* 45 reserved */
 
12015         0,                      /* 46 reserved */
 
12016         0,                      /* 47 reserved */
 
12017         0,                      /* 48 reserved */
 
12018         0,                      /* 49 reserved */
 
12019         0,                      /* 50 reserved */
 
12020         0,                      /* 51 reserved */
 
12021         0,                      /* 52 reserved */
 
12022         0,                      /* 53 reserved */
 
12023         0,                      /* 54 reserved */
 
12024         0,                      /* 55 reserved */
 
12025         0,                      /* 56 cisptr_lsw */
 
12026         0,                      /* 57 cisprt_msw */
 
12027         PCI_VENDOR_ID_ASP,      /* 58 subsysvid */
 
12028         PCI_DEVICE_ID_38C0800_REV1,     /* 59 subsysid */
 
12029         0,                      /* 60 reserved */
 
12030         0,                      /* 61 reserved */
 
12031         0,                      /* 62 reserved */
 
12032         0                       /* 63 reserved */
 
12035 static ADVEEP_38C0800_CONFIG ADVEEP_38C0800_Config_Field_IsChar __devinitdata = {
 
12036         0,                      /* 00 cfg_lsw */
 
12037         0,                      /* 01 cfg_msw */
 
12038         0,                      /* 02 disc_enable */
 
12039         0,                      /* 03 wdtr_able */
 
12040         0,                      /* 04 sdtr_speed1 */
 
12041         0,                      /* 05 start_motor */
 
12042         0,                      /* 06 tagqng_able */
 
12043         0,                      /* 07 bios_scan */
 
12044         0,                      /* 08 scam_tolerant */
 
12045         1,                      /* 09 adapter_scsi_id */
 
12046         1,                      /*    bios_boot_delay */
 
12047         1,                      /* 10 scsi_reset_delay */
 
12048         1,                      /*    bios_id_lun */
 
12049         1,                      /* 11 termination_se */
 
12050         1,                      /*    termination_lvd */
 
12051         0,                      /* 12 bios_ctrl */
 
12052         0,                      /* 13 sdtr_speed2 */
 
12053         0,                      /* 14 sdtr_speed3 */
 
12054         1,                      /* 15 max_host_qng */
 
12055         1,                      /*    max_dvc_qng */
 
12056         0,                      /* 16 dvc_cntl */
 
12057         0,                      /* 17 sdtr_speed4 */
 
12058         0,                      /* 18 serial_number_word1 */
 
12059         0,                      /* 19 serial_number_word2 */
 
12060         0,                      /* 20 serial_number_word3 */
 
12061         0,                      /* 21 check_sum */
 
12062         {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
 
12063         ,                       /* 22-29 oem_name[16] */
 
12064         0,                      /* 30 dvc_err_code */
 
12065         0,                      /* 31 adv_err_code */
 
12066         0,                      /* 32 adv_err_addr */
 
12067         0,                      /* 33 saved_dvc_err_code */
 
12068         0,                      /* 34 saved_adv_err_code */
 
12069         0,                      /* 35 saved_adv_err_addr */
 
12070         0,                      /* 36 reserved */
 
12071         0,                      /* 37 reserved */
 
12072         0,                      /* 38 reserved */
 
12073         0,                      /* 39 reserved */
 
12074         0,                      /* 40 reserved */
 
12075         0,                      /* 41 reserved */
 
12076         0,                      /* 42 reserved */
 
12077         0,                      /* 43 reserved */
 
12078         0,                      /* 44 reserved */
 
12079         0,                      /* 45 reserved */
 
12080         0,                      /* 46 reserved */
 
12081         0,                      /* 47 reserved */
 
12082         0,                      /* 48 reserved */
 
12083         0,                      /* 49 reserved */
 
12084         0,                      /* 50 reserved */
 
12085         0,                      /* 51 reserved */
 
12086         0,                      /* 52 reserved */
 
12087         0,                      /* 53 reserved */
 
12088         0,                      /* 54 reserved */
 
12089         0,                      /* 55 reserved */
 
12090         0,                      /* 56 cisptr_lsw */
 
12091         0,                      /* 57 cisprt_msw */
 
12092         0,                      /* 58 subsysvid */
 
12093         0,                      /* 59 subsysid */
 
12094         0,                      /* 60 reserved */
 
12095         0,                      /* 61 reserved */
 
12096         0,                      /* 62 reserved */
 
12097         0                       /* 63 reserved */
 
12100 static ADVEEP_38C1600_CONFIG Default_38C1600_EEPROM_Config __devinitdata = {
 
12101         ADV_EEPROM_BIOS_ENABLE, /* 00 cfg_lsw */
 
12102         0x0000,                 /* 01 cfg_msw */
 
12103         0xFFFF,                 /* 02 disc_enable */
 
12104         0xFFFF,                 /* 03 wdtr_able */
 
12105         0x5555,                 /* 04 sdtr_speed1 */
 
12106         0xFFFF,                 /* 05 start_motor */
 
12107         0xFFFF,                 /* 06 tagqng_able */
 
12108         0xFFFF,                 /* 07 bios_scan */
 
12109         0,                      /* 08 scam_tolerant */
 
12110         7,                      /* 09 adapter_scsi_id */
 
12111         0,                      /*    bios_boot_delay */
 
12112         3,                      /* 10 scsi_reset_delay */
 
12113         0,                      /*    bios_id_lun */
 
12114         0,                      /* 11 termination_se */
 
12115         0,                      /*    termination_lvd */
 
12116         0xFFE7,                 /* 12 bios_ctrl */
 
12117         0x5555,                 /* 13 sdtr_speed2 */
 
12118         0x5555,                 /* 14 sdtr_speed3 */
 
12119         ASC_DEF_MAX_HOST_QNG,   /* 15 max_host_qng */
 
12120         ASC_DEF_MAX_DVC_QNG,    /*    max_dvc_qng */
 
12121         0,                      /* 16 dvc_cntl */
 
12122         0x5555,                 /* 17 sdtr_speed4 */
 
12123         0,                      /* 18 serial_number_word1 */
 
12124         0,                      /* 19 serial_number_word2 */
 
12125         0,                      /* 20 serial_number_word3 */
 
12126         0,                      /* 21 check_sum */
 
12127         {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
 
12128         ,                       /* 22-29 oem_name[16] */
 
12129         0,                      /* 30 dvc_err_code */
 
12130         0,                      /* 31 adv_err_code */
 
12131         0,                      /* 32 adv_err_addr */
 
12132         0,                      /* 33 saved_dvc_err_code */
 
12133         0,                      /* 34 saved_adv_err_code */
 
12134         0,                      /* 35 saved_adv_err_addr */
 
12135         0,                      /* 36 reserved */
 
12136         0,                      /* 37 reserved */
 
12137         0,                      /* 38 reserved */
 
12138         0,                      /* 39 reserved */
 
12139         0,                      /* 40 reserved */
 
12140         0,                      /* 41 reserved */
 
12141         0,                      /* 42 reserved */
 
12142         0,                      /* 43 reserved */
 
12143         0,                      /* 44 reserved */
 
12144         0,                      /* 45 reserved */
 
12145         0,                      /* 46 reserved */
 
12146         0,                      /* 47 reserved */
 
12147         0,                      /* 48 reserved */
 
12148         0,                      /* 49 reserved */
 
12149         0,                      /* 50 reserved */
 
12150         0,                      /* 51 reserved */
 
12151         0,                      /* 52 reserved */
 
12152         0,                      /* 53 reserved */
 
12153         0,                      /* 54 reserved */
 
12154         0,                      /* 55 reserved */
 
12155         0,                      /* 56 cisptr_lsw */
 
12156         0,                      /* 57 cisprt_msw */
 
12157         PCI_VENDOR_ID_ASP,      /* 58 subsysvid */
 
12158         PCI_DEVICE_ID_38C1600_REV1,     /* 59 subsysid */
 
12159         0,                      /* 60 reserved */
 
12160         0,                      /* 61 reserved */
 
12161         0,                      /* 62 reserved */
 
12162         0                       /* 63 reserved */
 
12165 static ADVEEP_38C1600_CONFIG ADVEEP_38C1600_Config_Field_IsChar __devinitdata = {
 
12166         0,                      /* 00 cfg_lsw */
 
12167         0,                      /* 01 cfg_msw */
 
12168         0,                      /* 02 disc_enable */
 
12169         0,                      /* 03 wdtr_able */
 
12170         0,                      /* 04 sdtr_speed1 */
 
12171         0,                      /* 05 start_motor */
 
12172         0,                      /* 06 tagqng_able */
 
12173         0,                      /* 07 bios_scan */
 
12174         0,                      /* 08 scam_tolerant */
 
12175         1,                      /* 09 adapter_scsi_id */
 
12176         1,                      /*    bios_boot_delay */
 
12177         1,                      /* 10 scsi_reset_delay */
 
12178         1,                      /*    bios_id_lun */
 
12179         1,                      /* 11 termination_se */
 
12180         1,                      /*    termination_lvd */
 
12181         0,                      /* 12 bios_ctrl */
 
12182         0,                      /* 13 sdtr_speed2 */
 
12183         0,                      /* 14 sdtr_speed3 */
 
12184         1,                      /* 15 max_host_qng */
 
12185         1,                      /*    max_dvc_qng */
 
12186         0,                      /* 16 dvc_cntl */
 
12187         0,                      /* 17 sdtr_speed4 */
 
12188         0,                      /* 18 serial_number_word1 */
 
12189         0,                      /* 19 serial_number_word2 */
 
12190         0,                      /* 20 serial_number_word3 */
 
12191         0,                      /* 21 check_sum */
 
12192         {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
 
12193         ,                       /* 22-29 oem_name[16] */
 
12194         0,                      /* 30 dvc_err_code */
 
12195         0,                      /* 31 adv_err_code */
 
12196         0,                      /* 32 adv_err_addr */
 
12197         0,                      /* 33 saved_dvc_err_code */
 
12198         0,                      /* 34 saved_adv_err_code */
 
12199         0,                      /* 35 saved_adv_err_addr */
 
12200         0,                      /* 36 reserved */
 
12201         0,                      /* 37 reserved */
 
12202         0,                      /* 38 reserved */
 
12203         0,                      /* 39 reserved */
 
12204         0,                      /* 40 reserved */
 
12205         0,                      /* 41 reserved */
 
12206         0,                      /* 42 reserved */
 
12207         0,                      /* 43 reserved */
 
12208         0,                      /* 44 reserved */
 
12209         0,                      /* 45 reserved */
 
12210         0,                      /* 46 reserved */
 
12211         0,                      /* 47 reserved */
 
12212         0,                      /* 48 reserved */
 
12213         0,                      /* 49 reserved */
 
12214         0,                      /* 50 reserved */
 
12215         0,                      /* 51 reserved */
 
12216         0,                      /* 52 reserved */
 
12217         0,                      /* 53 reserved */
 
12218         0,                      /* 54 reserved */
 
12219         0,                      /* 55 reserved */
 
12220         0,                      /* 56 cisptr_lsw */
 
12221         0,                      /* 57 cisprt_msw */
 
12222         0,                      /* 58 subsysvid */
 
12223         0,                      /* 59 subsysid */
 
12224         0,                      /* 60 reserved */
 
12225         0,                      /* 61 reserved */
 
12226         0,                      /* 62 reserved */
 
12227         0                       /* 63 reserved */
 
12232  * Wait for EEPROM command to complete
 
12234 static void __devinit AdvWaitEEPCmd(AdvPortAddr iop_base)
 
12238         for (eep_delay_ms = 0; eep_delay_ms < ADV_EEP_DELAY_MS; eep_delay_ms++) {
 
12239                 if (AdvReadWordRegister(iop_base, IOPW_EE_CMD) &
 
12240                     ASC_EEP_CMD_DONE) {
 
12245         if ((AdvReadWordRegister(iop_base, IOPW_EE_CMD) & ASC_EEP_CMD_DONE) ==
 
12251  * Read the EEPROM from specified location
 
12253 static ushort __devinit AdvReadEEPWord(AdvPortAddr iop_base, int eep_word_addr)
 
12255         AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12256                              ASC_EEP_CMD_READ | eep_word_addr);
 
12257         AdvWaitEEPCmd(iop_base);
 
12258         return AdvReadWordRegister(iop_base, IOPW_EE_DATA);
 
12262  * Write the EEPROM from 'cfg_buf'.
 
12265 AdvSet3550EEPConfig(AdvPortAddr iop_base, ADVEEP_3550_CONFIG *cfg_buf)
 
12268         ushort addr, chksum;
 
12269         ushort *charfields;
 
12271         wbuf = (ushort *)cfg_buf;
 
12272         charfields = (ushort *)&ADVEEP_3550_Config_Field_IsChar;
 
12275         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_ABLE);
 
12276         AdvWaitEEPCmd(iop_base);
 
12279          * Write EEPROM from word 0 to word 20.
 
12281         for (addr = ADV_EEP_DVC_CFG_BEGIN;
 
12282              addr < ADV_EEP_DVC_CFG_END; addr++, wbuf++) {
 
12285                 if (*charfields++) {
 
12286                         word = cpu_to_le16(*wbuf);
 
12290                 chksum += *wbuf;        /* Checksum is calculated from word values. */
 
12291                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12292                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12293                                      ASC_EEP_CMD_WRITE | addr);
 
12294                 AdvWaitEEPCmd(iop_base);
 
12295                 mdelay(ADV_EEP_DELAY_MS);
 
12299          * Write EEPROM checksum at word 21.
 
12301         AdvWriteWordRegister(iop_base, IOPW_EE_DATA, chksum);
 
12302         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE | addr);
 
12303         AdvWaitEEPCmd(iop_base);
 
12308          * Write EEPROM OEM name at words 22 to 29.
 
12310         for (addr = ADV_EEP_DVC_CTL_BEGIN;
 
12311              addr < ADV_EEP_MAX_WORD_ADDR; addr++, wbuf++) {
 
12314                 if (*charfields++) {
 
12315                         word = cpu_to_le16(*wbuf);
 
12319                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12320                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12321                                      ASC_EEP_CMD_WRITE | addr);
 
12322                 AdvWaitEEPCmd(iop_base);
 
12324         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_DISABLE);
 
12325         AdvWaitEEPCmd(iop_base);
 
12329  * Write the EEPROM from 'cfg_buf'.
 
12332 AdvSet38C0800EEPConfig(AdvPortAddr iop_base, ADVEEP_38C0800_CONFIG *cfg_buf)
 
12335         ushort *charfields;
 
12336         ushort addr, chksum;
 
12338         wbuf = (ushort *)cfg_buf;
 
12339         charfields = (ushort *)&ADVEEP_38C0800_Config_Field_IsChar;
 
12342         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_ABLE);
 
12343         AdvWaitEEPCmd(iop_base);
 
12346          * Write EEPROM from word 0 to word 20.
 
12348         for (addr = ADV_EEP_DVC_CFG_BEGIN;
 
12349              addr < ADV_EEP_DVC_CFG_END; addr++, wbuf++) {
 
12352                 if (*charfields++) {
 
12353                         word = cpu_to_le16(*wbuf);
 
12357                 chksum += *wbuf;        /* Checksum is calculated from word values. */
 
12358                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12359                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12360                                      ASC_EEP_CMD_WRITE | addr);
 
12361                 AdvWaitEEPCmd(iop_base);
 
12362                 mdelay(ADV_EEP_DELAY_MS);
 
12366          * Write EEPROM checksum at word 21.
 
12368         AdvWriteWordRegister(iop_base, IOPW_EE_DATA, chksum);
 
12369         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE | addr);
 
12370         AdvWaitEEPCmd(iop_base);
 
12375          * Write EEPROM OEM name at words 22 to 29.
 
12377         for (addr = ADV_EEP_DVC_CTL_BEGIN;
 
12378              addr < ADV_EEP_MAX_WORD_ADDR; addr++, wbuf++) {
 
12381                 if (*charfields++) {
 
12382                         word = cpu_to_le16(*wbuf);
 
12386                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12387                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12388                                      ASC_EEP_CMD_WRITE | addr);
 
12389                 AdvWaitEEPCmd(iop_base);
 
12391         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_DISABLE);
 
12392         AdvWaitEEPCmd(iop_base);
 
12396  * Write the EEPROM from 'cfg_buf'.
 
12399 AdvSet38C1600EEPConfig(AdvPortAddr iop_base, ADVEEP_38C1600_CONFIG *cfg_buf)
 
12402         ushort *charfields;
 
12403         ushort addr, chksum;
 
12405         wbuf = (ushort *)cfg_buf;
 
12406         charfields = (ushort *)&ADVEEP_38C1600_Config_Field_IsChar;
 
12409         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_ABLE);
 
12410         AdvWaitEEPCmd(iop_base);
 
12413          * Write EEPROM from word 0 to word 20.
 
12415         for (addr = ADV_EEP_DVC_CFG_BEGIN;
 
12416              addr < ADV_EEP_DVC_CFG_END; addr++, wbuf++) {
 
12419                 if (*charfields++) {
 
12420                         word = cpu_to_le16(*wbuf);
 
12424                 chksum += *wbuf;        /* Checksum is calculated from word values. */
 
12425                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12426                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12427                                      ASC_EEP_CMD_WRITE | addr);
 
12428                 AdvWaitEEPCmd(iop_base);
 
12429                 mdelay(ADV_EEP_DELAY_MS);
 
12433          * Write EEPROM checksum at word 21.
 
12435         AdvWriteWordRegister(iop_base, IOPW_EE_DATA, chksum);
 
12436         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE | addr);
 
12437         AdvWaitEEPCmd(iop_base);
 
12442          * Write EEPROM OEM name at words 22 to 29.
 
12444         for (addr = ADV_EEP_DVC_CTL_BEGIN;
 
12445              addr < ADV_EEP_MAX_WORD_ADDR; addr++, wbuf++) {
 
12448                 if (*charfields++) {
 
12449                         word = cpu_to_le16(*wbuf);
 
12453                 AdvWriteWordRegister(iop_base, IOPW_EE_DATA, word);
 
12454                 AdvWriteWordRegister(iop_base, IOPW_EE_CMD,
 
12455                                      ASC_EEP_CMD_WRITE | addr);
 
12456                 AdvWaitEEPCmd(iop_base);
 
12458         AdvWriteWordRegister(iop_base, IOPW_EE_CMD, ASC_EEP_CMD_WRITE_DISABLE);
 
12459         AdvWaitEEPCmd(iop_base);
 
12463  * Read EEPROM configuration into the specified buffer.
 
12465  * Return a checksum based on the EEPROM configuration read.
 
12467 static ushort __devinit
 
12468 AdvGet3550EEPConfig(AdvPortAddr iop_base, ADVEEP_3550_CONFIG *cfg_buf)
 
12470         ushort wval, chksum;
 
12473         ushort *charfields;
 
12475         charfields = (ushort *)&ADVEEP_3550_Config_Field_IsChar;
 
12476         wbuf = (ushort *)cfg_buf;
 
12479         for (eep_addr = ADV_EEP_DVC_CFG_BEGIN;
 
12480              eep_addr < ADV_EEP_DVC_CFG_END; eep_addr++, wbuf++) {
 
12481                 wval = AdvReadEEPWord(iop_base, eep_addr);
 
12482                 chksum += wval; /* Checksum is calculated from word values. */
 
12483                 if (*charfields++) {
 
12484                         *wbuf = le16_to_cpu(wval);
 
12489         /* Read checksum word. */
 
12490         *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12494         /* Read rest of EEPROM not covered by the checksum. */
 
12495         for (eep_addr = ADV_EEP_DVC_CTL_BEGIN;
 
12496              eep_addr < ADV_EEP_MAX_WORD_ADDR; eep_addr++, wbuf++) {
 
12497                 *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12498                 if (*charfields++) {
 
12499                         *wbuf = le16_to_cpu(*wbuf);
 
12506  * Read EEPROM configuration into the specified buffer.
 
12508  * Return a checksum based on the EEPROM configuration read.
 
12510 static ushort __devinit
 
12511 AdvGet38C0800EEPConfig(AdvPortAddr iop_base, ADVEEP_38C0800_CONFIG *cfg_buf)
 
12513         ushort wval, chksum;
 
12516         ushort *charfields;
 
12518         charfields = (ushort *)&ADVEEP_38C0800_Config_Field_IsChar;
 
12519         wbuf = (ushort *)cfg_buf;
 
12522         for (eep_addr = ADV_EEP_DVC_CFG_BEGIN;
 
12523              eep_addr < ADV_EEP_DVC_CFG_END; eep_addr++, wbuf++) {
 
12524                 wval = AdvReadEEPWord(iop_base, eep_addr);
 
12525                 chksum += wval; /* Checksum is calculated from word values. */
 
12526                 if (*charfields++) {
 
12527                         *wbuf = le16_to_cpu(wval);
 
12532         /* Read checksum word. */
 
12533         *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12537         /* Read rest of EEPROM not covered by the checksum. */
 
12538         for (eep_addr = ADV_EEP_DVC_CTL_BEGIN;
 
12539              eep_addr < ADV_EEP_MAX_WORD_ADDR; eep_addr++, wbuf++) {
 
12540                 *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12541                 if (*charfields++) {
 
12542                         *wbuf = le16_to_cpu(*wbuf);
 
12549  * Read EEPROM configuration into the specified buffer.
 
12551  * Return a checksum based on the EEPROM configuration read.
 
12553 static ushort __devinit
 
12554 AdvGet38C1600EEPConfig(AdvPortAddr iop_base, ADVEEP_38C1600_CONFIG *cfg_buf)
 
12556         ushort wval, chksum;
 
12559         ushort *charfields;
 
12561         charfields = (ushort *)&ADVEEP_38C1600_Config_Field_IsChar;
 
12562         wbuf = (ushort *)cfg_buf;
 
12565         for (eep_addr = ADV_EEP_DVC_CFG_BEGIN;
 
12566              eep_addr < ADV_EEP_DVC_CFG_END; eep_addr++, wbuf++) {
 
12567                 wval = AdvReadEEPWord(iop_base, eep_addr);
 
12568                 chksum += wval; /* Checksum is calculated from word values. */
 
12569                 if (*charfields++) {
 
12570                         *wbuf = le16_to_cpu(wval);
 
12575         /* Read checksum word. */
 
12576         *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12580         /* Read rest of EEPROM not covered by the checksum. */
 
12581         for (eep_addr = ADV_EEP_DVC_CTL_BEGIN;
 
12582              eep_addr < ADV_EEP_MAX_WORD_ADDR; eep_addr++, wbuf++) {
 
12583                 *wbuf = AdvReadEEPWord(iop_base, eep_addr);
 
12584                 if (*charfields++) {
 
12585                         *wbuf = le16_to_cpu(*wbuf);
 
12592  * Read the board's EEPROM configuration. Set fields in ADV_DVC_VAR and
 
12593  * ADV_DVC_CFG based on the EEPROM settings. The chip is stopped while
 
12594  * all of this is done.
 
12596  * On failure set the ADV_DVC_VAR field 'err_code' and return ADV_ERROR.
 
12598  * For a non-fatal error return a warning code. If there are no warnings
 
12599  * then 0 is returned.
 
12601  * Note: Chip is stopped on entry.
 
12603 static int __devinit AdvInitFrom3550EEP(ADV_DVC_VAR *asc_dvc)
 
12605         AdvPortAddr iop_base;
 
12607         ADVEEP_3550_CONFIG eep_config;
 
12609         iop_base = asc_dvc->iop_base;
 
12614          * Read the board's EEPROM configuration.
 
12616          * Set default values if a bad checksum is found.
 
12618         if (AdvGet3550EEPConfig(iop_base, &eep_config) != eep_config.check_sum) {
 
12619                 warn_code |= ASC_WARN_EEPROM_CHKSUM;
 
12622                  * Set EEPROM default values.
 
12624                 memcpy(&eep_config, &Default_3550_EEPROM_Config,
 
12625                         sizeof(ADVEEP_3550_CONFIG));
 
12628                  * Assume the 6 byte board serial number that was read from
 
12629                  * EEPROM is correct even if the EEPROM checksum failed.
 
12631                 eep_config.serial_number_word3 =
 
12632                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 1);
 
12634                 eep_config.serial_number_word2 =
 
12635                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 2);
 
12637                 eep_config.serial_number_word1 =
 
12638                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 3);
 
12640                 AdvSet3550EEPConfig(iop_base, &eep_config);
 
12643          * Set ASC_DVC_VAR and ASC_DVC_CFG variables from the
 
12644          * EEPROM configuration that was read.
 
12646          * This is the mapping of EEPROM fields to Adv Library fields.
 
12648         asc_dvc->wdtr_able = eep_config.wdtr_able;
 
12649         asc_dvc->sdtr_able = eep_config.sdtr_able;
 
12650         asc_dvc->ultra_able = eep_config.ultra_able;
 
12651         asc_dvc->tagqng_able = eep_config.tagqng_able;
 
12652         asc_dvc->cfg->disc_enable = eep_config.disc_enable;
 
12653         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
12654         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
12655         asc_dvc->chip_scsi_id = (eep_config.adapter_scsi_id & ADV_MAX_TID);
 
12656         asc_dvc->start_motor = eep_config.start_motor;
 
12657         asc_dvc->scsi_reset_wait = eep_config.scsi_reset_delay;
 
12658         asc_dvc->bios_ctrl = eep_config.bios_ctrl;
 
12659         asc_dvc->no_scam = eep_config.scam_tolerant;
 
12660         asc_dvc->cfg->serial1 = eep_config.serial_number_word1;
 
12661         asc_dvc->cfg->serial2 = eep_config.serial_number_word2;
 
12662         asc_dvc->cfg->serial3 = eep_config.serial_number_word3;
 
12665          * Set the host maximum queuing (max. 253, min. 16) and the per device
 
12666          * maximum queuing (max. 63, min. 4).
 
12668         if (eep_config.max_host_qng > ASC_DEF_MAX_HOST_QNG) {
 
12669                 eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
12670         } else if (eep_config.max_host_qng < ASC_DEF_MIN_HOST_QNG) {
 
12671                 /* If the value is zero, assume it is uninitialized. */
 
12672                 if (eep_config.max_host_qng == 0) {
 
12673                         eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
12675                         eep_config.max_host_qng = ASC_DEF_MIN_HOST_QNG;
 
12679         if (eep_config.max_dvc_qng > ASC_DEF_MAX_DVC_QNG) {
 
12680                 eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
12681         } else if (eep_config.max_dvc_qng < ASC_DEF_MIN_DVC_QNG) {
 
12682                 /* If the value is zero, assume it is uninitialized. */
 
12683                 if (eep_config.max_dvc_qng == 0) {
 
12684                         eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
12686                         eep_config.max_dvc_qng = ASC_DEF_MIN_DVC_QNG;
 
12691          * If 'max_dvc_qng' is greater than 'max_host_qng', then
 
12692          * set 'max_dvc_qng' to 'max_host_qng'.
 
12694         if (eep_config.max_dvc_qng > eep_config.max_host_qng) {
 
12695                 eep_config.max_dvc_qng = eep_config.max_host_qng;
 
12699          * Set ADV_DVC_VAR 'max_host_qng' and ADV_DVC_VAR 'max_dvc_qng'
 
12700          * values based on possibly adjusted EEPROM values.
 
12702         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
12703         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
12706          * If the EEPROM 'termination' field is set to automatic (0), then set
 
12707          * the ADV_DVC_CFG 'termination' field to automatic also.
 
12709          * If the termination is specified with a non-zero 'termination'
 
12710          * value check that a legal value is set and set the ADV_DVC_CFG
 
12711          * 'termination' field appropriately.
 
12713         if (eep_config.termination == 0) {
 
12714                 asc_dvc->cfg->termination = 0;  /* auto termination */
 
12716                 /* Enable manual control with low off / high off. */
 
12717                 if (eep_config.termination == 1) {
 
12718                         asc_dvc->cfg->termination = TERM_CTL_SEL;
 
12720                         /* Enable manual control with low off / high on. */
 
12721                 } else if (eep_config.termination == 2) {
 
12722                         asc_dvc->cfg->termination = TERM_CTL_SEL | TERM_CTL_H;
 
12724                         /* Enable manual control with low on / high on. */
 
12725                 } else if (eep_config.termination == 3) {
 
12726                         asc_dvc->cfg->termination =
 
12727                             TERM_CTL_SEL | TERM_CTL_H | TERM_CTL_L;
 
12730                          * The EEPROM 'termination' field contains a bad value. Use
 
12731                          * automatic termination instead.
 
12733                         asc_dvc->cfg->termination = 0;
 
12734                         warn_code |= ASC_WARN_EEPROM_TERMINATION;
 
12742  * Read the board's EEPROM configuration. Set fields in ADV_DVC_VAR and
 
12743  * ADV_DVC_CFG based on the EEPROM settings. The chip is stopped while
 
12744  * all of this is done.
 
12746  * On failure set the ADV_DVC_VAR field 'err_code' and return ADV_ERROR.
 
12748  * For a non-fatal error return a warning code. If there are no warnings
 
12749  * then 0 is returned.
 
12751  * Note: Chip is stopped on entry.
 
12753 static int __devinit AdvInitFrom38C0800EEP(ADV_DVC_VAR *asc_dvc)
 
12755         AdvPortAddr iop_base;
 
12757         ADVEEP_38C0800_CONFIG eep_config;
 
12758         uchar tid, termination;
 
12759         ushort sdtr_speed = 0;
 
12761         iop_base = asc_dvc->iop_base;
 
12766          * Read the board's EEPROM configuration.
 
12768          * Set default values if a bad checksum is found.
 
12770         if (AdvGet38C0800EEPConfig(iop_base, &eep_config) !=
 
12771             eep_config.check_sum) {
 
12772                 warn_code |= ASC_WARN_EEPROM_CHKSUM;
 
12775                  * Set EEPROM default values.
 
12777                 memcpy(&eep_config, &Default_38C0800_EEPROM_Config,
 
12778                         sizeof(ADVEEP_38C0800_CONFIG));
 
12781                  * Assume the 6 byte board serial number that was read from
 
12782                  * EEPROM is correct even if the EEPROM checksum failed.
 
12784                 eep_config.serial_number_word3 =
 
12785                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 1);
 
12787                 eep_config.serial_number_word2 =
 
12788                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 2);
 
12790                 eep_config.serial_number_word1 =
 
12791                     AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 3);
 
12793                 AdvSet38C0800EEPConfig(iop_base, &eep_config);
 
12796          * Set ADV_DVC_VAR and ADV_DVC_CFG variables from the
 
12797          * EEPROM configuration that was read.
 
12799          * This is the mapping of EEPROM fields to Adv Library fields.
 
12801         asc_dvc->wdtr_able = eep_config.wdtr_able;
 
12802         asc_dvc->sdtr_speed1 = eep_config.sdtr_speed1;
 
12803         asc_dvc->sdtr_speed2 = eep_config.sdtr_speed2;
 
12804         asc_dvc->sdtr_speed3 = eep_config.sdtr_speed3;
 
12805         asc_dvc->sdtr_speed4 = eep_config.sdtr_speed4;
 
12806         asc_dvc->tagqng_able = eep_config.tagqng_able;
 
12807         asc_dvc->cfg->disc_enable = eep_config.disc_enable;
 
12808         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
12809         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
12810         asc_dvc->chip_scsi_id = (eep_config.adapter_scsi_id & ADV_MAX_TID);
 
12811         asc_dvc->start_motor = eep_config.start_motor;
 
12812         asc_dvc->scsi_reset_wait = eep_config.scsi_reset_delay;
 
12813         asc_dvc->bios_ctrl = eep_config.bios_ctrl;
 
12814         asc_dvc->no_scam = eep_config.scam_tolerant;
 
12815         asc_dvc->cfg->serial1 = eep_config.serial_number_word1;
 
12816         asc_dvc->cfg->serial2 = eep_config.serial_number_word2;
 
12817         asc_dvc->cfg->serial3 = eep_config.serial_number_word3;
 
12820          * For every Target ID if any of its 'sdtr_speed[1234]' bits
 
12821          * are set, then set an 'sdtr_able' bit for it.
 
12823         asc_dvc->sdtr_able = 0;
 
12824         for (tid = 0; tid <= ADV_MAX_TID; tid++) {
 
12826                         sdtr_speed = asc_dvc->sdtr_speed1;
 
12827                 } else if (tid == 4) {
 
12828                         sdtr_speed = asc_dvc->sdtr_speed2;
 
12829                 } else if (tid == 8) {
 
12830                         sdtr_speed = asc_dvc->sdtr_speed3;
 
12831                 } else if (tid == 12) {
 
12832                         sdtr_speed = asc_dvc->sdtr_speed4;
 
12834                 if (sdtr_speed & ADV_MAX_TID) {
 
12835                         asc_dvc->sdtr_able |= (1 << tid);
 
12841          * Set the host maximum queuing (max. 253, min. 16) and the per device
 
12842          * maximum queuing (max. 63, min. 4).
 
12844         if (eep_config.max_host_qng > ASC_DEF_MAX_HOST_QNG) {
 
12845                 eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
12846         } else if (eep_config.max_host_qng < ASC_DEF_MIN_HOST_QNG) {
 
12847                 /* If the value is zero, assume it is uninitialized. */
 
12848                 if (eep_config.max_host_qng == 0) {
 
12849                         eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
12851                         eep_config.max_host_qng = ASC_DEF_MIN_HOST_QNG;
 
12855         if (eep_config.max_dvc_qng > ASC_DEF_MAX_DVC_QNG) {
 
12856                 eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
12857         } else if (eep_config.max_dvc_qng < ASC_DEF_MIN_DVC_QNG) {
 
12858                 /* If the value is zero, assume it is uninitialized. */
 
12859                 if (eep_config.max_dvc_qng == 0) {
 
12860                         eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
12862                         eep_config.max_dvc_qng = ASC_DEF_MIN_DVC_QNG;
 
12867          * If 'max_dvc_qng' is greater than 'max_host_qng', then
 
12868          * set 'max_dvc_qng' to 'max_host_qng'.
 
12870         if (eep_config.max_dvc_qng > eep_config.max_host_qng) {
 
12871                 eep_config.max_dvc_qng = eep_config.max_host_qng;
 
12875          * Set ADV_DVC_VAR 'max_host_qng' and ADV_DVC_VAR 'max_dvc_qng'
 
12876          * values based on possibly adjusted EEPROM values.
 
12878         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
12879         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
12882          * If the EEPROM 'termination' field is set to automatic (0), then set
 
12883          * the ADV_DVC_CFG 'termination' field to automatic also.
 
12885          * If the termination is specified with a non-zero 'termination'
 
12886          * value check that a legal value is set and set the ADV_DVC_CFG
 
12887          * 'termination' field appropriately.
 
12889         if (eep_config.termination_se == 0) {
 
12890                 termination = 0;        /* auto termination for SE */
 
12892                 /* Enable manual control with low off / high off. */
 
12893                 if (eep_config.termination_se == 1) {
 
12896                         /* Enable manual control with low off / high on. */
 
12897                 } else if (eep_config.termination_se == 2) {
 
12898                         termination = TERM_SE_HI;
 
12900                         /* Enable manual control with low on / high on. */
 
12901                 } else if (eep_config.termination_se == 3) {
 
12902                         termination = TERM_SE;
 
12905                          * The EEPROM 'termination_se' field contains a bad value.
 
12906                          * Use automatic termination instead.
 
12909                         warn_code |= ASC_WARN_EEPROM_TERMINATION;
 
12913         if (eep_config.termination_lvd == 0) {
 
12914                 asc_dvc->cfg->termination = termination;        /* auto termination for LVD */
 
12916                 /* Enable manual control with low off / high off. */
 
12917                 if (eep_config.termination_lvd == 1) {
 
12918                         asc_dvc->cfg->termination = termination;
 
12920                         /* Enable manual control with low off / high on. */
 
12921                 } else if (eep_config.termination_lvd == 2) {
 
12922                         asc_dvc->cfg->termination = termination | TERM_LVD_HI;
 
12924                         /* Enable manual control with low on / high on. */
 
12925                 } else if (eep_config.termination_lvd == 3) {
 
12926                         asc_dvc->cfg->termination = termination | TERM_LVD;
 
12929                          * The EEPROM 'termination_lvd' field contains a bad value.
 
12930                          * Use automatic termination instead.
 
12932                         asc_dvc->cfg->termination = termination;
 
12933                         warn_code |= ASC_WARN_EEPROM_TERMINATION;
 
12941  * Read the board's EEPROM configuration. Set fields in ASC_DVC_VAR and
 
12942  * ASC_DVC_CFG based on the EEPROM settings. The chip is stopped while
 
12943  * all of this is done.
 
12945  * On failure set the ASC_DVC_VAR field 'err_code' and return ADV_ERROR.
 
12947  * For a non-fatal error return a warning code. If there are no warnings
 
12948  * then 0 is returned.
 
12950  * Note: Chip is stopped on entry.
 
12952 static int __devinit AdvInitFrom38C1600EEP(ADV_DVC_VAR *asc_dvc)
 
12954         AdvPortAddr iop_base;
 
12956         ADVEEP_38C1600_CONFIG eep_config;
 
12957         uchar tid, termination;
 
12958         ushort sdtr_speed = 0;
 
12960         iop_base = asc_dvc->iop_base;
 
12965          * Read the board's EEPROM configuration.
 
12967          * Set default values if a bad checksum is found.
 
12969         if (AdvGet38C1600EEPConfig(iop_base, &eep_config) !=
 
12970             eep_config.check_sum) {
 
12971                 struct pci_dev *pdev = adv_dvc_to_pdev(asc_dvc);
 
12972                 warn_code |= ASC_WARN_EEPROM_CHKSUM;
 
12975                  * Set EEPROM default values.
 
12977                 memcpy(&eep_config, &Default_38C1600_EEPROM_Config,
 
12978                         sizeof(ADVEEP_38C1600_CONFIG));
 
12980                 if (PCI_FUNC(pdev->devfn) != 0) {
 
12983                          * Disable Bit 14 (BIOS_ENABLE) to fix SPARC Ultra 60
 
12984                          * and old Mac system booting problem. The Expansion
 
12985                          * ROM must be disabled in Function 1 for these systems
 
12987                         eep_config.cfg_lsw &= ~ADV_EEPROM_BIOS_ENABLE;
 
12989                          * Clear the INTAB (bit 11) if the GPIO 0 input
 
12990                          * indicates the Function 1 interrupt line is wired
 
12993                          * Set/Clear Bit 11 (INTAB) from the GPIO bit 0 input:
 
12994                          *   1 - Function 1 interrupt line wired to INT A.
 
12995                          *   0 - Function 1 interrupt line wired to INT B.
 
12997                          * Note: Function 0 is always wired to INTA.
 
12998                          * Put all 5 GPIO bits in input mode and then read
 
12999                          * their input values.
 
13001                         AdvWriteByteRegister(iop_base, IOPB_GPIO_CNTL, 0);
 
13002                         ints = AdvReadByteRegister(iop_base, IOPB_GPIO_DATA);
 
13003                         if ((ints & 0x01) == 0)
 
13004                                 eep_config.cfg_lsw &= ~ADV_EEPROM_INTAB;
 
13008                  * Assume the 6 byte board serial number that was read from
 
13009                  * EEPROM is correct even if the EEPROM checksum failed.
 
13011                 eep_config.serial_number_word3 =
 
13012                         AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 1);
 
13013                 eep_config.serial_number_word2 =
 
13014                         AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 2);
 
13015                 eep_config.serial_number_word1 =
 
13016                         AdvReadEEPWord(iop_base, ADV_EEP_DVC_CFG_END - 3);
 
13018                 AdvSet38C1600EEPConfig(iop_base, &eep_config);
 
13022          * Set ASC_DVC_VAR and ASC_DVC_CFG variables from the
 
13023          * EEPROM configuration that was read.
 
13025          * This is the mapping of EEPROM fields to Adv Library fields.
 
13027         asc_dvc->wdtr_able = eep_config.wdtr_able;
 
13028         asc_dvc->sdtr_speed1 = eep_config.sdtr_speed1;
 
13029         asc_dvc->sdtr_speed2 = eep_config.sdtr_speed2;
 
13030         asc_dvc->sdtr_speed3 = eep_config.sdtr_speed3;
 
13031         asc_dvc->sdtr_speed4 = eep_config.sdtr_speed4;
 
13032         asc_dvc->ppr_able = 0;
 
13033         asc_dvc->tagqng_able = eep_config.tagqng_able;
 
13034         asc_dvc->cfg->disc_enable = eep_config.disc_enable;
 
13035         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
13036         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
13037         asc_dvc->chip_scsi_id = (eep_config.adapter_scsi_id & ASC_MAX_TID);
 
13038         asc_dvc->start_motor = eep_config.start_motor;
 
13039         asc_dvc->scsi_reset_wait = eep_config.scsi_reset_delay;
 
13040         asc_dvc->bios_ctrl = eep_config.bios_ctrl;
 
13041         asc_dvc->no_scam = eep_config.scam_tolerant;
 
13044          * For every Target ID if any of its 'sdtr_speed[1234]' bits
 
13045          * are set, then set an 'sdtr_able' bit for it.
 
13047         asc_dvc->sdtr_able = 0;
 
13048         for (tid = 0; tid <= ASC_MAX_TID; tid++) {
 
13050                         sdtr_speed = asc_dvc->sdtr_speed1;
 
13051                 } else if (tid == 4) {
 
13052                         sdtr_speed = asc_dvc->sdtr_speed2;
 
13053                 } else if (tid == 8) {
 
13054                         sdtr_speed = asc_dvc->sdtr_speed3;
 
13055                 } else if (tid == 12) {
 
13056                         sdtr_speed = asc_dvc->sdtr_speed4;
 
13058                 if (sdtr_speed & ASC_MAX_TID) {
 
13059                         asc_dvc->sdtr_able |= (1 << tid);
 
13065          * Set the host maximum queuing (max. 253, min. 16) and the per device
 
13066          * maximum queuing (max. 63, min. 4).
 
13068         if (eep_config.max_host_qng > ASC_DEF_MAX_HOST_QNG) {
 
13069                 eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
13070         } else if (eep_config.max_host_qng < ASC_DEF_MIN_HOST_QNG) {
 
13071                 /* If the value is zero, assume it is uninitialized. */
 
13072                 if (eep_config.max_host_qng == 0) {
 
13073                         eep_config.max_host_qng = ASC_DEF_MAX_HOST_QNG;
 
13075                         eep_config.max_host_qng = ASC_DEF_MIN_HOST_QNG;
 
13079         if (eep_config.max_dvc_qng > ASC_DEF_MAX_DVC_QNG) {
 
13080                 eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
13081         } else if (eep_config.max_dvc_qng < ASC_DEF_MIN_DVC_QNG) {
 
13082                 /* If the value is zero, assume it is uninitialized. */
 
13083                 if (eep_config.max_dvc_qng == 0) {
 
13084                         eep_config.max_dvc_qng = ASC_DEF_MAX_DVC_QNG;
 
13086                         eep_config.max_dvc_qng = ASC_DEF_MIN_DVC_QNG;
 
13091          * If 'max_dvc_qng' is greater than 'max_host_qng', then
 
13092          * set 'max_dvc_qng' to 'max_host_qng'.
 
13094         if (eep_config.max_dvc_qng > eep_config.max_host_qng) {
 
13095                 eep_config.max_dvc_qng = eep_config.max_host_qng;
 
13099          * Set ASC_DVC_VAR 'max_host_qng' and ASC_DVC_VAR 'max_dvc_qng'
 
13100          * values based on possibly adjusted EEPROM values.
 
13102         asc_dvc->max_host_qng = eep_config.max_host_qng;
 
13103         asc_dvc->max_dvc_qng = eep_config.max_dvc_qng;
 
13106          * If the EEPROM 'termination' field is set to automatic (0), then set
 
13107          * the ASC_DVC_CFG 'termination' field to automatic also.
 
13109          * If the termination is specified with a non-zero 'termination'
 
13110          * value check that a legal value is set and set the ASC_DVC_CFG
 
13111          * 'termination' field appropriately.
 
13113         if (eep_config.termination_se == 0) {
 
13114                 termination = 0;        /* auto termination for SE */
 
13116                 /* Enable manual control with low off / high off. */
 
13117                 if (eep_config.termination_se == 1) {
 
13120                         /* Enable manual control with low off / high on. */
 
13121                 } else if (eep_config.termination_se == 2) {
 
13122                         termination = TERM_SE_HI;
 
13124                         /* Enable manual control with low on / high on. */
 
13125                 } else if (eep_config.termination_se == 3) {
 
13126                         termination = TERM_SE;
 
13129                          * The EEPROM 'termination_se' field contains a bad value.
 
13130                          * Use automatic termination instead.
 
13133                         warn_code |= ASC_WARN_EEPROM_TERMINATION;
 
13137         if (eep_config.termination_lvd == 0) {
 
13138                 asc_dvc->cfg->termination = termination;        /* auto termination for LVD */
 
13140                 /* Enable manual control with low off / high off. */
 
13141                 if (eep_config.termination_lvd == 1) {
 
13142                         asc_dvc->cfg->termination = termination;
 
13144                         /* Enable manual control with low off / high on. */
 
13145                 } else if (eep_config.termination_lvd == 2) {
 
13146                         asc_dvc->cfg->termination = termination | TERM_LVD_HI;
 
13148                         /* Enable manual control with low on / high on. */
 
13149                 } else if (eep_config.termination_lvd == 3) {
 
13150                         asc_dvc->cfg->termination = termination | TERM_LVD;
 
13153                          * The EEPROM 'termination_lvd' field contains a bad value.
 
13154                          * Use automatic termination instead.
 
13156                         asc_dvc->cfg->termination = termination;
 
13157                         warn_code |= ASC_WARN_EEPROM_TERMINATION;
 
13165  * Initialize the ADV_DVC_VAR structure.
 
13167  * On failure set the ADV_DVC_VAR field 'err_code' and return ADV_ERROR.
 
13169  * For a non-fatal error return a warning code. If there are no warnings
 
13170  * then 0 is returned.
 
13172 static int __devinit
 
13173 AdvInitGetConfig(struct pci_dev *pdev, struct Scsi_Host *shost)
 
13175         struct asc_board *board = shost_priv(shost);
 
13176         ADV_DVC_VAR *asc_dvc = &board->dvc_var.adv_dvc_var;
 
13177         unsigned short warn_code = 0;
 
13178         AdvPortAddr iop_base = asc_dvc->iop_base;
 
13182         asc_dvc->err_code = 0;
 
13185          * Save the state of the PCI Configuration Command Register
 
13186          * "Parity Error Response Control" Bit. If the bit is clear (0),
 
13187          * in AdvInitAsc3550/38C0800Driver() tell the microcode to ignore
 
13188          * DMA parity errors.
 
13190         asc_dvc->cfg->control_flag = 0;
 
13191         pci_read_config_word(pdev, PCI_COMMAND, &cmd);
 
13192         if ((cmd & PCI_COMMAND_PARITY) == 0)
 
13193                 asc_dvc->cfg->control_flag |= CONTROL_FLAG_IGNORE_PERR;
 
13195         asc_dvc->cfg->chip_version =
 
13196             AdvGetChipVersion(iop_base, asc_dvc->bus_type);
 
13198         ASC_DBG(1, "iopb_chip_id_1: 0x%x 0x%x\n",
 
13199                  (ushort)AdvReadByteRegister(iop_base, IOPB_CHIP_ID_1),
 
13200                  (ushort)ADV_CHIP_ID_BYTE);
 
13202         ASC_DBG(1, "iopw_chip_id_0: 0x%x 0x%x\n",
 
13203                  (ushort)AdvReadWordRegister(iop_base, IOPW_CHIP_ID_0),
 
13204                  (ushort)ADV_CHIP_ID_WORD);
 
13207          * Reset the chip to start and allow register writes.
 
13209         if (AdvFindSignature(iop_base) == 0) {
 
13210                 asc_dvc->err_code = ASC_IERR_BAD_SIGNATURE;
 
13214                  * The caller must set 'chip_type' to a valid setting.
 
13216                 if (asc_dvc->chip_type != ADV_CHIP_ASC3550 &&
 
13217                     asc_dvc->chip_type != ADV_CHIP_ASC38C0800 &&
 
13218                     asc_dvc->chip_type != ADV_CHIP_ASC38C1600) {
 
13219                         asc_dvc->err_code |= ASC_IERR_BAD_CHIPTYPE;
 
13226                 AdvWriteWordRegister(iop_base, IOPW_CTRL_REG,
 
13227                                      ADV_CTRL_REG_CMD_RESET);
 
13229                 AdvWriteWordRegister(iop_base, IOPW_CTRL_REG,
 
13230                                      ADV_CTRL_REG_CMD_WR_IO_REG);
 
13232                 if (asc_dvc->chip_type == ADV_CHIP_ASC38C1600) {
 
13233                         status = AdvInitFrom38C1600EEP(asc_dvc);
 
13234                 } else if (asc_dvc->chip_type == ADV_CHIP_ASC38C0800) {
 
13235                         status = AdvInitFrom38C0800EEP(asc_dvc);
 
13237                         status = AdvInitFrom3550EEP(asc_dvc);
 
13239                 warn_code |= status;
 
13242         if (warn_code != 0)
 
13243                 shost_printk(KERN_WARNING, shost, "warning: 0x%x\n", warn_code);
 
13245         if (asc_dvc->err_code)
 
13246                 shost_printk(KERN_ERR, shost, "error code 0x%x\n",
 
13247                                 asc_dvc->err_code);
 
13249         return asc_dvc->err_code;
 
13253 static struct scsi_host_template advansys_template = {
 
13254         .proc_name = DRV_NAME,
 
13255 #ifdef CONFIG_PROC_FS
 
13256         .proc_info = advansys_proc_info,
 
13259         .info = advansys_info,
 
13260         .queuecommand = advansys_queuecommand,
 
13261         .eh_bus_reset_handler = advansys_reset,
 
13262         .bios_param = advansys_biosparam,
 
13263         .slave_configure = advansys_slave_configure,
 
13265          * Because the driver may control an ISA adapter 'unchecked_isa_dma'
 
13266          * must be set. The flag will be cleared in advansys_board_found
 
13267          * for non-ISA adapters.
 
13269         .unchecked_isa_dma = 1,
 
13271          * All adapters controlled by this driver are capable of large
 
13272          * scatter-gather lists. According to the mid-level SCSI documentation
 
13273          * this obviates any performance gain provided by setting
 
13274          * 'use_clustering'. But empirically while CPU utilization is increased
 
13275          * by enabling clustering, I/O throughput increases as well.
 
13277         .use_clustering = ENABLE_CLUSTERING,
 
13280 static int __devinit advansys_wide_init_chip(struct Scsi_Host *shost)
 
13282         struct asc_board *board = shost_priv(shost);
 
13283         struct adv_dvc_var *adv_dvc = &board->dvc_var.adv_dvc_var;
 
13285         adv_req_t *reqp = NULL;
 
13288         int warn_code, err_code;
 
13291          * Allocate buffer carrier structures. The total size
 
13292          * is about 4 KB, so allocate all at once.
 
13294         adv_dvc->carrier_buf = kmalloc(ADV_CARRIER_BUFSIZE, GFP_KERNEL);
 
13295         ASC_DBG(1, "carrier_buf 0x%p\n", adv_dvc->carrier_buf);
 
13297         if (!adv_dvc->carrier_buf)
 
13298                 goto kmalloc_failed;
 
13301          * Allocate up to 'max_host_qng' request structures for the Wide
 
13302          * board. The total size is about 16 KB, so allocate all at once.
 
13303          * If the allocation fails decrement and try again.
 
13305         for (req_cnt = adv_dvc->max_host_qng; req_cnt > 0; req_cnt--) {
 
13306                 reqp = kmalloc(sizeof(adv_req_t) * req_cnt, GFP_KERNEL);
 
13308                 ASC_DBG(1, "reqp 0x%p, req_cnt %d, bytes %lu\n", reqp, req_cnt,
 
13309                          (ulong)sizeof(adv_req_t) * req_cnt);
 
13316                 goto kmalloc_failed;
 
13318         adv_dvc->orig_reqp = reqp;
 
13321          * Allocate up to ADV_TOT_SG_BLOCK request structures for
 
13322          * the Wide board. Each structure is about 136 bytes.
 
13324         board->adv_sgblkp = NULL;
 
13325         for (sg_cnt = 0; sg_cnt < ADV_TOT_SG_BLOCK; sg_cnt++) {
 
13326                 sgp = kmalloc(sizeof(adv_sgblk_t), GFP_KERNEL);
 
13331                 sgp->next_sgblkp = board->adv_sgblkp;
 
13332                 board->adv_sgblkp = sgp;
 
13336         ASC_DBG(1, "sg_cnt %d * %lu = %lu bytes\n", sg_cnt, sizeof(adv_sgblk_t),
 
13337                  sizeof(adv_sgblk_t) * sg_cnt);
 
13339         if (!board->adv_sgblkp)
 
13340                 goto kmalloc_failed;
 
13343          * Point 'adv_reqp' to the request structures and
 
13344          * link them together.
 
13347         reqp[req_cnt].next_reqp = NULL;
 
13348         for (; req_cnt > 0; req_cnt--) {
 
13349                 reqp[req_cnt - 1].next_reqp = &reqp[req_cnt];
 
13351         board->adv_reqp = &reqp[0];
 
13353         if (adv_dvc->chip_type == ADV_CHIP_ASC3550) {
 
13354                 ASC_DBG(2, "AdvInitAsc3550Driver()\n");
 
13355                 warn_code = AdvInitAsc3550Driver(adv_dvc);
 
13356         } else if (adv_dvc->chip_type == ADV_CHIP_ASC38C0800) {
 
13357                 ASC_DBG(2, "AdvInitAsc38C0800Driver()\n");
 
13358                 warn_code = AdvInitAsc38C0800Driver(adv_dvc);
 
13360                 ASC_DBG(2, "AdvInitAsc38C1600Driver()\n");
 
13361                 warn_code = AdvInitAsc38C1600Driver(adv_dvc);
 
13363         err_code = adv_dvc->err_code;
 
13365         if (warn_code || err_code) {
 
13366                 shost_printk(KERN_WARNING, shost, "error: warn 0x%x, error "
 
13367                         "0x%x\n", warn_code, err_code);
 
13373         shost_printk(KERN_ERR, shost, "error: kmalloc() failed\n");
 
13374         err_code = ADV_ERROR;
 
13379 static void advansys_wide_free_mem(struct asc_board *board)
 
13381         struct adv_dvc_var *adv_dvc = &board->dvc_var.adv_dvc_var;
 
13382         kfree(adv_dvc->carrier_buf);
 
13383         adv_dvc->carrier_buf = NULL;
 
13384         kfree(adv_dvc->orig_reqp);
 
13385         adv_dvc->orig_reqp = board->adv_reqp = NULL;
 
13386         while (board->adv_sgblkp) {
 
13387                 adv_sgblk_t *sgp = board->adv_sgblkp;
 
13388                 board->adv_sgblkp = sgp->next_sgblkp;
 
13393 static int __devinit advansys_board_found(struct Scsi_Host *shost,
 
13394                                           unsigned int iop, int bus_type)
 
13396         struct pci_dev *pdev;
 
13397         struct asc_board *boardp = shost_priv(shost);
 
13398         ASC_DVC_VAR *asc_dvc_varp = NULL;
 
13399         ADV_DVC_VAR *adv_dvc_varp = NULL;
 
13400         int share_irq, warn_code, ret;
 
13402         pdev = (bus_type == ASC_IS_PCI) ? to_pci_dev(boardp->dev) : NULL;
 
13404         if (ASC_NARROW_BOARD(boardp)) {
 
13405                 ASC_DBG(1, "narrow board\n");
 
13406                 asc_dvc_varp = &boardp->dvc_var.asc_dvc_var;
 
13407                 asc_dvc_varp->bus_type = bus_type;
 
13408                 asc_dvc_varp->drv_ptr = boardp;
 
13409                 asc_dvc_varp->cfg = &boardp->dvc_cfg.asc_dvc_cfg;
 
13410                 asc_dvc_varp->iop_base = iop;
 
13413                 adv_dvc_varp = &boardp->dvc_var.adv_dvc_var;
 
13414                 adv_dvc_varp->drv_ptr = boardp;
 
13415                 adv_dvc_varp->cfg = &boardp->dvc_cfg.adv_dvc_cfg;
 
13416                 if (pdev->device == PCI_DEVICE_ID_ASP_ABP940UW) {
 
13417                         ASC_DBG(1, "wide board ASC-3550\n");
 
13418                         adv_dvc_varp->chip_type = ADV_CHIP_ASC3550;
 
13419                 } else if (pdev->device == PCI_DEVICE_ID_38C0800_REV1) {
 
13420                         ASC_DBG(1, "wide board ASC-38C0800\n");
 
13421                         adv_dvc_varp->chip_type = ADV_CHIP_ASC38C0800;
 
13423                         ASC_DBG(1, "wide board ASC-38C1600\n");
 
13424                         adv_dvc_varp->chip_type = ADV_CHIP_ASC38C1600;
 
13427                 boardp->asc_n_io_port = pci_resource_len(pdev, 1);
 
13428                 boardp->ioremap_addr = ioremap(pci_resource_start(pdev, 1),
 
13429                                                boardp->asc_n_io_port);
 
13430                 if (!boardp->ioremap_addr) {
 
13431                         shost_printk(KERN_ERR, shost, "ioremap(%lx, %d) "
 
13433                                         (long)pci_resource_start(pdev, 1),
 
13434                                         boardp->asc_n_io_port);
 
13438                 adv_dvc_varp->iop_base = (AdvPortAddr)boardp->ioremap_addr;
 
13439                 ASC_DBG(1, "iop_base: 0x%p\n", adv_dvc_varp->iop_base);
 
13442                  * Even though it isn't used to access wide boards, other
 
13443                  * than for the debug line below, save I/O Port address so
 
13444                  * that it can be reported.
 
13446                 boardp->ioport = iop;
 
13448                 ASC_DBG(1, "iopb_chip_id_1 0x%x, iopw_chip_id_0 0x%x\n",
 
13449                                 (ushort)inp(iop + 1), (ushort)inpw(iop));
 
13450 #endif /* CONFIG_PCI */
 
13453 #ifdef CONFIG_PROC_FS
 
13455          * Allocate buffer for printing information from
 
13456          * /proc/scsi/advansys/[0...].
 
13458         boardp->prtbuf = kmalloc(ASC_PRTBUF_SIZE, GFP_KERNEL);
 
13459         if (!boardp->prtbuf) {
 
13460                 shost_printk(KERN_ERR, shost, "kmalloc(%d) returned NULL\n",
 
13465 #endif /* CONFIG_PROC_FS */
 
13467         if (ASC_NARROW_BOARD(boardp)) {
 
13469                  * Set the board bus type and PCI IRQ before
 
13470                  * calling AscInitGetConfig().
 
13472                 switch (asc_dvc_varp->bus_type) {
 
13475                         shost->unchecked_isa_dma = TRUE;
 
13479                         shost->unchecked_isa_dma = FALSE;
 
13483                         shost->unchecked_isa_dma = FALSE;
 
13484                         share_irq = IRQF_SHARED;
 
13486 #endif /* CONFIG_ISA */
 
13489                         shost->unchecked_isa_dma = FALSE;
 
13490                         share_irq = IRQF_SHARED;
 
13492 #endif /* CONFIG_PCI */
 
13494                         shost_printk(KERN_ERR, shost, "unknown adapter type: "
 
13495                                         "%d\n", asc_dvc_varp->bus_type);
 
13496                         shost->unchecked_isa_dma = TRUE;
 
13502                  * NOTE: AscInitGetConfig() may change the board's
 
13503                  * bus_type value. The bus_type value should no
 
13504                  * longer be used. If the bus_type field must be
 
13505                  * referenced only use the bit-wise AND operator "&".
 
13507                 ASC_DBG(2, "AscInitGetConfig()\n");
 
13508                 ret = AscInitGetConfig(shost) ? -ENODEV : 0;
 
13512                  * For Wide boards set PCI information before calling
 
13513                  * AdvInitGetConfig().
 
13515                 shost->unchecked_isa_dma = FALSE;
 
13516                 share_irq = IRQF_SHARED;
 
13517                 ASC_DBG(2, "AdvInitGetConfig()\n");
 
13519                 ret = AdvInitGetConfig(pdev, shost) ? -ENODEV : 0;
 
13520 #endif /* CONFIG_PCI */
 
13524                 goto err_free_proc;
 
13527          * Save the EEPROM configuration so that it can be displayed
 
13528          * from /proc/scsi/advansys/[0...].
 
13530         if (ASC_NARROW_BOARD(boardp)) {
 
13535                  * Set the adapter's target id bit in the 'init_tidmask' field.
 
13537                 boardp->init_tidmask |=
 
13538                     ADV_TID_TO_TIDMASK(asc_dvc_varp->cfg->chip_scsi_id);
 
13541                  * Save EEPROM settings for the board.
 
13543                 ep = &boardp->eep_config.asc_eep;
 
13545                 ep->init_sdtr = asc_dvc_varp->cfg->sdtr_enable;
 
13546                 ep->disc_enable = asc_dvc_varp->cfg->disc_enable;
 
13547                 ep->use_cmd_qng = asc_dvc_varp->cfg->cmd_qng_enabled;
 
13548                 ASC_EEP_SET_DMA_SPD(ep, asc_dvc_varp->cfg->isa_dma_speed);
 
13549                 ep->start_motor = asc_dvc_varp->start_motor;
 
13550                 ep->cntl = asc_dvc_varp->dvc_cntl;
 
13551                 ep->no_scam = asc_dvc_varp->no_scam;
 
13552                 ep->max_total_qng = asc_dvc_varp->max_total_qng;
 
13553                 ASC_EEP_SET_CHIP_ID(ep, asc_dvc_varp->cfg->chip_scsi_id);
 
13554                 /* 'max_tag_qng' is set to the same value for every device. */
 
13555                 ep->max_tag_qng = asc_dvc_varp->cfg->max_tag_qng[0];
 
13556                 ep->adapter_info[0] = asc_dvc_varp->cfg->adapter_info[0];
 
13557                 ep->adapter_info[1] = asc_dvc_varp->cfg->adapter_info[1];
 
13558                 ep->adapter_info[2] = asc_dvc_varp->cfg->adapter_info[2];
 
13559                 ep->adapter_info[3] = asc_dvc_varp->cfg->adapter_info[3];
 
13560                 ep->adapter_info[4] = asc_dvc_varp->cfg->adapter_info[4];
 
13561                 ep->adapter_info[5] = asc_dvc_varp->cfg->adapter_info[5];
 
13564                  * Modify board configuration.
 
13566                 ASC_DBG(2, "AscInitSetConfig()\n");
 
13567                 ret = AscInitSetConfig(pdev, shost) ? -ENODEV : 0;
 
13569                         goto err_free_proc;
 
13571                 ADVEEP_3550_CONFIG *ep_3550;
 
13572                 ADVEEP_38C0800_CONFIG *ep_38C0800;
 
13573                 ADVEEP_38C1600_CONFIG *ep_38C1600;
 
13576                  * Save Wide EEP Configuration Information.
 
13578                 if (adv_dvc_varp->chip_type == ADV_CHIP_ASC3550) {
 
13579                         ep_3550 = &boardp->eep_config.adv_3550_eep;
 
13581                         ep_3550->adapter_scsi_id = adv_dvc_varp->chip_scsi_id;
 
13582                         ep_3550->max_host_qng = adv_dvc_varp->max_host_qng;
 
13583                         ep_3550->max_dvc_qng = adv_dvc_varp->max_dvc_qng;
 
13584                         ep_3550->termination = adv_dvc_varp->cfg->termination;
 
13585                         ep_3550->disc_enable = adv_dvc_varp->cfg->disc_enable;
 
13586                         ep_3550->bios_ctrl = adv_dvc_varp->bios_ctrl;
 
13587                         ep_3550->wdtr_able = adv_dvc_varp->wdtr_able;
 
13588                         ep_3550->sdtr_able = adv_dvc_varp->sdtr_able;
 
13589                         ep_3550->ultra_able = adv_dvc_varp->ultra_able;
 
13590                         ep_3550->tagqng_able = adv_dvc_varp->tagqng_able;
 
13591                         ep_3550->start_motor = adv_dvc_varp->start_motor;
 
13592                         ep_3550->scsi_reset_delay =
 
13593                             adv_dvc_varp->scsi_reset_wait;
 
13594                         ep_3550->serial_number_word1 =
 
13595                             adv_dvc_varp->cfg->serial1;
 
13596                         ep_3550->serial_number_word2 =
 
13597                             adv_dvc_varp->cfg->serial2;
 
13598                         ep_3550->serial_number_word3 =
 
13599                             adv_dvc_varp->cfg->serial3;
 
13600                 } else if (adv_dvc_varp->chip_type == ADV_CHIP_ASC38C0800) {
 
13601                         ep_38C0800 = &boardp->eep_config.adv_38C0800_eep;
 
13603                         ep_38C0800->adapter_scsi_id =
 
13604                             adv_dvc_varp->chip_scsi_id;
 
13605                         ep_38C0800->max_host_qng = adv_dvc_varp->max_host_qng;
 
13606                         ep_38C0800->max_dvc_qng = adv_dvc_varp->max_dvc_qng;
 
13607                         ep_38C0800->termination_lvd =
 
13608                             adv_dvc_varp->cfg->termination;
 
13609                         ep_38C0800->disc_enable =
 
13610                             adv_dvc_varp->cfg->disc_enable;
 
13611                         ep_38C0800->bios_ctrl = adv_dvc_varp->bios_ctrl;
 
13612                         ep_38C0800->wdtr_able = adv_dvc_varp->wdtr_able;
 
13613                         ep_38C0800->tagqng_able = adv_dvc_varp->tagqng_able;
 
13614                         ep_38C0800->sdtr_speed1 = adv_dvc_varp->sdtr_speed1;
 
13615                         ep_38C0800->sdtr_speed2 = adv_dvc_varp->sdtr_speed2;
 
13616                         ep_38C0800->sdtr_speed3 = adv_dvc_varp->sdtr_speed3;
 
13617                         ep_38C0800->sdtr_speed4 = adv_dvc_varp->sdtr_speed4;
 
13618                         ep_38C0800->tagqng_able = adv_dvc_varp->tagqng_able;
 
13619                         ep_38C0800->start_motor = adv_dvc_varp->start_motor;
 
13620                         ep_38C0800->scsi_reset_delay =
 
13621                             adv_dvc_varp->scsi_reset_wait;
 
13622                         ep_38C0800->serial_number_word1 =
 
13623                             adv_dvc_varp->cfg->serial1;
 
13624                         ep_38C0800->serial_number_word2 =
 
13625                             adv_dvc_varp->cfg->serial2;
 
13626                         ep_38C0800->serial_number_word3 =
 
13627                             adv_dvc_varp->cfg->serial3;
 
13629                         ep_38C1600 = &boardp->eep_config.adv_38C1600_eep;
 
13631                         ep_38C1600->adapter_scsi_id =
 
13632                             adv_dvc_varp->chip_scsi_id;
 
13633                         ep_38C1600->max_host_qng = adv_dvc_varp->max_host_qng;
 
13634                         ep_38C1600->max_dvc_qng = adv_dvc_varp->max_dvc_qng;
 
13635                         ep_38C1600->termination_lvd =
 
13636                             adv_dvc_varp->cfg->termination;
 
13637                         ep_38C1600->disc_enable =
 
13638                             adv_dvc_varp->cfg->disc_enable;
 
13639                         ep_38C1600->bios_ctrl = adv_dvc_varp->bios_ctrl;
 
13640                         ep_38C1600->wdtr_able = adv_dvc_varp->wdtr_able;
 
13641                         ep_38C1600->tagqng_able = adv_dvc_varp->tagqng_able;
 
13642                         ep_38C1600->sdtr_speed1 = adv_dvc_varp->sdtr_speed1;
 
13643                         ep_38C1600->sdtr_speed2 = adv_dvc_varp->sdtr_speed2;
 
13644                         ep_38C1600->sdtr_speed3 = adv_dvc_varp->sdtr_speed3;
 
13645                         ep_38C1600->sdtr_speed4 = adv_dvc_varp->sdtr_speed4;
 
13646                         ep_38C1600->tagqng_able = adv_dvc_varp->tagqng_able;
 
13647                         ep_38C1600->start_motor = adv_dvc_varp->start_motor;
 
13648                         ep_38C1600->scsi_reset_delay =
 
13649                             adv_dvc_varp->scsi_reset_wait;
 
13650                         ep_38C1600->serial_number_word1 =
 
13651                             adv_dvc_varp->cfg->serial1;
 
13652                         ep_38C1600->serial_number_word2 =
 
13653                             adv_dvc_varp->cfg->serial2;
 
13654                         ep_38C1600->serial_number_word3 =
 
13655                             adv_dvc_varp->cfg->serial3;
 
13659                  * Set the adapter's target id bit in the 'init_tidmask' field.
 
13661                 boardp->init_tidmask |=
 
13662                     ADV_TID_TO_TIDMASK(adv_dvc_varp->chip_scsi_id);
 
13666          * Channels are numbered beginning with 0. For AdvanSys one host
 
13667          * structure supports one channel. Multi-channel boards have a
 
13668          * separate host structure for each channel.
 
13670         shost->max_channel = 0;
 
13671         if (ASC_NARROW_BOARD(boardp)) {
 
13672                 shost->max_id = ASC_MAX_TID + 1;
 
13673                 shost->max_lun = ASC_MAX_LUN + 1;
 
13674                 shost->max_cmd_len = ASC_MAX_CDB_LEN;
 
13676                 shost->io_port = asc_dvc_varp->iop_base;
 
13677                 boardp->asc_n_io_port = ASC_IOADR_GAP;
 
13678                 shost->this_id = asc_dvc_varp->cfg->chip_scsi_id;
 
13680                 /* Set maximum number of queues the adapter can handle. */
 
13681                 shost->can_queue = asc_dvc_varp->max_total_qng;
 
13683                 shost->max_id = ADV_MAX_TID + 1;
 
13684                 shost->max_lun = ADV_MAX_LUN + 1;
 
13685                 shost->max_cmd_len = ADV_MAX_CDB_LEN;
 
13688                  * Save the I/O Port address and length even though
 
13689                  * I/O ports are not used to access Wide boards.
 
13690                  * Instead the Wide boards are accessed with
 
13691                  * PCI Memory Mapped I/O.
 
13693                 shost->io_port = iop;
 
13695                 shost->this_id = adv_dvc_varp->chip_scsi_id;
 
13697                 /* Set maximum number of queues the adapter can handle. */
 
13698                 shost->can_queue = adv_dvc_varp->max_host_qng;
 
13702          * Following v1.3.89, 'cmd_per_lun' is no longer needed
 
13703          * and should be set to zero.
 
13705          * But because of a bug introduced in v1.3.89 if the driver is
 
13706          * compiled as a module and 'cmd_per_lun' is zero, the Mid-Level
 
13707          * SCSI function 'allocate_device' will panic. To allow the driver
 
13708          * to work as a module in these kernels set 'cmd_per_lun' to 1.
 
13710          * Note: This is wrong.  cmd_per_lun should be set to the depth
 
13711          * you want on untagged devices always.
 
13714         shost->cmd_per_lun = 1;
 
13716             shost->cmd_per_lun = 0;
 
13720          * Set the maximum number of scatter-gather elements the
 
13721          * adapter can handle.
 
13723         if (ASC_NARROW_BOARD(boardp)) {
 
13725                  * Allow two commands with 'sg_tablesize' scatter-gather
 
13726                  * elements to be executed simultaneously. This value is
 
13727                  * the theoretical hardware limit. It may be decreased
 
13730                 shost->sg_tablesize =
 
13731                     (((asc_dvc_varp->max_total_qng - 2) / 2) *
 
13732                      ASC_SG_LIST_PER_Q) + 1;
 
13734                 shost->sg_tablesize = ADV_MAX_SG_LIST;
 
13738          * The value of 'sg_tablesize' can not exceed the SCSI
 
13739          * mid-level driver definition of SG_ALL. SG_ALL also
 
13740          * must not be exceeded, because it is used to define the
 
13741          * size of the scatter-gather table in 'struct asc_sg_head'.
 
13743         if (shost->sg_tablesize > SG_ALL) {
 
13744                 shost->sg_tablesize = SG_ALL;
 
13747         ASC_DBG(1, "sg_tablesize: %d\n", shost->sg_tablesize);
 
13749         /* BIOS start address. */
 
13750         if (ASC_NARROW_BOARD(boardp)) {
 
13751                 shost->base = AscGetChipBiosAddress(asc_dvc_varp->iop_base,
 
13752                                                     asc_dvc_varp->bus_type);
 
13755                  * Fill-in BIOS board variables. The Wide BIOS saves
 
13756                  * information in LRAM that is used by the driver.
 
13758                 AdvReadWordLram(adv_dvc_varp->iop_base,
 
13759                                 BIOS_SIGNATURE, boardp->bios_signature);
 
13760                 AdvReadWordLram(adv_dvc_varp->iop_base,
 
13761                                 BIOS_VERSION, boardp->bios_version);
 
13762                 AdvReadWordLram(adv_dvc_varp->iop_base,
 
13763                                 BIOS_CODESEG, boardp->bios_codeseg);
 
13764                 AdvReadWordLram(adv_dvc_varp->iop_base,
 
13765                                 BIOS_CODELEN, boardp->bios_codelen);
 
13767                 ASC_DBG(1, "bios_signature 0x%x, bios_version 0x%x\n",
 
13768                          boardp->bios_signature, boardp->bios_version);
 
13770                 ASC_DBG(1, "bios_codeseg 0x%x, bios_codelen 0x%x\n",
 
13771                          boardp->bios_codeseg, boardp->bios_codelen);
 
13774                  * If the BIOS saved a valid signature, then fill in
 
13775                  * the BIOS code segment base address.
 
13777                 if (boardp->bios_signature == 0x55AA) {
 
13779                          * Convert x86 realmode code segment to a linear
 
13780                          * address by shifting left 4.
 
13782                         shost->base = ((ulong)boardp->bios_codeseg << 4);
 
13789          * Register Board Resources - I/O Port, DMA, IRQ
 
13792         /* Register DMA Channel for Narrow boards. */
 
13793         shost->dma_channel = NO_ISA_DMA;        /* Default to no ISA DMA. */
 
13795         if (ASC_NARROW_BOARD(boardp)) {
 
13796                 /* Register DMA channel for ISA bus. */
 
13797                 if (asc_dvc_varp->bus_type & ASC_IS_ISA) {
 
13798                         shost->dma_channel = asc_dvc_varp->cfg->isa_dma_channel;
 
13799                         ret = request_dma(shost->dma_channel, DRV_NAME);
 
13801                                 shost_printk(KERN_ERR, shost, "request_dma() "
 
13803                                                 shost->dma_channel, ret);
 
13804                                 goto err_free_proc;
 
13806                         AscEnableIsaDma(shost->dma_channel);
 
13809 #endif /* CONFIG_ISA */
 
13811         /* Register IRQ Number. */
 
13812         ASC_DBG(2, "request_irq(%d, %p)\n", boardp->irq, shost);
 
13814         ret = request_irq(boardp->irq, advansys_interrupt, share_irq,
 
13818                 if (ret == -EBUSY) {
 
13819                         shost_printk(KERN_ERR, shost, "request_irq(): IRQ 0x%x "
 
13820                                         "already in use\n", boardp->irq);
 
13821                 } else if (ret == -EINVAL) {
 
13822                         shost_printk(KERN_ERR, shost, "request_irq(): IRQ 0x%x "
 
13823                                         "not valid\n", boardp->irq);
 
13825                         shost_printk(KERN_ERR, shost, "request_irq(): IRQ 0x%x "
 
13826                                         "failed with %d\n", boardp->irq, ret);
 
13832          * Initialize board RISC chip and enable interrupts.
 
13834         if (ASC_NARROW_BOARD(boardp)) {
 
13835                 ASC_DBG(2, "AscInitAsc1000Driver()\n");
 
13836                 warn_code = AscInitAsc1000Driver(asc_dvc_varp);
 
13838                 if (warn_code || asc_dvc_varp->err_code) {
 
13839                         shost_printk(KERN_ERR, shost, "error: init_state 0x%x, "
 
13840                                         "warn 0x%x, error 0x%x\n",
 
13841                                         asc_dvc_varp->init_state, warn_code,
 
13842                                         asc_dvc_varp->err_code);
 
13843                         if (asc_dvc_varp->err_code)
 
13847                 if (advansys_wide_init_chip(shost))
 
13852                 goto err_free_wide_mem;
 
13854         ASC_DBG_PRT_SCSI_HOST(2, shost);
 
13856         ret = scsi_add_host(shost, boardp->dev);
 
13858                 goto err_free_wide_mem;
 
13860         scsi_scan_host(shost);
 
13864         advansys_wide_free_mem(boardp);
 
13865         free_irq(boardp->irq, shost);
 
13867         if (shost->dma_channel != NO_ISA_DMA)
 
13868                 free_dma(shost->dma_channel);
 
13870         kfree(boardp->prtbuf);
 
13872         if (boardp->ioremap_addr)
 
13873                 iounmap(boardp->ioremap_addr);
 
13879  * advansys_release()
 
13881  * Release resources allocated for a single AdvanSys adapter.
 
13883 static int advansys_release(struct Scsi_Host *shost)
 
13885         struct asc_board *board = shost_priv(shost);
 
13886         ASC_DBG(1, "begin\n");
 
13887         scsi_remove_host(shost);
 
13888         free_irq(board->irq, shost);
 
13889         if (shost->dma_channel != NO_ISA_DMA) {
 
13890                 ASC_DBG(1, "free_dma()\n");
 
13891                 free_dma(shost->dma_channel);
 
13893         if (ASC_NARROW_BOARD(board)) {
 
13894                 dma_unmap_single(board->dev,
 
13895                                         board->dvc_var.asc_dvc_var.overrun_dma,
 
13896                                         ASC_OVERRUN_BSIZE, DMA_FROM_DEVICE);
 
13898                 iounmap(board->ioremap_addr);
 
13899                 advansys_wide_free_mem(board);
 
13901         kfree(board->prtbuf);
 
13902         scsi_host_put(shost);
 
13903         ASC_DBG(1, "end\n");
 
13907 #define ASC_IOADR_TABLE_MAX_IX  11
 
13909 static PortAddr _asc_def_iop_base[ASC_IOADR_TABLE_MAX_IX] = {
 
13910         0x100, 0x0110, 0x120, 0x0130, 0x140, 0x0150, 0x0190,
 
13911         0x0210, 0x0230, 0x0250, 0x0330
 
13915  * The ISA IRQ number is found in bits 2 and 3 of the CfgLsw.  It decodes as:
 
13921 static unsigned int __devinit advansys_isa_irq_no(PortAddr iop_base)
 
13923         unsigned short cfg_lsw = AscGetChipCfgLsw(iop_base);
 
13924         unsigned int chip_irq = ((cfg_lsw >> 2) & 0x03) + 10;
 
13925         if (chip_irq == 13)
 
13930 static int __devinit advansys_isa_probe(struct device *dev, unsigned int id)
 
13933         PortAddr iop_base = _asc_def_iop_base[id];
 
13934         struct Scsi_Host *shost;
 
13935         struct asc_board *board;
 
13937         if (!request_region(iop_base, ASC_IOADR_GAP, DRV_NAME)) {
 
13938                 ASC_DBG(1, "I/O port 0x%x busy\n", iop_base);
 
13941         ASC_DBG(1, "probing I/O port 0x%x\n", iop_base);
 
13942         if (!AscFindSignature(iop_base))
 
13943                 goto release_region;
 
13944         if (!(AscGetChipVersion(iop_base, ASC_IS_ISA) & ASC_CHIP_VER_ISA_BIT))
 
13945                 goto release_region;
 
13948         shost = scsi_host_alloc(&advansys_template, sizeof(*board));
 
13950                 goto release_region;
 
13952         board = shost_priv(shost);
 
13953         board->irq = advansys_isa_irq_no(iop_base);
 
13956         err = advansys_board_found(shost, iop_base, ASC_IS_ISA);
 
13960         dev_set_drvdata(dev, shost);
 
13964         scsi_host_put(shost);
 
13966         release_region(iop_base, ASC_IOADR_GAP);
 
13970 static int __devexit advansys_isa_remove(struct device *dev, unsigned int id)
 
13972         int ioport = _asc_def_iop_base[id];
 
13973         advansys_release(dev_get_drvdata(dev));
 
13974         release_region(ioport, ASC_IOADR_GAP);
 
13978 static struct isa_driver advansys_isa_driver = {
 
13979         .probe          = advansys_isa_probe,
 
13980         .remove         = __devexit_p(advansys_isa_remove),
 
13982                 .owner  = THIS_MODULE,
 
13988  * The VLB IRQ number is found in bits 2 to 4 of the CfgLsw.  It decodes as:
 
13998 static unsigned int __devinit advansys_vlb_irq_no(PortAddr iop_base)
 
14000         unsigned short cfg_lsw = AscGetChipCfgLsw(iop_base);
 
14001         unsigned int chip_irq = ((cfg_lsw >> 2) & 0x07) + 9;
 
14002         if ((chip_irq < 10) || (chip_irq == 13) || (chip_irq > 15))
 
14007 static int __devinit advansys_vlb_probe(struct device *dev, unsigned int id)
 
14010         PortAddr iop_base = _asc_def_iop_base[id];
 
14011         struct Scsi_Host *shost;
 
14012         struct asc_board *board;
 
14014         if (!request_region(iop_base, ASC_IOADR_GAP, DRV_NAME)) {
 
14015                 ASC_DBG(1, "I/O port 0x%x busy\n", iop_base);
 
14018         ASC_DBG(1, "probing I/O port 0x%x\n", iop_base);
 
14019         if (!AscFindSignature(iop_base))
 
14020                 goto release_region;
 
14022          * I don't think this condition can actually happen, but the old
 
14023          * driver did it, and the chances of finding a VLB setup in 2007
 
14024          * to do testing with is slight to none.
 
14026         if (AscGetChipVersion(iop_base, ASC_IS_VL) > ASC_CHIP_MAX_VER_VL)
 
14027                 goto release_region;
 
14030         shost = scsi_host_alloc(&advansys_template, sizeof(*board));
 
14032                 goto release_region;
 
14034         board = shost_priv(shost);
 
14035         board->irq = advansys_vlb_irq_no(iop_base);
 
14038         err = advansys_board_found(shost, iop_base, ASC_IS_VL);
 
14042         dev_set_drvdata(dev, shost);
 
14046         scsi_host_put(shost);
 
14048         release_region(iop_base, ASC_IOADR_GAP);
 
14052 static struct isa_driver advansys_vlb_driver = {
 
14053         .probe          = advansys_vlb_probe,
 
14054         .remove         = __devexit_p(advansys_isa_remove),
 
14056                 .owner  = THIS_MODULE,
 
14057                 .name   = "advansys_vlb",
 
14061 static struct eisa_device_id advansys_eisa_table[] __devinitdata = {
 
14067 MODULE_DEVICE_TABLE(eisa, advansys_eisa_table);
 
14070  * EISA is a little more tricky than PCI; each EISA device may have two
 
14071  * channels, and this driver is written to make each channel its own Scsi_Host
 
14073 struct eisa_scsi_data {
 
14074         struct Scsi_Host *host[2];
 
14078  * The EISA IRQ number is found in bits 8 to 10 of the CfgLsw.  It decodes as:
 
14088 static unsigned int __devinit advansys_eisa_irq_no(struct eisa_device *edev)
 
14090         unsigned short cfg_lsw = inw(edev->base_addr + 0xc86);
 
14091         unsigned int chip_irq = ((cfg_lsw >> 8) & 0x07) + 10;
 
14092         if ((chip_irq == 13) || (chip_irq > 15))
 
14097 static int __devinit advansys_eisa_probe(struct device *dev)
 
14099         int i, ioport, irq = 0;
 
14101         struct eisa_device *edev = to_eisa_device(dev);
 
14102         struct eisa_scsi_data *data;
 
14105         data = kzalloc(sizeof(*data), GFP_KERNEL);
 
14108         ioport = edev->base_addr + 0xc30;
 
14111         for (i = 0; i < 2; i++, ioport += 0x20) {
 
14112                 struct asc_board *board;
 
14113                 struct Scsi_Host *shost;
 
14114                 if (!request_region(ioport, ASC_IOADR_GAP, DRV_NAME)) {
 
14115                         printk(KERN_WARNING "Region %x-%x busy\n", ioport,
 
14116                                ioport + ASC_IOADR_GAP - 1);
 
14119                 if (!AscFindSignature(ioport)) {
 
14120                         release_region(ioport, ASC_IOADR_GAP);
 
14125                  * I don't know why we need to do this for EISA chips, but
 
14126                  * not for any others.  It looks to be equivalent to
 
14127                  * AscGetChipCfgMsw, but I may have overlooked something,
 
14128                  * so I'm not converting it until I get an EISA board to
 
14134                         irq = advansys_eisa_irq_no(edev);
 
14137                 shost = scsi_host_alloc(&advansys_template, sizeof(*board));
 
14139                         goto release_region;
 
14141                 board = shost_priv(shost);
 
14145                 err = advansys_board_found(shost, ioport, ASC_IS_EISA);
 
14147                         data->host[i] = shost;
 
14151                 scsi_host_put(shost);
 
14153                 release_region(ioport, ASC_IOADR_GAP);
 
14159         dev_set_drvdata(dev, data);
 
14163         kfree(data->host[0]);
 
14164         kfree(data->host[1]);
 
14170 static __devexit int advansys_eisa_remove(struct device *dev)
 
14173         struct eisa_scsi_data *data = dev_get_drvdata(dev);
 
14175         for (i = 0; i < 2; i++) {
 
14177                 struct Scsi_Host *shost = data->host[i];
 
14180                 ioport = shost->io_port;
 
14181                 advansys_release(shost);
 
14182                 release_region(ioport, ASC_IOADR_GAP);
 
14189 static struct eisa_driver advansys_eisa_driver = {
 
14190         .id_table =             advansys_eisa_table,
 
14193                 .probe =        advansys_eisa_probe,
 
14194                 .remove =       __devexit_p(advansys_eisa_remove),
 
14198 /* PCI Devices supported by this driver */
 
14199 static struct pci_device_id advansys_pci_tbl[] __devinitdata = {
 
14200         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_ASP_1200A,
 
14201          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14202         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_ASP_ABP940,
 
14203          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14204         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_ASP_ABP940U,
 
14205          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14206         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_ASP_ABP940UW,
 
14207          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14208         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_38C0800_REV1,
 
14209          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14210         {PCI_VENDOR_ID_ASP, PCI_DEVICE_ID_38C1600_REV1,
 
14211          PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
 
14215 MODULE_DEVICE_TABLE(pci, advansys_pci_tbl);
 
14217 static void __devinit advansys_set_latency(struct pci_dev *pdev)
 
14219         if ((pdev->device == PCI_DEVICE_ID_ASP_1200A) ||
 
14220             (pdev->device == PCI_DEVICE_ID_ASP_ABP940)) {
 
14221                 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0);
 
14224                 pci_read_config_byte(pdev, PCI_LATENCY_TIMER, &latency);
 
14225                 if (latency < 0x20)
 
14226                         pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x20);
 
14230 static int __devinit
 
14231 advansys_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
 
14234         struct Scsi_Host *shost;
 
14235         struct asc_board *board;
 
14237         err = pci_enable_device(pdev);
 
14240         err = pci_request_regions(pdev, DRV_NAME);
 
14242                 goto disable_device;
 
14243         pci_set_master(pdev);
 
14244         advansys_set_latency(pdev);
 
14247         if (pci_resource_len(pdev, 0) == 0)
 
14248                 goto release_region;
 
14250         ioport = pci_resource_start(pdev, 0);
 
14253         shost = scsi_host_alloc(&advansys_template, sizeof(*board));
 
14255                 goto release_region;
 
14257         board = shost_priv(shost);
 
14258         board->irq = pdev->irq;
 
14259         board->dev = &pdev->dev;
 
14261         if (pdev->device == PCI_DEVICE_ID_ASP_ABP940UW ||
 
14262             pdev->device == PCI_DEVICE_ID_38C0800_REV1 ||
 
14263             pdev->device == PCI_DEVICE_ID_38C1600_REV1) {
 
14264                 board->flags |= ASC_IS_WIDE_BOARD;
 
14267         err = advansys_board_found(shost, ioport, ASC_IS_PCI);
 
14271         pci_set_drvdata(pdev, shost);
 
14275         scsi_host_put(shost);
 
14277         pci_release_regions(pdev);
 
14279         pci_disable_device(pdev);
 
14284 static void __devexit advansys_pci_remove(struct pci_dev *pdev)
 
14286         advansys_release(pci_get_drvdata(pdev));
 
14287         pci_release_regions(pdev);
 
14288         pci_disable_device(pdev);
 
14291 static struct pci_driver advansys_pci_driver = {
 
14293         .id_table =     advansys_pci_tbl,
 
14294         .probe =        advansys_pci_probe,
 
14295         .remove =       __devexit_p(advansys_pci_remove),
 
14298 static int __init advansys_init(void)
 
14302         error = isa_register_driver(&advansys_isa_driver,
 
14303                                     ASC_IOADR_TABLE_MAX_IX);
 
14307         error = isa_register_driver(&advansys_vlb_driver,
 
14308                                     ASC_IOADR_TABLE_MAX_IX);
 
14310                 goto unregister_isa;
 
14312         error = eisa_driver_register(&advansys_eisa_driver);
 
14314                 goto unregister_vlb;
 
14316         error = pci_register_driver(&advansys_pci_driver);
 
14318                 goto unregister_eisa;
 
14323         eisa_driver_unregister(&advansys_eisa_driver);
 
14325         isa_unregister_driver(&advansys_vlb_driver);
 
14327         isa_unregister_driver(&advansys_isa_driver);
 
14332 static void __exit advansys_exit(void)
 
14334         pci_unregister_driver(&advansys_pci_driver);
 
14335         eisa_driver_unregister(&advansys_eisa_driver);
 
14336         isa_unregister_driver(&advansys_vlb_driver);
 
14337         isa_unregister_driver(&advansys_isa_driver);
 
14340 module_init(advansys_init);
 
14341 module_exit(advansys_exit);
 
14343 MODULE_LICENSE("GPL");