186d7f5d3SJohn Marino /* $FreeBSD: src/sys/dev/pccard/pccard_cis.h,v 1.4 2005/07/13 14:59:06 imp Exp $ */ 286d7f5d3SJohn Marino /* $DragonFly: src/sys/bus/pccard/pccard_cis.h,v 1.1 2007/07/05 12:08:53 sephe Exp $ */ 386d7f5d3SJohn Marino 486d7f5d3SJohn Marino /*- 586d7f5d3SJohn Marino * Copyright (c) 1997 Marc Horowitz. All rights reserved. 686d7f5d3SJohn Marino * 786d7f5d3SJohn Marino * Redistribution and use in source and binary forms, with or without 886d7f5d3SJohn Marino * modification, are permitted provided that the following conditions 986d7f5d3SJohn Marino * are met: 1086d7f5d3SJohn Marino * 1. Redistributions of source code must retain the above copyright 1186d7f5d3SJohn Marino * notice, this list of conditions and the following disclaimer. 1286d7f5d3SJohn Marino * 2. Redistributions in binary form must reproduce the above copyright 1386d7f5d3SJohn Marino * notice, this list of conditions and the following disclaimer in the 1486d7f5d3SJohn Marino * documentation and/or other materials provided with the distribution. 1586d7f5d3SJohn Marino * 3. All advertising materials mentioning features or use of this software 1686d7f5d3SJohn Marino * must display the following acknowledgement: 1786d7f5d3SJohn Marino * This product includes software developed by Marc Horowitz. 1886d7f5d3SJohn Marino * 4. The name of the author may not be used to endorse or promote products 1986d7f5d3SJohn Marino * derived from this software without specific prior written permission. 2086d7f5d3SJohn Marino * 2186d7f5d3SJohn Marino * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 2286d7f5d3SJohn Marino * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 2386d7f5d3SJohn Marino * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 2486d7f5d3SJohn Marino * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 2586d7f5d3SJohn Marino * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 2686d7f5d3SJohn Marino * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2786d7f5d3SJohn Marino * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2886d7f5d3SJohn Marino * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2986d7f5d3SJohn Marino * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 3086d7f5d3SJohn Marino * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 3186d7f5d3SJohn Marino */ 3286d7f5d3SJohn Marino 3386d7f5d3SJohn Marino /* 3486d7f5d3SJohn Marino * CIS Tuples */ 3586d7f5d3SJohn Marino 3686d7f5d3SJohn Marino /* Layer 1 Basic Compatibility Tuples */ 3786d7f5d3SJohn Marino #define CISTPL_NULL 0x00 3886d7f5d3SJohn Marino #define CISTPL_DEVICE 0x01 3986d7f5d3SJohn Marino #define PCCARD_DTYPE_MASK 0xF0 4086d7f5d3SJohn Marino #define PCCARD_DTYPE_NULL 0x00 4186d7f5d3SJohn Marino #define PCCARD_DTYPE_ROM 0x10 4286d7f5d3SJohn Marino #define PCCARD_DTYPE_OTPROM 0x20 4386d7f5d3SJohn Marino #define PCCARD_DTYPE_EPROM 0x30 4486d7f5d3SJohn Marino #define PCCARD_DTYPE_EEPROM 0x40 4586d7f5d3SJohn Marino #define PCCARD_DTYPE_FLASH 0x50 4686d7f5d3SJohn Marino #define PCCARD_DTYPE_SRAM 0x60 4786d7f5d3SJohn Marino #define PCCARD_DTYPE_DRAM 0x70 4886d7f5d3SJohn Marino #define PCCARD_DTYPE_FUNCSPEC 0xD0 4986d7f5d3SJohn Marino #define PCCARD_DTYPE_EXTEND 0xE0 5086d7f5d3SJohn Marino #define PCCARD_DSPEED_MASK 0x07 5186d7f5d3SJohn Marino #define PCCARD_DSPEED_NULL 0x00 5286d7f5d3SJohn Marino #define PCCARD_DSPEED_250NS 0x01 5386d7f5d3SJohn Marino #define PCCARD_DSPEED_200NS 0x02 5486d7f5d3SJohn Marino #define PCCARD_DSPEED_150NS 0x03 5586d7f5d3SJohn Marino #define PCCARD_DSPEED_100NS 0x04 5686d7f5d3SJohn Marino #define PCCARD_DSPEED_EXT 0x07 5786d7f5d3SJohn Marino 5886d7f5d3SJohn Marino /* 5986d7f5d3SJohn Marino * the 2.1 docs have 0x02-0x07 as reserved, but the linux drivers list the 6086d7f5d3SJohn Marino * follwing tuple code values. I have at least one card (3com 3c562 6186d7f5d3SJohn Marino * lan+modem) which has a code 0x06 tuple, so I'm going to assume that these 6286d7f5d3SJohn Marino * are for real 6386d7f5d3SJohn Marino */ 6486d7f5d3SJohn Marino 6586d7f5d3SJohn Marino #define CISTPL_LONGLINK_CB 0x02 6686d7f5d3SJohn Marino #define CISTPL_INDIRECT 0x03 6786d7f5d3SJohn Marino #define CISTPL_CONFIG_CB 0x04 6886d7f5d3SJohn Marino #define CISTPL_CFTABLE_ENTRY_CB 0x05 6986d7f5d3SJohn Marino #define CISTPL_LONGLINK_MFC 0x06 7086d7f5d3SJohn Marino #define PCCARD_MFC_MEM_ATTR 0x00 7186d7f5d3SJohn Marino #define PCCARD_MFC_MEM_COMMON 0x01 7286d7f5d3SJohn Marino #define CISTPL_BAR 0x07 7386d7f5d3SJohn Marino #define CISTPL_PWR_MGMNT 0x08 7486d7f5d3SJohn Marino #define CISTPL_EXTDEVICE 0x09 7586d7f5d3SJohn Marino 7686d7f5d3SJohn Marino #define CISTPL_CHECKSUM 0x10 7786d7f5d3SJohn Marino #define CISTPL_LONGLINK_A 0x11 7886d7f5d3SJohn Marino #define CISTPL_LONGLINK_C 0x12 7986d7f5d3SJohn Marino #define CISTPL_LINKTARGET 0x13 8086d7f5d3SJohn Marino #define CISTPL_NO_LINK 0x14 8186d7f5d3SJohn Marino #define CISTPL_VERS_1 0x15 8286d7f5d3SJohn Marino #define CISTPL_ALTSTR 0x16 8386d7f5d3SJohn Marino #define CISTPL_DEVICE_A 0x17 8486d7f5d3SJohn Marino #define CISTPL_JEDEC_C 0x18 8586d7f5d3SJohn Marino #define CISTPL_JEDEC_A 0x19 8686d7f5d3SJohn Marino #define CISTPL_CONFIG 0x1A 8786d7f5d3SJohn Marino #define PCCARD_TPCC_RASZ_MASK 0x03 8886d7f5d3SJohn Marino #define PCCARD_TPCC_RASZ_SHIFT 0 8986d7f5d3SJohn Marino #define PCCARD_TPCC_RMSZ_MASK 0x3C 9086d7f5d3SJohn Marino #define PCCARD_TPCC_RMSZ_SHIFT 2 9186d7f5d3SJohn Marino #define PCCARD_TPCC_RFSZ_MASK 0xC0 9286d7f5d3SJohn Marino #define PCCARD_TPCC_RFSZ_SHIFT 6 9386d7f5d3SJohn Marino #define CISTPL_CFTABLE_ENTRY 0x1B 9486d7f5d3SJohn Marino #define PCCARD_TPCE_INDX_INTFACE 0x80 9586d7f5d3SJohn Marino #define PCCARD_TPCE_INDX_DEFAULT 0x40 9686d7f5d3SJohn Marino #define PCCARD_TPCE_INDX_NUM_MASK 0x3F 9786d7f5d3SJohn Marino #define PCCARD_TPCE_IF_MWAIT 0x80 9886d7f5d3SJohn Marino #define PCCARD_TPCE_IF_RDYBSY 0x40 9986d7f5d3SJohn Marino #define PCCARD_TPCE_IF_WP 0x20 10086d7f5d3SJohn Marino #define PCCARD_TPCE_IF_BVD 0x10 10186d7f5d3SJohn Marino #define PCCARD_TPCE_IF_IFTYPE 0x0F 10286d7f5d3SJohn Marino #define PCCARD_IFTYPE_MEMORY 0 10386d7f5d3SJohn Marino #define PCCARD_IFTYPE_IO 1 10486d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MISC 0x80 10586d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MEMSPACE_MASK 0x60 10686d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MEMSPACE_NONE 0x00 10786d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MEMSPACE_LENGTH 0x20 10886d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MEMSPACE_LENGTHADDR 0x40 10986d7f5d3SJohn Marino #define PCCARD_TPCE_FS_MEMSPACE_TABLE 0x60 11086d7f5d3SJohn Marino #define PCCARD_TPCE_FS_IRQ 0x10 11186d7f5d3SJohn Marino #define PCCARD_TPCE_FS_IOSPACE 0x08 11286d7f5d3SJohn Marino #define PCCARD_TPCE_FS_TIMING 0x04 11386d7f5d3SJohn Marino #define PCCARD_TPCE_FS_POWER_MASK 0x03 11486d7f5d3SJohn Marino #define PCCARD_TPCE_FS_POWER_NONE 0x00 11586d7f5d3SJohn Marino #define PCCARD_TPCE_FS_POWER_VCC 0x01 11686d7f5d3SJohn Marino #define PCCARD_TPCE_FS_POWER_VCCVPP1 0x02 11786d7f5d3SJohn Marino #define PCCARD_TPCE_FS_POWER_VCCVPP1VPP2 0x03 11886d7f5d3SJohn Marino #define PCCARD_TPCE_TD_RESERVED_MASK 0xE0 11986d7f5d3SJohn Marino #define PCCARD_TPCE_TD_RDYBSY_MASK 0x1C 12086d7f5d3SJohn Marino #define PCCARD_TPCE_TD_WAIT_MASK 0x03 12186d7f5d3SJohn Marino #define PCCARD_TPCE_IO_HASRANGE 0x80 12286d7f5d3SJohn Marino #define PCCARD_TPCE_IO_BUSWIDTH_16BIT 0x40 12386d7f5d3SJohn Marino #define PCCARD_TPCE_IO_BUSWIDTH_8BIT 0x20 12486d7f5d3SJohn Marino #define PCCARD_TPCE_IO_IOADDRLINES_MASK 0x1F 12586d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_MASK 0xC0 12686d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_NONE 0x00 12786d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_ONE 0x40 12886d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_TWO 0x80 12986d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_FOUR 0xC0 13086d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_ADDRSIZE_MASK 0x30 13186d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_ADDRSIZE_NONE 0x00 13286d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_ADDRSIZE_ONE 0x10 13386d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_ADDRSIZE_TWO 0x20 13486d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_ADDRSIZE_FOUR 0x30 13586d7f5d3SJohn Marino #define PCCARD_TPCE_IO_RANGE_COUNT 0x0F 13686d7f5d3SJohn Marino #define PCCARD_TPCE_IR_SHARE 0x80 13786d7f5d3SJohn Marino #define PCCARD_TPCE_IR_PULSE 0x40 13886d7f5d3SJohn Marino #define PCCARD_TPCE_IR_LEVEL 0x20 13986d7f5d3SJohn Marino #define PCCARD_TPCE_IR_HASMASK 0x10 14086d7f5d3SJohn Marino #define PCCARD_TPCE_IR_IRQ 0x0F 14186d7f5d3SJohn Marino #define PCCARD_TPCE_MS_HOSTADDR 0x80 14286d7f5d3SJohn Marino #define PCCARD_TPCE_MS_CARDADDR_SIZE_MASK 0x60 14386d7f5d3SJohn Marino #define PCCARD_TPCE_MS_CARDADDR_SIZE_SHIFT 5 14486d7f5d3SJohn Marino #define PCCARD_TPCE_MS_LENGTH_SIZE_MASK 0x18 14586d7f5d3SJohn Marino #define PCCARD_TPCE_MS_LENGTH_SIZE_SHIFT 3 14686d7f5d3SJohn Marino #define PCCARD_TPCE_MS_COUNT 0x07 14786d7f5d3SJohn Marino #define PCCARD_TPCE_MI_EXT 0x80 14886d7f5d3SJohn Marino #define PCCARD_TPCE_MI_RESERVED 0x40 14986d7f5d3SJohn Marino #define PCCARD_TPCE_MI_PWRDOWN 0x20 15086d7f5d3SJohn Marino #define PCCARD_TPCE_MI_READONLY 0x10 15186d7f5d3SJohn Marino #define PCCARD_TPCE_MI_AUDIO 0x08 15286d7f5d3SJohn Marino #define PCCARD_TPCE_MI_MAXTWINS 0x07 15386d7f5d3SJohn Marino #define CISTPL_DEVICE_OC 0x1C 15486d7f5d3SJohn Marino #define CISTPL_DEVICE_OA 0x1D 15586d7f5d3SJohn Marino #define CISTPL_DEVICE_GEO 0x1E 15686d7f5d3SJohn Marino #define CISTPL_DEVICE_GEO_A 0x1F 15786d7f5d3SJohn Marino #define CISTPL_MANFID 0x20 15886d7f5d3SJohn Marino #define CISTPL_FUNCID 0x21 15986d7f5d3SJohn Marino #define PCCARD_FUNCTION_UNSPEC -1 16086d7f5d3SJohn Marino #define PCCARD_FUNCTION_MULTIFUNCTION 0 16186d7f5d3SJohn Marino #define PCCARD_FUNCTION_MEMORY 1 16286d7f5d3SJohn Marino #define PCCARD_FUNCTION_SERIAL 2 16386d7f5d3SJohn Marino #define PCCARD_FUNCTION_PARALLEL 3 16486d7f5d3SJohn Marino #define PCCARD_FUNCTION_DISK 4 16586d7f5d3SJohn Marino #define PCCARD_FUNCTION_VIDEO 5 16686d7f5d3SJohn Marino #define PCCARD_FUNCTION_NETWORK 6 16786d7f5d3SJohn Marino #define PCCARD_FUNCTION_AIMS 7 16886d7f5d3SJohn Marino #define PCCARD_FUNCTION_SCSI 8 16986d7f5d3SJohn Marino #define PCCARD_FUNCTION_SECURITY 9 17086d7f5d3SJohn Marino #define PCCARD_FUNCTION_INSTRUMENT 10 17186d7f5d3SJohn Marino #define CISTPL_FUNCE 0x22 17286d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_LAN_TECH 0x01 17386d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_LAN_SPEED 0x02 17486d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_LAN_MEDIA 0x03 17586d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_LAN_NID 0x04 17686d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_LAN_CONN 0x05 17786d7f5d3SJohn Marino #define PCCARD_TPLFE_TYPE_DISK_DEVICE_INTERFACE 0x01 17886d7f5d3SJohn Marino #define PCCARD_TPLFE_DDI_PCCARD_ATA 0x01 17986d7f5d3SJohn Marino #define CISTPL_END 0xFF 18086d7f5d3SJohn Marino 18186d7f5d3SJohn Marino /* Layer 2 Data Recording Format Tuples */ 18286d7f5d3SJohn Marino 18386d7f5d3SJohn Marino #define CISTPL_SWIL 0x23 18486d7f5d3SJohn Marino /* #define CISTPL_RESERVED 0x24-0x3F */ 18586d7f5d3SJohn Marino #define CISTPL_VERS_2 0x40 18686d7f5d3SJohn Marino #define CISTPL_FORMAT 0x41 18786d7f5d3SJohn Marino #define CISTPL_GEOMETRY 0x42 18886d7f5d3SJohn Marino #define CISTPL_BYTEORDER 0x43 18986d7f5d3SJohn Marino #define CISTPL_DATE 0x44 19086d7f5d3SJohn Marino #define CISTPL_BATTERY 0x45 19186d7f5d3SJohn Marino #define CISTPL_FORAMT_A 0x47 19286d7f5d3SJohn Marino 19386d7f5d3SJohn Marino /* Layer 3 Data Organization Tuples */ 19486d7f5d3SJohn Marino 19586d7f5d3SJohn Marino #define CISTPL_ORG 0x46 19686d7f5d3SJohn Marino /* #define CISTPL_RESERVED 0x47-0x7F */ 19786d7f5d3SJohn Marino 19886d7f5d3SJohn Marino /* Layer 4 System-Specific Standard Tuples */ 19986d7f5d3SJohn Marino 20086d7f5d3SJohn Marino /* #define CISTPL_RESERVED 0x80-0x8F */ 20186d7f5d3SJohn Marino #define CISTPL_SPCL 0x90 20286d7f5d3SJohn Marino /* #define CISTPL_RESERVED 0x90-0xFE */ 20386d7f5d3SJohn Marino 20486d7f5d3SJohn Marino #define CISTPL_GENERIC -1 205