blob: 37d38b5a1972e1cdb79e43029af39c1ee52cb815 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Dominik Brodowskidc953e52008-08-25 23:18:20 +02002 * cs_internal.h -- definitions internal to the PCMCIA core modules
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * The initial developer of the original code is David A. Hinds
9 * <dahinds@users.sourceforge.net>. Portions created by David A. Hinds
10 * are Copyright (C) 1999 David A. Hinds. All Rights Reserved.
11 *
12 * (C) 1999 David A. Hinds
Dominik Brodowski7b24e792010-07-11 10:26:53 +020013 * (C) 2003 - 2010 Dominik Brodowski
Dominik Brodowskidc953e52008-08-25 23:18:20 +020014 *
15 *
16 * This file contains definitions _only_ needed by the PCMCIA core modules.
17 * It must not be included by PCMCIA socket drivers or by PCMCIA device
18 * drivers.
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 */
20
21#ifndef _LINUX_CS_INTERNAL_H
22#define _LINUX_CS_INTERNAL_H
23
Dominik Brodowski360b65b2006-01-10 20:50:39 +010024#include <linux/kref.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Linus Torvalds1da177e2005-04-16 15:20:36 -070026/* Flags in client state */
Dominik Brodowskie2d40962006-03-02 00:09:29 +010027#define CLIENT_WIN_REQ(i) (0x1<<(i))
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Dominik Brodowskia3d0d4d2010-07-24 17:43:10 +020029/* Flag to access all functions */
30#define BIND_FN_ALL 0xff
31
Linus Torvalds1da177e2005-04-16 15:20:36 -070032/* Each card function gets one of these guys */
33typedef struct config_t {
Dominik Brodowski360b65b2006-01-10 20:50:39 +010034 struct kref ref;
Dominik Brodowskidc953e52008-08-25 23:18:20 +020035 unsigned int state;
36 unsigned int Attributes;
37 unsigned int IntType;
38 unsigned int ConfigBase;
39 unsigned char Status, Pin, Copy, Option, ExtStatus;
40 unsigned int CardValues;
Dominik Brodowski2ce49052010-07-24 13:14:44 +020041
42 struct resource io[MAX_IO_WIN]; /* io ports */
Dominik Brodowski0ca724d2010-07-24 19:03:02 +020043 struct resource mem[MAX_WIN]; /* mem areas */
Dominik Brodowski2ce49052010-07-24 13:14:44 +020044
Dominik Brodowskidc953e52008-08-25 23:18:20 +020045 struct {
46 u_int Attributes;
47 } irq;
Linus Torvalds1da177e2005-04-16 15:20:36 -070048} config_t;
49
Dominik Brodowskidc953e52008-08-25 23:18:20 +020050
Linus Torvalds1da177e2005-04-16 15:20:36 -070051struct cis_cache_entry {
52 struct list_head node;
53 unsigned int addr;
54 unsigned int len;
55 unsigned int attr;
56 unsigned char cache[0];
57};
58
Dominik Brodowskic23889c2008-08-26 00:09:56 +020059struct pccard_resource_ops {
60 int (*validate_mem) (struct pcmcia_socket *s);
Dominik Brodowskib19a7272010-03-20 13:10:47 +010061 int (*find_io) (struct pcmcia_socket *s,
62 unsigned int attr,
63 unsigned int *base,
64 unsigned int num,
65 unsigned int align);
Dominik Brodowskic23889c2008-08-26 00:09:56 +020066 struct resource* (*find_mem) (unsigned long base, unsigned long num,
67 unsigned long align, int low,
68 struct pcmcia_socket *s);
Dominik Brodowskic23889c2008-08-26 00:09:56 +020069 int (*init) (struct pcmcia_socket *s);
70 void (*exit) (struct pcmcia_socket *s);
71};
72
Linus Torvalds1da177e2005-04-16 15:20:36 -070073/* Flags in config state */
74#define CONFIG_LOCKED 0x01
75#define CONFIG_IRQ_REQ 0x02
76#define CONFIG_IO_REQ 0x04
77
78/* Flags in socket state */
79#define SOCKET_PRESENT 0x0008
80#define SOCKET_INUSE 0x0010
81#define SOCKET_SUSPEND 0x0080
82#define SOCKET_WIN_REQ(i) (0x0100<<(i))
Linus Torvalds1da177e2005-04-16 15:20:36 -070083#define SOCKET_CARDBUS 0x8000
84#define SOCKET_CARDBUS_CONFIG 0x10000
85
Dominik Brodowskidc953e52008-08-25 23:18:20 +020086
87/*
Dominik Brodowski49b11532010-03-07 16:41:57 +010088 * Stuff internal to module "pcmcia_rsrc":
89 */
90extern int static_init(struct pcmcia_socket *s);
91extern struct resource *pcmcia_make_resource(unsigned long start,
92 unsigned long end,
93 int flags, const char *name);
94
95/*
Dominik Brodowskidc953e52008-08-25 23:18:20 +020096 * Stuff internal to module "pcmcia_core":
97 */
98
Dominik Brodowskidc953e52008-08-25 23:18:20 +020099/* socket_sysfs.c */
100extern int pccard_sysfs_add_socket(struct device *dev);
101extern void pccard_sysfs_remove_socket(struct device *dev);
102
103/* cardbus.c */
104int cb_alloc(struct pcmcia_socket *s);
105void cb_free(struct pcmcia_socket *s);
Dominik Brodowskidc953e52008-08-25 23:18:20 +0200106
107
108
109/*
110 * Stuff exported by module "pcmcia_core" to module "pcmcia"
111 */
112
113struct pcmcia_callback{
114 struct module *owner;
Dominik Brodowski7b24e792010-07-11 10:26:53 +0200115 int (*add) (struct pcmcia_socket *s);
116 int (*remove) (struct pcmcia_socket *s);
Dominik Brodowskiaf461fc2010-01-17 19:30:53 +0100117 void (*requery) (struct pcmcia_socket *s);
Dominik Brodowski6e7b51a2010-01-06 13:57:43 +0100118 int (*validate) (struct pcmcia_socket *s, unsigned int *i);
Dominik Brodowskidc953e52008-08-25 23:18:20 +0200119 int (*suspend) (struct pcmcia_socket *s);
Dominik Brodowski7b24e792010-07-11 10:26:53 +0200120 int (*early_resume) (struct pcmcia_socket *s);
Dominik Brodowskidc953e52008-08-25 23:18:20 +0200121 int (*resume) (struct pcmcia_socket *s);
122};
123
124/* cs.c */
125extern struct rw_semaphore pcmcia_socket_list_rwsem;
126extern struct list_head pcmcia_socket_list;
Dominik Brodowskic23889c2008-08-26 00:09:56 +0200127extern struct class pcmcia_socket_class;
128
Dominik Brodowskidc953e52008-08-25 23:18:20 +0200129int pccard_register_pcmcia(struct pcmcia_socket *s, struct pcmcia_callback *c);
Dominik Brodowskic23889c2008-08-26 00:09:56 +0200130struct pcmcia_socket *pcmcia_get_socket_by_nr(unsigned int nr);
Dominik Brodowskidc953e52008-08-25 23:18:20 +0200131
Dominik Brodowskif971dbd2010-01-17 18:13:31 +0100132void pcmcia_parse_uevents(struct pcmcia_socket *socket, unsigned int events);
133#define PCMCIA_UEVENT_EJECT 0x0001
134#define PCMCIA_UEVENT_INSERT 0x0002
135#define PCMCIA_UEVENT_SUSPEND 0x0004
136#define PCMCIA_UEVENT_RESUME 0x0008
Dominik Brodowskiaf461fc2010-01-17 19:30:53 +0100137#define PCMCIA_UEVENT_REQUERY 0x0010
Dominik Brodowski994917f2008-08-31 15:20:26 +0200138
139struct pcmcia_socket *pcmcia_get_socket(struct pcmcia_socket *skt);
140void pcmcia_put_socket(struct pcmcia_socket *skt);
141
Dominik Brodowskib60a5ed2008-08-25 23:32:37 +0200142/*
143 * Stuff internal to module "pcmcia".
144 */
145/* ds.c */
146extern struct bus_type pcmcia_bus_type;
147
Dominik Brodowski5716d412010-07-11 09:51:14 +0200148struct pcmcia_device;
149
Dominik Brodowskib60a5ed2008-08-25 23:32:37 +0200150/* pcmcia_resource.c */
151extern int pcmcia_release_configuration(struct pcmcia_device *p_dev);
Dominik Brodowskia3ac9af2010-01-06 14:03:03 +0100152extern int pcmcia_validate_mem(struct pcmcia_socket *s);
153extern struct resource *pcmcia_find_mem_region(u_long base,
154 u_long num,
155 u_long align,
156 int low,
157 struct pcmcia_socket *s);
158
Dominik Brodowski6f0f38c2010-04-08 20:33:16 +0200159void pcmcia_cleanup_irq(struct pcmcia_socket *s);
160int pcmcia_setup_irq(struct pcmcia_device *p_dev);
Dominik Brodowskib60a5ed2008-08-25 23:32:37 +0200161
Dominik Brodowski6e7b51a2010-01-06 13:57:43 +0100162/* cistpl.c */
163extern struct bin_attribute pccard_cis_attr;
164
165int pcmcia_read_cis_mem(struct pcmcia_socket *s, int attr,
166 u_int addr, u_int len, void *ptr);
Dominik Brodowski1d5cc192010-07-24 12:23:21 +0200167int pcmcia_write_cis_mem(struct pcmcia_socket *s, int attr,
168 u_int addr, u_int len, void *ptr);
Dominik Brodowski6e7b51a2010-01-06 13:57:43 +0100169void release_cis_mem(struct pcmcia_socket *s);
170void destroy_cis_cache(struct pcmcia_socket *s);
171int pccard_read_tuple(struct pcmcia_socket *s, unsigned int function,
172 cisdata_t code, void *parse);
173int pcmcia_replace_cis(struct pcmcia_socket *s,
174 const u8 *data, const size_t len);
175int pccard_validate_cis(struct pcmcia_socket *s, unsigned int *count);
176int verify_cis_cache(struct pcmcia_socket *s);
177
178int pccard_loop_tuple(struct pcmcia_socket *s, unsigned int function,
179 cisdata_t code, cisparse_t *parse, void *priv_data,
180 int (*loop_tuple) (tuple_t *tuple,
181 cisparse_t *parse,
182 void *priv_data));
183
184int pccard_get_first_tuple(struct pcmcia_socket *s, unsigned int function,
185 tuple_t *tuple);
186
187int pccard_get_next_tuple(struct pcmcia_socket *s, unsigned int function,
188 tuple_t *tuple);
189
190int pccard_get_tuple_data(struct pcmcia_socket *s, tuple_t *tuple);
191
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192#endif /* _LINUX_CS_INTERNAL_H */