1120869Simp/* $FreeBSD: releng/11.0/sys/dev/pccard/pccard_cis.h 147962 2005-07-13 14:59:06Z imp $ */ 2120869Simp 3139749Simp/*- 4120869Simp * Copyright (c) 1997 Marc Horowitz. All rights reserved. 5120869Simp * 6120869Simp * Redistribution and use in source and binary forms, with or without 7120869Simp * modification, are permitted provided that the following conditions 8120869Simp * are met: 9120869Simp * 1. Redistributions of source code must retain the above copyright 10120869Simp * notice, this list of conditions and the following disclaimer. 11120869Simp * 2. Redistributions in binary form must reproduce the above copyright 12120869Simp * notice, this list of conditions and the following disclaimer in the 13120869Simp * documentation and/or other materials provided with the distribution. 14120869Simp * 3. All advertising materials mentioning features or use of this software 15120869Simp * must display the following acknowledgement: 16120869Simp * This product includes software developed by Marc Horowitz. 17120869Simp * 4. The name of the author may not be used to endorse or promote products 18120869Simp * derived from this software without specific prior written permission. 19120869Simp * 20120869Simp * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 21120869Simp * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 22120869Simp * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 23120869Simp * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 24120869Simp * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 25120869Simp * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 26120869Simp * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 27120869Simp * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 28120869Simp * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 29120869Simp * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 30120869Simp */ 31120869Simp 32120869Simp/* 33120869Simp * CIS Tuples */ 34120869Simp 35120869Simp/* Layer 1 Basic Compatibility Tuples */ 36120869Simp#define CISTPL_NULL 0x00 37120869Simp#define CISTPL_DEVICE 0x01 38120869Simp#define PCCARD_DTYPE_MASK 0xF0 39120869Simp#define PCCARD_DTYPE_NULL 0x00 40120869Simp#define PCCARD_DTYPE_ROM 0x10 41120869Simp#define PCCARD_DTYPE_OTPROM 0x20 42120869Simp#define PCCARD_DTYPE_EPROM 0x30 43120869Simp#define PCCARD_DTYPE_EEPROM 0x40 44120869Simp#define PCCARD_DTYPE_FLASH 0x50 45120869Simp#define PCCARD_DTYPE_SRAM 0x60 46120869Simp#define PCCARD_DTYPE_DRAM 0x70 47120869Simp#define PCCARD_DTYPE_FUNCSPEC 0xD0 48120869Simp#define PCCARD_DTYPE_EXTEND 0xE0 49120869Simp#define PCCARD_DSPEED_MASK 0x07 50120869Simp#define PCCARD_DSPEED_NULL 0x00 51120869Simp#define PCCARD_DSPEED_250NS 0x01 52120869Simp#define PCCARD_DSPEED_200NS 0x02 53120869Simp#define PCCARD_DSPEED_150NS 0x03 54120869Simp#define PCCARD_DSPEED_100NS 0x04 55120869Simp#define PCCARD_DSPEED_EXT 0x07 56120869Simp 57120869Simp/* 58120869Simp * the 2.1 docs have 0x02-0x07 as reserved, but the linux drivers list the 59120869Simp * follwing tuple code values. I have at least one card (3com 3c562 60120869Simp * lan+modem) which has a code 0x06 tuple, so I'm going to assume that these 61120869Simp * are for real 62120869Simp */ 63120869Simp 64120869Simp#define CISTPL_LONGLINK_CB 0x02 65120869Simp#define CISTPL_INDIRECT 0x03 66120869Simp#define CISTPL_CONFIG_CB 0x04 67120869Simp#define CISTPL_CFTABLE_ENTRY_CB 0x05 68120869Simp#define CISTPL_LONGLINK_MFC 0x06 69120869Simp#define PCCARD_MFC_MEM_ATTR 0x00 70120869Simp#define PCCARD_MFC_MEM_COMMON 0x01 71120869Simp#define CISTPL_BAR 0x07 72120869Simp#define CISTPL_PWR_MGMNT 0x08 73120869Simp#define CISTPL_EXTDEVICE 0x09 74120869Simp 75120869Simp#define CISTPL_CHECKSUM 0x10 76120869Simp#define CISTPL_LONGLINK_A 0x11 77120869Simp#define CISTPL_LONGLINK_C 0x12 78120869Simp#define CISTPL_LINKTARGET 0x13 79120869Simp#define CISTPL_NO_LINK 0x14 80120869Simp#define CISTPL_VERS_1 0x15 81120869Simp#define CISTPL_ALTSTR 0x16 82120869Simp#define CISTPL_DEVICE_A 0x17 83120869Simp#define CISTPL_JEDEC_C 0x18 84120869Simp#define CISTPL_JEDEC_A 0x19 85120869Simp#define CISTPL_CONFIG 0x1A 86120869Simp#define PCCARD_TPCC_RASZ_MASK 0x03 87120869Simp#define PCCARD_TPCC_RASZ_SHIFT 0 88120869Simp#define PCCARD_TPCC_RMSZ_MASK 0x3C 89120869Simp#define PCCARD_TPCC_RMSZ_SHIFT 2 90120869Simp#define PCCARD_TPCC_RFSZ_MASK 0xC0 91120869Simp#define PCCARD_TPCC_RFSZ_SHIFT 6 92120869Simp#define CISTPL_CFTABLE_ENTRY 0x1B 93120869Simp#define PCCARD_TPCE_INDX_INTFACE 0x80 94120869Simp#define PCCARD_TPCE_INDX_DEFAULT 0x40 95120869Simp#define PCCARD_TPCE_INDX_NUM_MASK 0x3F 96120869Simp#define PCCARD_TPCE_IF_MWAIT 0x80 97120869Simp#define PCCARD_TPCE_IF_RDYBSY 0x40 98120869Simp#define PCCARD_TPCE_IF_WP 0x20 99120869Simp#define PCCARD_TPCE_IF_BVD 0x10 100120869Simp#define PCCARD_TPCE_IF_IFTYPE 0x0F 101120869Simp#define PCCARD_IFTYPE_MEMORY 0 102120869Simp#define PCCARD_IFTYPE_IO 1 103120869Simp#define PCCARD_TPCE_FS_MISC 0x80 104120869Simp#define PCCARD_TPCE_FS_MEMSPACE_MASK 0x60 105120869Simp#define PCCARD_TPCE_FS_MEMSPACE_NONE 0x00 106120869Simp#define PCCARD_TPCE_FS_MEMSPACE_LENGTH 0x20 107120869Simp#define PCCARD_TPCE_FS_MEMSPACE_LENGTHADDR 0x40 108120869Simp#define PCCARD_TPCE_FS_MEMSPACE_TABLE 0x60 109120869Simp#define PCCARD_TPCE_FS_IRQ 0x10 110120869Simp#define PCCARD_TPCE_FS_IOSPACE 0x08 111120869Simp#define PCCARD_TPCE_FS_TIMING 0x04 112120869Simp#define PCCARD_TPCE_FS_POWER_MASK 0x03 113120869Simp#define PCCARD_TPCE_FS_POWER_NONE 0x00 114120869Simp#define PCCARD_TPCE_FS_POWER_VCC 0x01 115120869Simp#define PCCARD_TPCE_FS_POWER_VCCVPP1 0x02 116120869Simp#define PCCARD_TPCE_FS_POWER_VCCVPP1VPP2 0x03 117120869Simp#define PCCARD_TPCE_TD_RESERVED_MASK 0xE0 118120869Simp#define PCCARD_TPCE_TD_RDYBSY_MASK 0x1C 119120869Simp#define PCCARD_TPCE_TD_WAIT_MASK 0x03 120120869Simp#define PCCARD_TPCE_IO_HASRANGE 0x80 121120869Simp#define PCCARD_TPCE_IO_BUSWIDTH_16BIT 0x40 122120869Simp#define PCCARD_TPCE_IO_BUSWIDTH_8BIT 0x20 123120869Simp#define PCCARD_TPCE_IO_IOADDRLINES_MASK 0x1F 124120869Simp#define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_MASK 0xC0 125120869Simp#define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_NONE 0x00 126120869Simp#define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_ONE 0x40 127120869Simp#define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_TWO 0x80 128120869Simp#define PCCARD_TPCE_IO_RANGE_LENGTHSIZE_FOUR 0xC0 129120869Simp#define PCCARD_TPCE_IO_RANGE_ADDRSIZE_MASK 0x30 130120869Simp#define PCCARD_TPCE_IO_RANGE_ADDRSIZE_NONE 0x00 131120869Simp#define PCCARD_TPCE_IO_RANGE_ADDRSIZE_ONE 0x10 132120869Simp#define PCCARD_TPCE_IO_RANGE_ADDRSIZE_TWO 0x20 133120869Simp#define PCCARD_TPCE_IO_RANGE_ADDRSIZE_FOUR 0x30 134120869Simp#define PCCARD_TPCE_IO_RANGE_COUNT 0x0F 135120869Simp#define PCCARD_TPCE_IR_SHARE 0x80 136120869Simp#define PCCARD_TPCE_IR_PULSE 0x40 137120869Simp#define PCCARD_TPCE_IR_LEVEL 0x20 138120869Simp#define PCCARD_TPCE_IR_HASMASK 0x10 139120869Simp#define PCCARD_TPCE_IR_IRQ 0x0F 140120869Simp#define PCCARD_TPCE_MS_HOSTADDR 0x80 141120869Simp#define PCCARD_TPCE_MS_CARDADDR_SIZE_MASK 0x60 142120869Simp#define PCCARD_TPCE_MS_CARDADDR_SIZE_SHIFT 5 143120869Simp#define PCCARD_TPCE_MS_LENGTH_SIZE_MASK 0x18 144120869Simp#define PCCARD_TPCE_MS_LENGTH_SIZE_SHIFT 3 145120869Simp#define PCCARD_TPCE_MS_COUNT 0x07 146120869Simp#define PCCARD_TPCE_MI_EXT 0x80 147120869Simp#define PCCARD_TPCE_MI_RESERVED 0x40 148120869Simp#define PCCARD_TPCE_MI_PWRDOWN 0x20 149120869Simp#define PCCARD_TPCE_MI_READONLY 0x10 150120869Simp#define PCCARD_TPCE_MI_AUDIO 0x08 151120869Simp#define PCCARD_TPCE_MI_MAXTWINS 0x07 152120869Simp#define CISTPL_DEVICE_OC 0x1C 153120869Simp#define CISTPL_DEVICE_OA 0x1D 154120869Simp#define CISTPL_DEVICE_GEO 0x1E 155120869Simp#define CISTPL_DEVICE_GEO_A 0x1F 156120869Simp#define CISTPL_MANFID 0x20 157120869Simp#define CISTPL_FUNCID 0x21 158120869Simp#define PCCARD_FUNCTION_UNSPEC -1 159120869Simp#define PCCARD_FUNCTION_MULTIFUNCTION 0 160120869Simp#define PCCARD_FUNCTION_MEMORY 1 161120869Simp#define PCCARD_FUNCTION_SERIAL 2 162120869Simp#define PCCARD_FUNCTION_PARALLEL 3 163120869Simp#define PCCARD_FUNCTION_DISK 4 164120869Simp#define PCCARD_FUNCTION_VIDEO 5 165120869Simp#define PCCARD_FUNCTION_NETWORK 6 166120869Simp#define PCCARD_FUNCTION_AIMS 7 167120869Simp#define PCCARD_FUNCTION_SCSI 8 168120869Simp#define PCCARD_FUNCTION_SECURITY 9 169120869Simp#define PCCARD_FUNCTION_INSTRUMENT 10 170120869Simp#define CISTPL_FUNCE 0x22 171120869Simp#define PCCARD_TPLFE_TYPE_LAN_TECH 0x01 172120869Simp#define PCCARD_TPLFE_TYPE_LAN_SPEED 0x02 173120869Simp#define PCCARD_TPLFE_TYPE_LAN_MEDIA 0x03 174120869Simp#define PCCARD_TPLFE_TYPE_LAN_NID 0x04 175120869Simp#define PCCARD_TPLFE_TYPE_LAN_CONN 0x05 176120869Simp#define PCCARD_TPLFE_TYPE_DISK_DEVICE_INTERFACE 0x01 177120869Simp#define PCCARD_TPLFE_DDI_PCCARD_ATA 0x01 178120869Simp#define CISTPL_END 0xFF 179120869Simp 180120869Simp/* Layer 2 Data Recording Format Tuples */ 181120869Simp 182120869Simp#define CISTPL_SWIL 0x23 183120869Simp/* #define CISTPL_RESERVED 0x24-0x3F */ 184120869Simp#define CISTPL_VERS_2 0x40 185120869Simp#define CISTPL_FORMAT 0x41 186120869Simp#define CISTPL_GEOMETRY 0x42 187120869Simp#define CISTPL_BYTEORDER 0x43 188120869Simp#define CISTPL_DATE 0x44 189120869Simp#define CISTPL_BATTERY 0x45 190120869Simp#define CISTPL_FORAMT_A 0x47 191120869Simp 192120869Simp/* Layer 3 Data Organization Tuples */ 193120869Simp 194120869Simp#define CISTPL_ORG 0x46 195120869Simp/* #define CISTPL_RESERVED 0x47-0x7F */ 196120869Simp 197120869Simp/* Layer 4 System-Specific Standard Tuples */ 198120869Simp 199120869Simp/* #define CISTPL_RESERVED 0x80-0x8F */ 200120869Simp#define CISTPL_SPCL 0x90 201120869Simp/* #define CISTPL_RESERVED 0x90-0xFE */ 202120869Simp 203120869Simp#define CISTPL_GENERIC -1 204