Blame view

include/pcmcia/ss.h 7.87 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  /*
   * ss.h
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   *
   * The initial developer of the original code is David A. Hinds
   * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds
   * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved.
   *
   * (C) 1999             David A. Hinds
   */
  
  #ifndef _LINUX_SS_H
  #define _LINUX_SS_H
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
17
  #include <linux/device.h>
4e57b6817   Tim Schmielau   [PATCH] fix missi...
18
  #include <linux/sched.h>	/* task_struct, completion */
7fe908dd1   Dominik Brodowski   [PATCH] pcmcia: u...
19
  #include <linux/mutex.h>
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
20

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
21
22
23
  #include <pcmcia/cs_types.h>
  #include <pcmcia/cs.h>
  #include <pcmcia/bulkmem.h>
8c3520d4e   Daniel Ritz   [PATCH] yenta: au...
24
25
26
  #ifdef CONFIG_CARDBUS
  #include <linux/pci.h>
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
  
  /* Definitions for card status flags for GetStatus */
  #define SS_WRPROT	0x0001
  #define SS_CARDLOCK	0x0002
  #define SS_EJECTION	0x0004
  #define SS_INSERTION	0x0008
  #define SS_BATDEAD	0x0010
  #define SS_BATWARN	0x0020
  #define SS_READY	0x0040
  #define SS_DETECT	0x0080
  #define SS_POWERON	0x0100
  #define SS_GPI		0x0200
  #define SS_STSCHG	0x0400
  #define SS_CARDBUS	0x0800
  #define SS_3VCARD	0x1000
  #define SS_XVCARD	0x2000
  #define SS_PENDING	0x4000
  #define SS_ZVCARD	0x8000
  
  /* InquireSocket capabilities */
  #define SS_CAP_PAGE_REGS	0x0001
  #define SS_CAP_VIRTUAL_BUS	0x0002
  #define SS_CAP_MEM_ALIGN	0x0004
  #define SS_CAP_STATIC_MAP	0x0008
  #define SS_CAP_PCCARD		0x4000
  #define SS_CAP_CARDBUS		0x8000
  
  /* for GetSocket, SetSocket */
  typedef struct socket_state_t {
      u_int	flags;
      u_int	csc_mask;
      u_char	Vcc, Vpp;
      u_char	io_irq;
  } socket_state_t;
  
  extern socket_state_t dead_socket;
  
  /* Socket configuration flags */
  #define SS_PWR_AUTO	0x0010
  #define SS_IOCARD	0x0020
  #define SS_RESET	0x0040
  #define SS_DMA_MODE	0x0080
  #define SS_SPKR_ENA	0x0100
  #define SS_OUTPUT_ENA	0x0200
  
  /* Flags for I/O port and memory windows */
  #define MAP_ACTIVE	0x01
  #define MAP_16BIT	0x02
  #define MAP_AUTOSZ	0x04
  #define MAP_0WS		0x08
  #define MAP_WRPROT	0x10
  #define MAP_ATTRIB	0x20
  #define MAP_USE_WAIT	0x40
  #define MAP_PREFETCH	0x80
  
  /* Use this just for bridge windows */
  #define MAP_IOSPACE	0x20
