1 /* $NetBSD: dptivar.h,v 1.3 2002/12/07 19:48:31 ad Exp $ */ 2 3 /*- 4 * Copyright (c) 2001 The NetBSD Foundation, Inc. 5 * All rights reserved. 6 * 7 * This code is derived from software contributed to The NetBSD Foundation 8 * by Andrew Doran. 9 * 10 * Redistribution and use in source and binary forms, with or without 11 * modification, are permitted provided that the following conditions 12 * are met: 13 * 1. Redistributions of source code must retain the above copyright 14 * notice, this list of conditions and the following disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 3. All advertising materials mentioning features or use of this software 19 * must display the following acknowledgement: 20 * This product includes software developed by the NetBSD 21 * Foundation, Inc. and its contributors. 22 * 4. Neither the name of The NetBSD Foundation nor the names of its 23 * contributors may be used to endorse or promote products derived 24 * from this software without specific prior written permission. 25 * 26 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 27 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 28 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 29 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 30 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 31 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 32 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 33 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 34 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 35 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 36 * POSSIBILITY OF SUCH DAMAGE. 37 */ 38 39 /* 40 * Copyright (c) 1996-2000 Distributed Processing Technology Corporation 41 * Copyright (c) 2000 Adaptec Corporation 42 * All rights reserved. 43 * 44 * TERMS AND CONDITIONS OF USE 45 * 46 * Redistribution and use in source form, with or without modification, are 47 * permitted provided that redistributions of source code must retain the 48 * above copyright notice, this list of conditions and the following disclaimer. 49 * 50 * This software is provided `as is' by Adaptec and any express or implied 51 * warranties, including, but not limited to, the implied warranties of 52 * merchantability and fitness for a particular purpose, are disclaimed. In no 53 * event shall Adaptec be liable for any direct, indirect, incidental, special, 54 * exemplary or consequential damages (including, but not limited to, 55 * procurement of substitute goods or services; loss of use, data, or profits; 56 * or business interruptions) however caused and on any theory of liability, 57 * whether in contract, strict liability, or tort (including negligence or 58 * otherwise) arising in any way out of the use of this driver software, even 59 * if advised of the possibility of such damage. 60 */ 61 62 #ifndef _I2O_DPTIVAR_H_ 63 #define _I2O_DPTIVAR_H_ 64 65 #define DPTI_MAX_SEGS 17 66 67 /* 68 * Runtime state. 69 */ 70 struct dpti_softc { 71 struct device sc_dv; 72 int sc_blinkled; 73 int sc_nactive; 74 }; 75 76 struct dpti_ptbuf { 77 caddr_t db_ptr; 78 struct proc *db_proc; 79 int db_size; 80 int db_out; 81 int db_nfrag; 82 struct iovec db_frags[DPTI_MAX_SEGS]; 83 }; 84 85 /* 86 * Constants used by the `signature'. 87 */ 88 89 /* I2O */ 90 #define DPTI_VERSION 1 91 #define DPTI_REVISION 0 92 #define DPTI_SUBREVISION 0 93 94 #define DPTI_YEAR 1 95 #define DPTI_MONTH 9 96 #define DPTI_DAY 12 97 98 /* EATA */ 99 #define DPT_VERSION 1 100 #define DPT_REVISION 0 101 #define DPT_SUBREVISION 0 102 103 #define DPT_YEAR 1 104 #define DPT_MONTH 9 105 #define DPT_DAY 12 106 107 /* 108 * ioctls. We define only the lower 16 bits, since the DPT utilities don't 109 * seem to obey the ioctl encoding conventions of each platform - the high 110 * 16 bits are relatively meaningless. 111 */ 112 #define DPT_EATAUSRCMD 0x4441 113 #define DPT_DEBUG 0x4442 114 #define DPT_SIGNATURE 0x4443 115 #define DPT_NUMCTRLS 0x4444 116 #define DPT_CTRLINFO 0x4445 117 #define DPT_STATINFO 0x4446 118 #define DPT_CLRSTAT 0x4447 119 #define DPT_SYSINFO 0x4448 120 #define DPT_TIMEOUT 0x4449 121 #define DPT_CONFIG 0x444a 122 #define DPT_BLINKLED 0x444b 123 #define DPT_I2OUSRCMD 0x444c 124 #define DPT_I2ORESCANCMD 0x444d 125 #define DPT_I2ORESETCMD 0x444e 126 #define DPT_TARGET_BUSY 0x444f 127 128 /* 129 * Controller and system info structures. 130 */ 131 struct dpt_ctlrinfo { 132 u_int16_t length; 133 u_int16_t drvrHBAnum; 134 u_int32_t baseAddr; 135 u_int16_t blinkState; 136 u_int8_t pciBusNum; 137 u_int8_t pciDeviceNum; 138 u_int16_t hbaFlags; 139 u_int16_t Interrupt; 140 u_int32_t reserved1; 141 u_int32_t reserved2; 142 u_int32_t reserved3; 143 }; 144 #define FLG_OSD_PCI_VALID 0x0001 145 #define FLG_OSD_DMA 0x0002 146 #define FLG_OSD_I2O 0x0004 147 148 struct dpt_eata_ctlrinfo { 149 u_int8_t state; 150 u_int8_t id; 151 int vect; 152 int base; 153 int njobs; 154 int qdepth; 155 int wakebase; 156 u_long sgsize; 157 u_int heads; 158 u_int sectors; 159 u_int8_t do_drive32; 160 u_int8_t busquiet; 161 u_int8_t idpal[4]; 162 u_int8_t primary; 163 u_int8_t eataVersion; 164 u_long cpLength; 165 u_long spLength; 166 u_int8_t drqNum; 167 u_int8_t flag1; 168 u_int8_t flag2; 169 }; 170 171 struct dpt_targetbusy { 172 u_long channel; 173 u_long id; 174 u_long lun; 175 u_long isbusy; 176 }; 177 178 #if (!defined(dsDescription_size)) 179 # define dsDescription_size 46 180 #endif 181 182 struct dpt_sig { 183 char dsSignature[6]; /* ALWAYS "dPtSiG" */ 184 u_int8_t dsSigVersion; /* sig version (currently 1) */ 185 u_int8_t dsProcessorFamily; /* what type of processor */ 186 u_int8_t dsProcessor; /* precise processor */ 187 u_int8_t dsFiletype; /* type of file */ 188 u_int8_t dsFiletypeFlags; /* flags to specify type, etc. */ 189 u_int8_t dsOEM; /* OEM file was created for */ 190 u_int32_t dsOS; /* which Operating systems */ 191 u_int16_t dsCapabilities; /* RAID levels, etc. */ 192 u_int16_t dsDeviceSupp; /* SCSI device types supported */ 193 u_int16_t dsAdapterSupp; /* DPT HBA families supported */ 194 u_int16_t dsApplication; /* applications file is for */ 195 u_int8_t dsRequirements; /* Other driver dependencies */ 196 u_int8_t dsVersion; /* 1 */ 197 u_int8_t dsRevision; /* 'J' */ 198 u_int8_t dsSubRevision; /* '9' ' ' if N/A */ 199 u_int8_t dsMonth; /* creation month */ 200 u_int8_t dsDay; /* creation day */ 201 u_int8_t dsYear; /* creation year since 1980 (1993=13) */ 202 char dsDescription[dsDescription_size]; 203 }; 204 205 struct dpt_dparam { 206 u_int16_t cylinders; /* Upto 1024 */ 207 u_int8_t heads; /* Upto 255 */ 208 u_int8_t sectors; /* Upto 63 */ 209 }; 210 211 struct dpt_sysinfo { 212 u_int8_t drive0CMOS; /* CMOS Drive 0 Type */ 213 u_int8_t drive1CMOS; /* CMOS Drive 1 Type */ 214 u_int8_t numDrives; /* 0040:0075 contents */ 215 u_int8_t processorFamily; /* Same as DPTSIG's defs */ 216 u_int8_t processorType; /* Same as DPTSIG's defs */ 217 u_int8_t smartROMMajorVersion; 218 u_int8_t smartROMMinorVersion; /* SmartROM version */ 219 u_int8_t smartROMRevision; 220 u_int16_t flags; /* See bit definitions above */ 221 u_int16_t conventionalMemSize; /* in KB */ 222 u_int32_t extendedMemSize; /* in KB */ 223 u_int32_t osType; /* Same as DPTSIG's defs */ 224 u_int8_t osMajorVersion; 225 u_int8_t osMinorVersion; /* The OS version */ 226 u_int8_t osRevision; 227 u_int8_t osSubRevision; 228 u_int8_t busType; /* See defininitions above */ 229 u_int8_t pad[3]; /* For alignment */ 230 struct dpt_dparam drives[16]; /* SmartROM Logical Drives */ 231 }; 232 233 /* 234 * Defs pertaining to dpt_sysinfo. 235 */ 236 237 #define SI_CMOS_Valid 0x0001 238 #define SI_NumDrivesValid 0x0002 239 #define SI_ProcessorValid 0x0004 240 #define SI_MemorySizeValid 0x0008 241 #define SI_DriveParamsValid 0x0010 242 #define SI_SmartROMverValid 0x0020 243 #define SI_OSversionValid 0x0040 244 #define SI_OSspecificValid 0x0080 245 #define SI_BusTypeValid 0x0100 246 #define SI_ALL_VALID 0x0FFF 247 #define SI_NO_SmartROM 0x8000 248 249 #define SI_ISA_BUS 0x00 250 #define SI_MCA_BUS 0x01 251 #define SI_EISA_BUS 0x02 252 #define SI_PCI_BUS 0x04 253 254 255 /* 256 * Defs pertaining to dpt_sig. 257 */ 258 259 /* Current Signature Version - u_int8_t dsSigVersion; */ 260 /* ------------------------------------------------------------------ */ 261 #define SIG_VERSION 1 262 263 /* Processor Family - u_int8_t dsProcessorFamily; DISTINCT VALUES */ 264 /* ------------------------------------------------------------------ */ 265 /* What type of processor the file is meant to run on. */ 266 /* This will let us know whether to read u_int16_ts as high/low or low/high. */ 267 #define PROC_INTEL 0x00 /* Intel 80x86 */ 268 #define PROC_MOTOROLA 0x01 /* Motorola 68K */ 269 #define PROC_MIPS4000 0x02 /* MIPS RISC 4000 */ 270 #define PROC_MIPS 0x02 /* MIPS RISC */ 271 #define PROC_ALPHA 0x03 /* DEC Alpha */ 272 #define PROC_POWERPC 0x04 /* IBM Power PC */ 273 #define PROC_i960 0x05 /* Intel i960 */ 274 #define PROC_ULTRASPARC 0x06 /* SPARC processor */ 275 276 /* Specific Minimim Processor - u_int8_t dsProcessor; FLAG BITS */ 277 /* ------------------------------------------------------------------ */ 278 /* Different bit definitions dependent on processor_family */ 279 280 /* PROC_INTEL: */ 281 #define PROC_8086 0x01 /* Intel 8086 */ 282 #define PROC_286 0x02 /* Intel 80286 */ 283 #define PROC_386 0x04 /* Intel 80386 */ 284 #define PROC_486 0x08 /* Intel 80486 */ 285 #define PROC_PENTIUM 0x10 /* Intel 586 aka P5 aka Pentium */ 286 #define PROC_SEXIUM 0x20 /* Intel 686 aka P6 aka Pentium Pro or MMX */ 287 288 /* PROC_i960: */ 289 #define PROC_960RX 0x01 /* Intel 80960RP/RD */ 290 #define PROC_960HX 0x02 /* Intel 80960HA/HD/HT */ 291 #define PROC_960RN 0x03 /* Intel 80960RN/RM */ 292 #define PROC_960RS 0x04 /* Intel 80960RS */ 293 294 /* PROC_MOTOROLA: */ 295 #define PROC_68000 0x01 /* Motorola 68000 */ 296 #define PROC_68010 0x02 /* Motorola 68010 */ 297 #define PROC_68020 0x04 /* Motorola 68020 */ 298 #define PROC_68030 0x08 /* Motorola 68030 */ 299 #define PROC_68040 0x10 /* Motorola 68040 */ 300 301 /* PROC_POWERPC */ 302 #define PROC_PPC601 0x01 /* PowerPC 601 */ 303 #define PROC_PPC603 0x02 /* PowerPC 603 */ 304 #define PROC_PPC604 0x04 /* PowerPC 604 */ 305 306 /* PROC_MIPS */ 307 #define PROC_R4000 0x01 /* MIPS R4000 */ 308 #define PROC_RM7000 0x02 /* MIPS RM7000 */ 309 310 /* Filetype - u_int8_t dsFiletype; DISTINCT VALUES */ 311 /* ------------------------------------------------------------------ */ 312 #define FT_EXECUTABLE 0 /* Executable Program */ 313 #define FT_SCRIPT 1 /* Script/Batch File??? */ 314 #define FT_HBADRVR 2 /* HBA Driver */ 315 #define FT_OTHERDRVR 3 /* Other Driver */ 316 #define FT_IFS 4 /* Installable Filesystem Driver */ 317 #define FT_ENGINE 5 /* DPT Engine */ 318 #define FT_COMPDRVR 6 /* Compressed Driver Disk */ 319 #define FT_LANGUAGE 7 /* Foreign Language file */ 320 #define FT_FIRMWARE 8 /* Downloadable or actual Firmware */ 321 #define FT_COMMMODL 9 /* Communications Module */ 322 #define FT_INT13 10 /* INT 13 style HBA Driver */ 323 #define FT_HELPFILE 11 /* Help file */ 324 #define FT_LOGGER 12 /* Event Logger */ 325 #define FT_INSTALL 13 /* An Install Program */ 326 #define FT_LIBRARY 14 /* Storage Manager Real-Mode Calls */ 327 #define FT_RESOURCE 15 /* Storage Manager Resource File */ 328 #define FT_MODEM_DB 16 /* Storage Manager Modem Database */ 329 330 /* Filetype flags - u_int8_t dsFiletypeFlags; FLAG BITS */ 331 /* ------------------------------------------------------------------ */ 332 #define FTF_DLL 0x01 /* Dynamic Link Library */ 333 #define FTF_NLM 0x02 /* Netware Loadable Module */ 334 #define FTF_OVERLAYS 0x04 /* Uses overlays */ 335 #define FTF_DEBUG 0x08 /* Debug version */ 336 #define FTF_TSR 0x10 /* TSR */ 337 #define FTF_SYS 0x20 /* DOS Loadable driver */ 338 #define FTF_PROTECTED 0x40 /* Runs in protected mode */ 339 #define FTF_APP_SPEC 0x80 /* Application Specific */ 340 #define FTF_ROM (FTF_SYS|FTF_TSR) /* Special Case */ 341 342 /* OEM - u_int8_t dsOEM; DISTINCT VALUES */ 343 /* ------------------------------------------------------------------ */ 344 #define OEM_DPT 0 /* DPT */ 345 #define OEM_ATT 1 /* ATT */ 346 #define OEM_NEC 2 /* NEC */ 347 #define OEM_ALPHA 3 /* Alphatronix */ 348 #define OEM_AST 4 /* AST */ 349 #define OEM_OLIVETTI 5 /* Olivetti */ 350 #define OEM_SNI 6 /* Siemens/Nixdorf */ 351 #define OEM_SUN 7 /* SUN Microsystems */ 352 #define OEM_ADAPTEC 8 /* Adaptec */ 353 354 /* Operating System - u_int32_t dsOS; FLAG BITS */ 355 /* ------------------------------------------------------------------ */ 356 #define OS_DOS 0x00000001 /* PC/MS-DOS */ 357 #define OS_WINDOWS 0x00000002 /* Microsoft Windows 3.x */ 358 #define OS_WINDOWS_NT 0x00000004 /* Microsoft Windows NT */ 359 #define OS_OS2M 0x00000008 /* OS/2 1.2.x,MS 1.3.0,IBM 1.3.x - Monolithic */ 360 #define OS_OS2L 0x00000010 /* Microsoft OS/2 1.301 - LADDR */ 361 #define OS_OS22x 0x00000020 /* IBM OS/2 2.x */ 362 #define OS_NW286 0x00000040 /* Novell NetWare 286 */ 363 #define OS_NW386 0x00000080 /* Novell NetWare 386 */ 364 #define OS_GEN_UNIX 0x00000100 /* Generic Unix */ 365 #define OS_SCO_UNIX 0x00000200 /* SCO Unix */ 366 #define OS_ATT_UNIX 0x00000400 /* ATT Unix */ 367 #define OS_UNIXWARE 0x00000800 /* USL Unix */ 368 #define OS_INT_UNIX 0x00001000 /* Interactive Unix */ 369 #define OS_SOLARIS 0x00002000 /* SunSoft Solaris */ 370 #define OS_QNX 0x00004000 /* QNX for Tom Moch */ 371 #define OS_NEXTSTEP 0x00008000 /* NeXTSTEP/OPENSTEP/MACH */ 372 #define OS_BANYAN 0x00010000 /* Banyan Vines */ 373 #define OS_OLIVETTI_UNIX 0x00020000/* Olivetti Unix */ 374 #define OS_MAC_OS 0x00040000 /* Mac OS */ 375 #define OS_WINDOWS_95 0x00080000 /* Microsoft Windows '95 */ 376 #define OS_NW4x 0x00100000 /* Novell Netware 4.x */ 377 #define OS_BSDI_UNIX 0x00200000 /* BSDi Unix BSD/OS 2.0 and up */ 378 #define OS_AIX_UNIX 0x00400000 /* AIX Unix */ 379 #define OS_FREE_BSD 0x00800000 /* FreeBSD Unix */ 380 #define OS_LINUX 0x01000000 /* Linux */ 381 #define OS_DGUX_UNIX 0x02000000 /* Data General Unix */ 382 #define OS_SINIX_N 0x04000000 /* SNI SINIX-N */ 383 #define OS_PLAN9 0x08000000 /* ATT Plan 9 */ 384 #define OS_TSX 0x10000000 /* SNH TSX-32 */ 385 #define OS_WINDOWS_98 0x20000000 /* Microsoft Windows '98 */ 386 387 #define OS_OTHER 0x80000000 /* Other */ 388 389 /* Capabilities - u_int16_t dsCapabilities; FLAG BITS */ 390 /* ------------------------------------------------------------------ */ 391 #define CAP_RAID0 0x0001 /* RAID-0 */ 392 #define CAP_RAID1 0x0002 /* RAID-1 */ 393 #define CAP_RAID3 0x0004 /* RAID-3 */ 394 #define CAP_RAID5 0x0008 /* RAID-5 */ 395 #define CAP_SPAN 0x0010 /* Spanning */ 396 #define CAP_PASS 0x0020 /* Provides passthrough */ 397 #define CAP_OVERLAP 0x0040 /* Passthrough supports overlapped commands */ 398 #define CAP_ASPI 0x0080 /* Supports ASPI Command Requests */ 399 #define CAP_ABOVE16MB 0x0100 /* ISA Driver supports greater than 16MB */ 400 #define CAP_EXTEND 0x8000 /* Extended info appears after description */ 401 #ifdef SNI_MIPS 402 #define CAP_CACHEMODE 0x1000 /* dpt_force_cache is set in driver */ 403 #endif 404 405 /* Devices Supported - u_int16_t dsDeviceSupp; FLAG BITS */ 406 /* ------------------------------------------------------------------ */ 407 #define DEV_DASD 0x0001 /* DASD (hard drives) */ 408 #define DEV_TAPE 0x0002 /* Tape drives */ 409 #define DEV_PRINTER 0x0004 /* Printers */ 410 #define DEV_PROC 0x0008 /* Processors */ 411 #define DEV_WORM 0x0010 /* WORM drives */ 412 #define DEV_CDROM 0x0020 /* CD-ROM drives */ 413 #define DEV_SCANNER 0x0040 /* Scanners */ 414 #define DEV_OPTICAL 0x0080 /* Optical Drives */ 415 #define DEV_JUKEBOX 0x0100 /* Jukebox */ 416 #define DEV_COMM 0x0200 /* Communications Devices */ 417 #define DEV_OTHER 0x0400 /* Other Devices */ 418 #define DEV_ALL 0xFFFF /* All SCSI Devices */ 419 420 /* Adapters Families Supported - u_int16_t dsAdapterSupp; FLAG BITS */ 421 /* ------------------------------------------------------------------ */ 422 #define ADF_2001 0x0001 /* PM2001 */ 423 #define ADF_2012A 0x0002 /* PM2012A */ 424 #define ADF_PLUS_ISA 0x0004 /* PM2011,PM2021 */ 425 #define ADF_PLUS_EISA 0x0008 /* PM2012B,PM2022 */ 426 #define ADF_SC3_ISA 0x0010 /* PM2021 */ 427 #define ADF_SC3_EISA 0x0020 /* PM2022,PM2122, etc */ 428 #define ADF_SC3_PCI 0x0040 /* SmartCache III PCI */ 429 #define ADF_SC4_ISA 0x0080 /* SmartCache IV ISA */ 430 #define ADF_SC4_EISA 0x0100 /* SmartCache IV EISA */ 431 #define ADF_SC4_PCI 0x0200 /* SmartCache IV PCI */ 432 #define ADF_SC5_PCI 0x0400 /* Fifth Generation I2O products */ 433 /* 434 * Combinations of products 435 */ 436 #define ADF_ALL_2000 (ADF_2001|ADF_2012A) 437 #define ADF_ALL_PLUS (ADF_PLUS_ISA|ADF_PLUS_EISA) 438 #define ADF_ALL_SC3 (ADF_SC3_ISA|ADF_SC3_EISA|ADF_SC3_PCI) 439 #define ADF_ALL_SC4 (ADF_SC4_ISA|ADF_SC4_EISA|ADF_SC4_PCI) 440 #define ADF_ALL_SC5 (ADF_SC5_PCI) 441 /* All EATA Cacheing Products */ 442 #define ADF_ALL_CACHE (ADF_ALL_PLUS|ADF_ALL_SC3|ADF_ALL_SC4) 443 /* All EATA Bus Mastering Products */ 444 #define ADF_ALL_MASTER (ADF_2012A|ADF_ALL_CACHE) 445 /* All EATA Adapter Products */ 446 #define ADF_ALL_EATA (ADF_2001|ADF_ALL_MASTER) 447 #define ADF_ALL ADF_ALL_EATA 448 449 /* Application - u_int16_t dsApplication; FLAG BITS */ 450 /* ------------------------------------------------------------------ */ 451 #define APP_DPTMGR 0x0001 /* DPT Storage Manager */ 452 #define APP_ENGINE 0x0002 /* DPT Engine */ 453 #define APP_SYTOS 0x0004 /* Sytron Sytos Plus */ 454 #define APP_CHEYENNE 0x0008 /* Cheyenne ARCServe + ARCSolo */ 455 #define APP_MSCDEX 0x0010 /* Microsoft CD-ROM extensions */ 456 #define APP_NOVABACK 0x0020 /* NovaStor Novaback */ 457 #define APP_AIM 0x0040 /* Archive Information Manager */ 458 459 /* Requirements - u_int8_t dsRequirements; FLAG BITS */ 460 /* ------------------------------------------------------------------ */ 461 #define REQ_SMARTROM 0x01 /* Requires SmartROM to be present */ 462 #define REQ_DPTDDL 0x02 /* Requires DPTDDL.SYS to be loaded */ 463 #define REQ_HBA_DRIVER 0x04 /* Requires an HBA driver to be loaded */ 464 #define REQ_ASPI_TRAN 0x08 /* Requires an ASPI Transport Modules */ 465 #define REQ_ENGINE 0x10 /* Requires a DPT Engine to be loaded */ 466 #define REQ_COMM_ENG 0x20 /* Requires a DPT Communications Engine */ 467 468 /* ------------------------------------------------------------------ */ 469 /* Requirements - u_int16_t dsFirmware; FLAG BITS */ 470 /* ------------------------------------------------------------------ */ 471 #define dsFirmware dsApplication 472 #define FW_DNLDSIZE0 0x0000 /* 0..2 DownLoader Size - NONE */ 473 #define FW_DNLDSIZE16 0x0001 /* 0..2 DownLoader Size 16K */ 474 #define FW_DNLDSIZE32 0x0002 /* 0..2 DownLoader Size 32K */ 475 #define FW_DNLDSIZE64 0x0004 /* 0..2 DownLoader Size 64K */ 476 477 #define FW_LOAD_BTM 0x2000 /* 13 Load Offset (1=Btm, 0=Top) */ 478 #define FW_LOAD_TOP 0x0000 /* 13 Load Offset (1=Btm, 0=Top) */ 479 #define FW_SIG_VERSION1 0x0000 /* 15..14 Version Bits 0=Ver1 */ 480 481 #endif /* !_I2O_DPTIVAR_H_ */ 482