xref: /openbmc/linux/include/pcmcia/cistpl.h (revision 4b4193256c8d3bc3a5397b5cd9494c2ad386317d)
1  /* SPDX-License-Identifier: GPL-2.0-only */
2  /*
3   * cistpl.h
4   *
5   * The initial developer of the original code is David A. Hinds
6   * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds
7   * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved.
8   *
9   * (C) 1999             David A. Hinds
10   */
11  
12  #ifndef _LINUX_CISTPL_H
13  #define _LINUX_CISTPL_H
14  
15  typedef unsigned char cisdata_t;
16  
17  #define CISTPL_NULL		0x00
18  #define CISTPL_DEVICE		0x01
19  #define CISTPL_LONGLINK_CB	0x02
20  #define CISTPL_INDIRECT		0x03
21  #define CISTPL_CONFIG_CB	0x04
22  #define CISTPL_CFTABLE_ENTRY_CB	0x05
23  #define CISTPL_LONGLINK_MFC	0x06
24  #define CISTPL_BAR		0x07
25  #define CISTPL_PWR_MGMNT	0x08
26  #define CISTPL_EXTDEVICE	0x09
27  #define CISTPL_CHECKSUM		0x10
28  #define CISTPL_LONGLINK_A	0x11
29  #define CISTPL_LONGLINK_C	0x12
30  #define CISTPL_LINKTARGET	0x13
31  #define CISTPL_NO_LINK		0x14
32  #define CISTPL_VERS_1		0x15
33  #define CISTPL_ALTSTR		0x16
34  #define CISTPL_DEVICE_A		0x17
35  #define CISTPL_JEDEC_C		0x18
36  #define CISTPL_JEDEC_A		0x19
37  #define CISTPL_CONFIG		0x1a
38  #define CISTPL_CFTABLE_ENTRY	0x1b
39  #define CISTPL_DEVICE_OC	0x1c
40  #define CISTPL_DEVICE_OA	0x1d
41  #define CISTPL_DEVICE_GEO	0x1e
42  #define CISTPL_DEVICE_GEO_A	0x1f
43  #define CISTPL_MANFID		0x20
44  #define CISTPL_FUNCID		0x21
45  #define CISTPL_FUNCE		0x22
46  #define CISTPL_SWIL		0x23
47  #define CISTPL_END		0xff
48  /* Layer 2 tuples */
49  #define CISTPL_VERS_2		0x40
50  #define CISTPL_FORMAT		0x41
51  #define CISTPL_GEOMETRY		0x42
52  #define CISTPL_BYTEORDER	0x43
53  #define CISTPL_DATE		0x44
54  #define CISTPL_BATTERY		0x45
55  #define CISTPL_FORMAT_A		0x47
56  /* Layer 3 tuples */
57  #define CISTPL_ORG		0x46
58  #define CISTPL_SPCL		0x90
59  
60  typedef struct cistpl_longlink_t {
61      u_int	addr;
62  } cistpl_longlink_t;
63  
64  typedef struct cistpl_checksum_t {
65      u_short	addr;
66      u_short	len;
67      u_char	sum;
68  } cistpl_checksum_t;
69  
70  #define CISTPL_MAX_FUNCTIONS	8
71  #define CISTPL_MFC_ATTR		0x00
72  #define CISTPL_MFC_COMMON	0x01
73  
74  typedef struct cistpl_longlink_mfc_t {
75      u_char	nfn;
76      struct {
77  	u_char	space;
78  	u_int	addr;
79      } fn[CISTPL_MAX_FUNCTIONS];
80  } cistpl_longlink_mfc_t;
81  
82  #define CISTPL_MAX_ALTSTR_STRINGS	4
83  
84  typedef struct cistpl_altstr_t {
85      u_char	ns;
86      u_char	ofs[CISTPL_MAX_ALTSTR_STRINGS];
87      char	str[254];
88  } cistpl_altstr_t;
89  
90  #define CISTPL_DTYPE_NULL	0x00
91  #define CISTPL_DTYPE_ROM	0x01
92  #define CISTPL_DTYPE_OTPROM	0x02
93  #define CISTPL_DTYPE_EPROM	0x03
94  #define CISTPL_DTYPE_EEPROM	0x04
95  #define CISTPL_DTYPE_FLASH	0x05
96  #define CISTPL_DTYPE_SRAM	0x06
97  #define CISTPL_DTYPE_DRAM	0x07
98  #define CISTPL_DTYPE_FUNCSPEC	0x0d
99  #define CISTPL_DTYPE_EXTEND	0x0e
100  
101  #define CISTPL_MAX_DEVICES	4
102  
103  typedef struct cistpl_device_t {
104      u_char	ndev;
105      struct {
106  	u_char 	type;
107  	u_char	wp;
108  	u_int	speed;
109  	u_int	size;
110      } dev[CISTPL_MAX_DEVICES];
111  } cistpl_device_t;
112  
113  #define CISTPL_DEVICE_MWAIT	0x01
114  #define CISTPL_DEVICE_3VCC	0x02
115  
116  typedef struct cistpl_device_o_t {
117      u_char		flags;
118      cistpl_device_t	device;
119  } cistpl_device_o_t;
120  
121  #define CISTPL_VERS_1_MAX_PROD_STRINGS	4
122  
123  typedef struct cistpl_vers_1_t {
124      u_char	major;
125      u_char	minor;
126      u_char	ns;
127      u_char	ofs[CISTPL_VERS_1_MAX_PROD_STRINGS];
128      char	str[254];
129  } cistpl_vers_1_t;
130  
131  typedef struct cistpl_jedec_t {
132      u_char	nid;
133      struct {
134  	u_char	mfr;
135  	u_char	info;
136      } id[CISTPL_MAX_DEVICES];
137  } cistpl_jedec_t;
138  
139  typedef struct cistpl_manfid_t {
140      u_short	manf;
141      u_short	card;
142  } cistpl_manfid_t;
143  
144  #define CISTPL_FUNCID_MULTI	0x00
145  #define CISTPL_FUNCID_MEMORY	0x01
146  #define CISTPL_FUNCID_SERIAL	0x02
147  #define CISTPL_FUNCID_PARALLEL	0x03
148  #define CISTPL_FUNCID_FIXED	0x04
149  #define CISTPL_FUNCID_VIDEO	0x05
150  #define CISTPL_FUNCID_NETWORK	0x06
151  #define CISTPL_FUNCID_AIMS	0x07
152  #define CISTPL_FUNCID_SCSI	0x08
153  
154  #define CISTPL_SYSINIT_POST	0x01
155  #define CISTPL_SYSINIT_ROM	0x02
156  
157  typedef struct cistpl_funcid_t {
158      u_char	func;
159      u_char	sysinit;
160  } cistpl_funcid_t;
161  
162  typedef struct cistpl_funce_t {
163      u_char	type;
164      u_char	data[];
165  } cistpl_funce_t;
166  
167  /*======================================================================
168  
169      Modem Function Extension Tuples
170  
171  ======================================================================*/
172  
173  #define CISTPL_FUNCE_SERIAL_IF		0x00
174  #define CISTPL_FUNCE_SERIAL_CAP		0x01
175  #define CISTPL_FUNCE_SERIAL_SERV_DATA	0x02
176  #define CISTPL_FUNCE_SERIAL_SERV_FAX	0x03
177  #define CISTPL_FUNCE_SERIAL_SERV_VOICE	0x04
178  #define CISTPL_FUNCE_SERIAL_CAP_DATA	0x05
179  #define CISTPL_FUNCE_SERIAL_CAP_FAX	0x06
180  #define CISTPL_FUNCE_SERIAL_CAP_VOICE	0x07
181  #define CISTPL_FUNCE_SERIAL_IF_DATA	0x08
182  #define CISTPL_FUNCE_SERIAL_IF_FAX	0x09
183  #define CISTPL_FUNCE_SERIAL_IF_VOICE	0x0a
184  
185  /* UART identification */
186  #define CISTPL_SERIAL_UART_8250		0x00
187  #define CISTPL_SERIAL_UART_16450	0x01
188  #define CISTPL_SERIAL_UART_16550	0x02
189  #define CISTPL_SERIAL_UART_8251		0x03
190  #define CISTPL_SERIAL_UART_8530		0x04
191  #define CISTPL_SERIAL_UART_85230	0x05
192  
193  /* UART capabilities */
194  #define CISTPL_SERIAL_UART_SPACE	0x01
195  #define CISTPL_SERIAL_UART_MARK		0x02
196  #define CISTPL_SERIAL_UART_ODD		0x04
197  #define CISTPL_SERIAL_UART_EVEN		0x08
198  #define CISTPL_SERIAL_UART_5BIT		0x01
199  #define CISTPL_SERIAL_UART_6BIT		0x02
200  #define CISTPL_SERIAL_UART_7BIT		0x04
201  #define CISTPL_SERIAL_UART_8BIT		0x08
202  #define CISTPL_SERIAL_UART_1STOP	0x10
203  #define CISTPL_SERIAL_UART_MSTOP	0x20
204  #define CISTPL_SERIAL_UART_2STOP	0x40
205  
206  typedef struct cistpl_serial_t {
207      u_char	uart_type;
208      u_char	uart_cap_0;
209      u_char	uart_cap_1;
210  } cistpl_serial_t;
211  
212  typedef struct cistpl_modem_cap_t {
213      u_char	flow;
214      u_char	cmd_buf;
215      u_char	rcv_buf_0, rcv_buf_1, rcv_buf_2;
216      u_char	xmit_buf_0, xmit_buf_1, xmit_buf_2;
217  } cistpl_modem_cap_t;
218  
219  #define CISTPL_SERIAL_MOD_103		0x01
220  #define CISTPL_SERIAL_MOD_V21		0x02
221  #define CISTPL_SERIAL_MOD_V23		0x04
222  #define CISTPL_SERIAL_MOD_V22		0x08
223  #define CISTPL_SERIAL_MOD_212A		0x10
224  #define CISTPL_SERIAL_MOD_V22BIS	0x20
225  #define CISTPL_SERIAL_MOD_V26		0x40
226  #define CISTPL_SERIAL_MOD_V26BIS	0x80
227  #define CISTPL_SERIAL_MOD_V27BIS	0x01
228  #define CISTPL_SERIAL_MOD_V29		0x02
229  #define CISTPL_SERIAL_MOD_V32		0x04
230  #define CISTPL_SERIAL_MOD_V32BIS	0x08
231  #define CISTPL_SERIAL_MOD_V34		0x10
232  
233  #define CISTPL_SERIAL_ERR_MNP2_4	0x01
234  #define CISTPL_SERIAL_ERR_V42_LAPM	0x02
235  
236  #define CISTPL_SERIAL_CMPR_V42BIS	0x01
237  #define CISTPL_SERIAL_CMPR_MNP5		0x02
238  
239  #define CISTPL_SERIAL_CMD_AT1		0x01
240  #define CISTPL_SERIAL_CMD_AT2		0x02
241  #define CISTPL_SERIAL_CMD_AT3		0x04
242  #define CISTPL_SERIAL_CMD_MNP_AT	0x08
243  #define CISTPL_SERIAL_CMD_V25BIS	0x10
244  #define CISTPL_SERIAL_CMD_V25A		0x20
245  #define CISTPL_SERIAL_CMD_DMCL		0x40
246  
247  typedef struct cistpl_data_serv_t {
248      u_char	max_data_0;
249      u_char	max_data_1;
250      u_char	modulation_0;
251      u_char	modulation_1;
252      u_char	error_control;
253      u_char	compression;
254      u_char	cmd_protocol;
255      u_char	escape;
256      u_char	encrypt;
257      u_char	misc_features;
258      u_char	ccitt_code[];
259  } cistpl_data_serv_t;
260  
261  typedef struct cistpl_fax_serv_t {
262      u_char	max_data_0;
263      u_char	max_data_1;
264      u_char	modulation;
265      u_char	encrypt;
266      u_char	features_0;
267      u_char	features_1;
268      u_char	ccitt_code[];
269  } cistpl_fax_serv_t;
270  
271  typedef struct cistpl_voice_serv_t {
272      u_char	max_data_0;
273      u_char	max_data_1;
274  } cistpl_voice_serv_t;
275  
276  /*======================================================================
277  
278      LAN Function Extension Tuples
279  
280  ======================================================================*/
281  
282  #define CISTPL_FUNCE_LAN_TECH		0x01
283  #define CISTPL_FUNCE_LAN_SPEED		0x02
284  #define CISTPL_FUNCE_LAN_MEDIA		0x03
285  #define CISTPL_FUNCE_LAN_NODE_ID	0x04
286  #define CISTPL_FUNCE_LAN_CONNECTOR	0x05
287  
288  /* LAN technologies */
289  #define CISTPL_LAN_TECH_ARCNET		0x01
290  #define CISTPL_LAN_TECH_ETHERNET	0x02
291  #define CISTPL_LAN_TECH_TOKENRING	0x03
292  #define CISTPL_LAN_TECH_LOCALTALK	0x04
293  #define CISTPL_LAN_TECH_FDDI		0x05
294  #define CISTPL_LAN_TECH_ATM		0x06
295  #define CISTPL_LAN_TECH_WIRELESS	0x07
296  
297  typedef struct cistpl_lan_tech_t {
298      u_char	tech;
299  } cistpl_lan_tech_t;
300  
301  typedef struct cistpl_lan_speed_t {
302      u_int	speed;
303  } cistpl_lan_speed_t;
304  
305  /* LAN media definitions */
306  #define CISTPL_LAN_MEDIA_UTP		0x01
307  #define CISTPL_LAN_MEDIA_STP		0x02
308  #define CISTPL_LAN_MEDIA_THIN_COAX	0x03
309  #define CISTPL_LAN_MEDIA_THICK_COAX	0x04
310  #define CISTPL_LAN_MEDIA_FIBER		0x05
311  #define CISTPL_LAN_MEDIA_900MHZ		0x06
312  #define CISTPL_LAN_MEDIA_2GHZ		0x07
313  #define CISTPL_LAN_MEDIA_5GHZ		0x08
314  #define CISTPL_LAN_MEDIA_DIFF_IR	0x09
315  #define CISTPL_LAN_MEDIA_PTP_IR		0x0a
316  
317  typedef struct cistpl_lan_media_t {
318      u_char	media;
319  } cistpl_lan_media_t;
320  
321  typedef struct cistpl_lan_node_id_t {
322      u_char	nb;
323      u_char	id[16];
324  } cistpl_lan_node_id_t;
325  
326  typedef struct cistpl_lan_connector_t {
327      u_char	code;
328  } cistpl_lan_connector_t;
329  
330  /*======================================================================
331  
332      IDE Function Extension Tuples
333  
334  ======================================================================*/
335  
336  #define CISTPL_IDE_INTERFACE		0x01
337  
338  typedef struct cistpl_ide_interface_t {
339      u_char	interface;
340  } cistpl_ide_interface_t;
341  
342  /* First feature byte */
343  #define CISTPL_IDE_SILICON		0x04
344  #define CISTPL_IDE_UNIQUE		0x08
345  #define CISTPL_IDE_DUAL			0x10
346  
347  /* Second feature byte */
348  #define CISTPL_IDE_HAS_SLEEP		0x01
349  #define CISTPL_IDE_HAS_STANDBY		0x02
350  #define CISTPL_IDE_HAS_IDLE		0x04
351  #define CISTPL_IDE_LOW_POWER		0x08
352  #define CISTPL_IDE_REG_INHIBIT		0x10
353  #define CISTPL_IDE_HAS_INDEX		0x20
354  #define CISTPL_IDE_IOIS16		0x40
355  
356  typedef struct cistpl_ide_feature_t {
357      u_char	feature1;
358      u_char	feature2;
359  } cistpl_ide_feature_t;
360  
361  #define CISTPL_FUNCE_IDE_IFACE		0x01
362  #define CISTPL_FUNCE_IDE_MASTER		0x02
363  #define CISTPL_FUNCE_IDE_SLAVE		0x03
364  
365  /*======================================================================
366  
367      Configuration Table Entries
368  
369  ======================================================================*/
370  
371  #define CISTPL_BAR_SPACE	0x07
372  #define CISTPL_BAR_SPACE_IO	0x10
373  #define CISTPL_BAR_PREFETCH	0x20
374  #define CISTPL_BAR_CACHEABLE	0x40
375  #define CISTPL_BAR_1MEG_MAP	0x80
376  
377  typedef struct cistpl_bar_t {
378      u_char	attr;
379      u_int	size;
380  } cistpl_bar_t;
381  
382  typedef struct cistpl_config_t {
383      u_char	last_idx;
384      u_int	base;
385      u_int	rmask[4];
386      u_char	subtuples;
387  } cistpl_config_t;
388  
389  /* These are bits in the 'present' field, and indices in 'param' */
390  #define CISTPL_POWER_VNOM	0
391  #define CISTPL_POWER_VMIN	1
392  #define CISTPL_POWER_VMAX	2
393  #define CISTPL_POWER_ISTATIC	3
394  #define CISTPL_POWER_IAVG	4
395  #define CISTPL_POWER_IPEAK	5
396  #define CISTPL_POWER_IDOWN	6
397  
398  #define CISTPL_POWER_HIGHZ_OK	0x01
399  #define CISTPL_POWER_HIGHZ_REQ	0x02
400  
401  typedef struct cistpl_power_t {
402      u_char	present;
403      u_char	flags;
404      u_int	param[7];
405  } cistpl_power_t;
406  
407  typedef struct cistpl_timing_t {
408      u_int	wait, waitscale;
409      u_int	ready, rdyscale;
410      u_int	reserved, rsvscale;
411  } cistpl_timing_t;
412  
413  #define CISTPL_IO_LINES_MASK	0x1f
414  #define CISTPL_IO_8BIT		0x20
415  #define CISTPL_IO_16BIT		0x40
416  #define CISTPL_IO_RANGE		0x80
417  
418  #define CISTPL_IO_MAX_WIN	16
419  
420  typedef struct cistpl_io_t {
421      u_char	flags;
422      u_char	nwin;
423      struct {
424  	u_int	base;
425  	u_int	len;
426      } win[CISTPL_IO_MAX_WIN];
427  } cistpl_io_t;
428  
429  typedef struct cistpl_irq_t {
430      u_int	IRQInfo1;
431      u_int	IRQInfo2;
432  } cistpl_irq_t;
433  
434  #define CISTPL_MEM_MAX_WIN	8
435  
436  typedef struct cistpl_mem_t {
437      u_char	flags;
438      u_char	nwin;
439      struct {
440  	u_int	len;
441  	u_int	card_addr;
442  	u_int	host_addr;
443      } win[CISTPL_MEM_MAX_WIN];
444  } cistpl_mem_t;
445  
446  #define CISTPL_CFTABLE_DEFAULT		0x0001
447  #define CISTPL_CFTABLE_BVDS		0x0002
448  #define CISTPL_CFTABLE_WP		0x0004
449  #define CISTPL_CFTABLE_RDYBSY		0x0008
450  #define CISTPL_CFTABLE_MWAIT		0x0010
451  #define CISTPL_CFTABLE_AUDIO		0x0800
452  #define CISTPL_CFTABLE_READONLY		0x1000
453  #define CISTPL_CFTABLE_PWRDOWN		0x2000
454  
455  typedef struct cistpl_cftable_entry_t {
456      u_char		index;
457      u_short		flags;
458      u_char		interface;
459      cistpl_power_t	vcc, vpp1, vpp2;
460      cistpl_timing_t	timing;
461      cistpl_io_t		io;
462      cistpl_irq_t	irq;
463      cistpl_mem_t	mem;
464      u_char		subtuples;
465  } cistpl_cftable_entry_t;
466  
467  #define CISTPL_CFTABLE_MASTER		0x000100
468  #define CISTPL_CFTABLE_INVALIDATE	0x000200
469  #define CISTPL_CFTABLE_VGA_PALETTE	0x000400
470  #define CISTPL_CFTABLE_PARITY		0x000800
471  #define CISTPL_CFTABLE_WAIT		0x001000
472  #define CISTPL_CFTABLE_SERR		0x002000
473  #define CISTPL_CFTABLE_FAST_BACK	0x004000
474  #define CISTPL_CFTABLE_BINARY_AUDIO	0x010000
475  #define CISTPL_CFTABLE_PWM_AUDIO	0x020000
476  
477  typedef struct cistpl_cftable_entry_cb_t {
478      u_char		index;
479      u_int		flags;
480      cistpl_power_t	vcc, vpp1, vpp2;
481      u_char		io;
482      cistpl_irq_t	irq;
483      u_char		mem;
484      u_char		subtuples;
485  } cistpl_cftable_entry_cb_t;
486  
487  typedef struct cistpl_device_geo_t {
488      u_char		ngeo;
489      struct {
490  	u_char		buswidth;
491  	u_int		erase_block;
492  	u_int		read_block;
493  	u_int		write_block;
494  	u_int		partition;
495  	u_int		interleave;
496      } geo[CISTPL_MAX_DEVICES];
497  } cistpl_device_geo_t;
498  
499  typedef struct cistpl_vers_2_t {
500      u_char	vers;
501      u_char	comply;
502      u_short	dindex;
503      u_char	vspec8, vspec9;
504      u_char	nhdr;
505      u_char	vendor, info;
506      char	str[244];
507  } cistpl_vers_2_t;
508  
509  typedef struct cistpl_org_t {
510      u_char	data_org;
511      char	desc[30];
512  } cistpl_org_t;
513  
514  #define CISTPL_ORG_FS		0x00
515  #define CISTPL_ORG_APPSPEC	0x01
516  #define CISTPL_ORG_XIP		0x02
517  
518  typedef struct cistpl_format_t {
519      u_char	type;
520      u_char	edc;
521      u_int	offset;
522      u_int	length;
523  } cistpl_format_t;
524  
525  #define CISTPL_FORMAT_DISK	0x00
526  #define CISTPL_FORMAT_MEM	0x01
527  
528  #define CISTPL_EDC_NONE		0x00
529  #define CISTPL_EDC_CKSUM	0x01
530  #define CISTPL_EDC_CRC		0x02
531  #define CISTPL_EDC_PCC		0x03
532  
533  typedef union cisparse_t {
534      cistpl_device_t		device;
535      cistpl_checksum_t		checksum;
536      cistpl_longlink_t		longlink;
537      cistpl_longlink_mfc_t	longlink_mfc;
538      cistpl_vers_1_t		version_1;
539      cistpl_altstr_t		altstr;
540      cistpl_jedec_t		jedec;
541      cistpl_manfid_t		manfid;
542      cistpl_funcid_t		funcid;
543      cistpl_funce_t		funce;
544      cistpl_bar_t		bar;
545      cistpl_config_t		config;
546      cistpl_cftable_entry_t	cftable_entry;
547      cistpl_cftable_entry_cb_t	cftable_entry_cb;
548      cistpl_device_geo_t		device_geo;
549      cistpl_vers_2_t		vers_2;
550      cistpl_org_t		org;
551      cistpl_format_t		format;
552  } cisparse_t;
553  
554  typedef struct tuple_t {
555      u_int	Attributes;
556      cisdata_t 	DesiredTuple;
557      u_int	Flags;		/* internal use */
558      u_int	LinkOffset;	/* internal use */
559      u_int	CISOffset;	/* internal use */
560      cisdata_t	TupleCode;
561      cisdata_t	TupleLink;
562      cisdata_t	TupleOffset;
563      cisdata_t	TupleDataMax;
564      cisdata_t	TupleDataLen;
565      cisdata_t	*TupleData;
566  } tuple_t;
567  
568  /* Special cisdata_t value */
569  #define RETURN_FIRST_TUPLE	0xff
570  
571  /* Attributes for tuple calls */
572  #define TUPLE_RETURN_LINK	0x01
573  #define TUPLE_RETURN_COMMON	0x02
574  
575  #define CISTPL_MAX_CIS_SIZE	0x200
576  
577  #endif /* LINUX_CISTPL_H */
578