fa912bcb0   Daniel Ritz   [PATCH] yenta TI:...
84
85
86
  /* power hook operations */
  #define HOOK_POWER_PRE	0x01
  #define HOOK_POWER_POST	0x02
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
  typedef struct pccard_io_map {
      u_char	map;
      u_char	flags;
      u_short	speed;
      kio_addr_t	start, stop;
  } pccard_io_map;
  
  typedef struct pccard_mem_map {
      u_char	map;
      u_char	flags;
      u_short	speed;
      u_long	static_start;
      u_int	card_start;
      struct resource *res;
  } pccard_mem_map;
  
  typedef struct cb_bridge_map {
      u_char	map;
      u_char	flags;
      u_int	start, stop;
  } cb_bridge_map;
  
  /*
   * Socket operations.
   */
  struct pcmcia_socket;
  
  struct pccard_operations {
  	int (*init)(struct pcmcia_socket *sock);
  	int (*suspend)(struct pcmcia_socket *sock);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
117
  	int (*get_status)(struct pcmcia_socket *sock, u_int *value);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
118
119
120
121
122
123
  	int (*set_socket)(struct pcmcia_socket *sock, socket_state_t *state);
  	int (*set_io_map)(struct pcmcia_socket *sock, struct pccard_io_map *io);
  	int (*set_mem_map)(struct pcmcia_socket *sock, struct pccard_mem_map *mem);
  };
  
  struct pccard_resource_ops {
de75914ee   Dominik Brodowski   [PATCH] pcmcia: v...
124
  	int	(*validate_mem)		(struct pcmcia_socket *s);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
  	int	(*adjust_io_region)	(struct resource *res,
  					 unsigned long r_start,
  					 unsigned long r_end,
  					 struct pcmcia_socket *s);
  	struct resource* (*find_io)	(unsigned long base, int num,
  					 unsigned long align,
  					 struct pcmcia_socket *s);
  	struct resource* (*find_mem)	(unsigned long base, unsigned long num,
  					 unsigned long align, int low,
  					 struct pcmcia_socket *s);
  	int	(*adjust_resource)	(struct pcmcia_socket *s,
  					 adjust_t *adj);
  	int	(*init)			(struct pcmcia_socket *s);
  	void	(*exit)			(struct pcmcia_socket *s);
  };
  /* SS_CAP_STATIC_MAP */
  extern struct pccard_resource_ops pccard_static_ops;
  /* !SS_CAP_STATIC_MAP */
  extern struct pccard_resource_ops pccard_nonstatic_ops;
553ee5dc1   Marcelo Tosatti   [PATCH] pcmcia: d...
144
145
  /* static mem, dynamic IO sockets */
  extern struct pccard_resource_ops pccard_iodyn_ops;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
146
147
148
149
150
151
  /*
   *  Calls to set up low-level "Socket Services" drivers
   */
  struct pcmcia_socket;
  
  typedef struct io_window_t {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
152
153
154
155
156
157
158
159
  	kio_addr_t		InUse, Config;
  	struct resource		*res;
  } io_window_t;
  
  #define WINDOW_MAGIC	0xB35C
  typedef struct window_t {
  	u_short			magic;
  	u_short			index;
fba395eee   Dominik Brodowski   [PATCH] pcmcia: r...
160
  	struct pcmcia_device	*handle;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
161
162
163
164
165
166
167
168
169
170
171
172
  	struct pcmcia_socket 	*sock;
  	pccard_mem_map		ctl;
  } window_t;
  
  /* Maximum number of IO windows per socket */
  #define MAX_IO_WIN 2
  
  /* Maximum number of memory windows per socket */
  #define MAX_WIN 4
  
  struct config_t;
  struct pcmcia_callback;
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
173
  struct user_info_t;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
174
175
176
177
178
179
180
181
182
183
  
  struct pcmcia_socket {
  	struct module			*owner;
  	spinlock_t			lock;
  	socket_state_t			socket;
  	u_int				state;
  	u_short				functions;
  	u_short				lock_count;
  	pccard_mem_map			cis_mem;
  	void __iomem 			*cis_virt;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
  	struct {
  		u_int			AssignedIRQ;
  		u_int			Config;
  	} irq;
  	io_window_t			io[MAX_IO_WIN];
  	window_t			win[MAX_WIN];
  	struct list_head		cis_cache;
  	u_int				fake_cis_len;
  	char				*fake_cis;
  
  	struct list_head		socket_list;
  	struct completion		socket_released;
  
   	/* deprecated */
  	unsigned int			sock;		/* socket number */
  
  
  	/* socket capabilities */
  	u_int				features;
  	u_int				irq_mask;
  	u_int				map_size;
  	kio_addr_t			io_offset;
  	u_char				pci_irq;
  	struct pci_dev *		cb_dev;
  
  
  	/* socket setup is done so resources should be able to be allocated. Only
  	 * if set to 1, calls to find_{io,mem}_region are handled, and insertion
  	 * events are actually managed by the PCMCIA layer.*/
  	u8				resource_setup_done:1;
  
  	/* is set to one if resource setup is done using adjust_resource_info() */
  	u8				resource_setup_old:1;
3c29976a6   Dominik Brodowski   [PATCH] pcmcia: m...
217
  	u8				resource_setup_new:1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
218

3c29976a6   Dominik Brodowski   [PATCH] pcmcia: m...
219
  	u8				reserved:5;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
220
221
222
223
224
225
226
227
228
  
  	/* socket operations */
  	struct pccard_operations *	ops;
  	struct pccard_resource_ops *	resource_ops;
  	void *				resource_data;
  
  	/* Zoom video behaviour is so chip specific its not worth adding
  	   this to _ops */
  	void 				(*zoom_video)(struct pcmcia_socket *, int);
fa912bcb0   Daniel Ritz   [PATCH] yenta TI:...
229
230
231
  
  	/* so is power hook */
  	int (*power_hook)(struct pcmcia_socket *sock, int operation);
8c3520d4e   Daniel Ritz   [PATCH] yenta: au...
232
233
234
235
  #ifdef CONFIG_CARDBUS
  	/* allows tuning the CB bridge before loading driver for the CB card */
  	void (*tune_bridge)(struct pcmcia_socket *sock, struct pci_bus *bus);
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
236
  	/* state thread */
7fe908dd1   Dominik Brodowski   [PATCH] pcmcia: u...
237
  	struct mutex			skt_mutex;	/* protects socket h/w state */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
238
239
240
241
242
243
244
245
  
  	struct task_struct		*thread;
  	struct completion		thread_done;
  	wait_queue_head_t		thread_wait;
  	spinlock_t			thread_lock;	/* protects thread_events */
  	unsigned int			thread_events;
  
  	/* pcmcia (16-bit) */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
246
  	struct pcmcia_callback		*callback;
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
247
248
249
250
251
252
253
254
255
256
  #if defined(CONFIG_PCMCIA) || defined(CONFIG_PCMCIA_MODULE)
  	struct list_head		devices_list;	/*  PCMCIA devices */
  	u8				device_count;	/* the number of devices, used
  							 * only internally and subject
  							 * to incorrectness and change */
  
  	struct {
  		u8			present:1,	/* PCMCIA card is present in socket */
  					busy:1,		/* "master" ioctl is used */
  					dead:1,		/* pcmcia module is being unloaded */
1d2c90425   Dominik Brodowski   [PATCH] pcmcia: m...
257
  					device_add_pending:1, /* a multifunction-device
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
258
  							       * add event is pending */
1d2c90425   Dominik Brodowski   [PATCH] pcmcia: m...
259
260
  					mfc_pfc:1,	/* the pending event adds a mfc (1) or pfc (0) */
  					reserved:3;
dc109497b   Dominik Brodowski   [PATCH] pcmcia: m...
261
262
263
264
265
266
267
268
269
270
  	} 				pcmcia_state;
  
  	struct work_struct		device_add;	/* for adding further pseudo-multifunction
  							 * devices */
  
  #ifdef CONFIG_PCMCIA_IOCTL
  	struct user_info_t		*user;
  	wait_queue_head_t		queue;
  #endif
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
271
272
273
274
275
276
277
  	/* cardbus (32-bit) */
  #ifdef CONFIG_CARDBUS
  	struct resource *		cb_cis_res;
  	void __iomem			*cb_cis_virt;
  #endif
  
  	/* socket device */
873733188   Greg Kroah-Hartman   Driver core: conv...
278
  	struct device			dev;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
  	void				*driver_data;	/* data internal to the socket driver */
  
  };
  
  struct pcmcia_socket * pcmcia_get_socket_by_nr(unsigned int nr);
  
  
  
  extern void pcmcia_parse_events(struct pcmcia_socket *socket, unsigned int events);
  extern int pcmcia_register_socket(struct pcmcia_socket *socket);
  extern void pcmcia_unregister_socket(struct pcmcia_socket *socket);
  
  extern struct class pcmcia_socket_class;
  
  /* socket drivers are expected to use these callbacks in their .drv struct */
  extern int pcmcia_socket_dev_suspend(struct device *dev, pm_message_t state);
  extern int pcmcia_socket_dev_resume(struct device *dev);
  
  #endif /* _LINUX_SS_H */