aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorDominik Brodowski <linux@dominikbrodowski.net>2010-07-30 07:13:46 -0400
committerDominik Brodowski <linux@dominikbrodowski.net>2010-09-29 11:20:24 -0400
commit00990e7ce0b0e596fe41d9c64d6933ea70084003 (patch)
tree189e0dd92860feba84231c66955749574cac5d6d /include
parent440eed43e2a95bb842488755683716814da10f2b (diff)
pcmcia: use autoconfiguration feature for ioports and iomem
When CONF_AUTO_SET_IO or CONF_AUTO_SET_IOMEM are set, the corresponding fields in struct pcmcia_device *p_dev->resource[0,1,2] are set accordinly. Drivers wishing to override certain settings may do so in the callback function, but they no longer need to parse the CIS entries stored in cistpl_cftable_entry_t themselves. CC: netdev@vger.kernel.org CC: linux-wireless@vger.kernel.org CC: linux-ide@vger.kernel.org CC: linux-usb@vger.kernel.org CC: laforge@gnumonks.org CC: linux-mtd@lists.infradead.org CC: linux-bluetooth@vger.kernel.org CC: alsa-devel@alsa-project.org CC: linux-serial@vger.kernel.org CC: Jiri Kosina <jkosina@suse.cz> CC: linux-scsi@vger.kernel.org Tested-by: Wolfram Sang <w.sang@pengutronix.de> Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'include')
-rw-r--r--include/pcmcia/ds.h30
1 files changed, 10 insertions, 20 deletions
diff --git a/include/pcmcia/ds.h b/include/pcmcia/ds.h
index 0577e5f10304..0b8c8d45df47 100644
--- a/include/pcmcia/ds.h
+++ b/include/pcmcia/ds.h
@@ -93,6 +93,7 @@ struct pcmcia_device {
93 /* device setup */ 93 /* device setup */
94 unsigned int irq; 94 unsigned int irq;
95 struct resource *resource[PCMCIA_NUM_RESOURCES]; 95 struct resource *resource[PCMCIA_NUM_RESOURCES];
96 resource_size_t card_addr; /* for the 1st IOMEM resource */
96 unsigned int vpp; 97 unsigned int vpp;
97 98
98 unsigned int config_flags; /* CONF_ENABLE_ flags below */ 99 unsigned int config_flags; /* CONF_ENABLE_ flags below */
@@ -175,8 +176,6 @@ int pcmcia_parse_tuple(tuple_t *tuple, cisparse_t *parse);
175/* loop CIS entries for valid configuration */ 176/* loop CIS entries for valid configuration */
176int pcmcia_loop_config(struct pcmcia_device *p_dev, 177int pcmcia_loop_config(struct pcmcia_device *p_dev,
177 int (*conf_check) (struct pcmcia_device *p_dev, 178 int (*conf_check) (struct pcmcia_device *p_dev,
178 cistpl_cftable_entry_t *cf,
179 cistpl_cftable_entry_t *dflt,
180 void *priv_data), 179 void *priv_data),
181 void *priv_data); 180 void *priv_data);
182 181
@@ -225,16 +224,6 @@ void pcmcia_disable_device(struct pcmcia_device *p_dev);
225#define IO_DATA_PATH_WIDTH_16 0x08 224#define IO_DATA_PATH_WIDTH_16 0x08
226#define IO_DATA_PATH_WIDTH_AUTO 0x10 225#define IO_DATA_PATH_WIDTH_AUTO 0x10
227 226
228/* convert flag found in cfgtable to data path width parameter */
229static inline int pcmcia_io_cfg_data_width(unsigned int flags)
230{
231 if (!(flags & CISTPL_IO_8BIT))
232 return IO_DATA_PATH_WIDTH_16;
233 if (!(flags & CISTPL_IO_16BIT))
234 return IO_DATA_PATH_WIDTH_8;
235 return IO_DATA_PATH_WIDTH_AUTO;
236}
237
238/* IO memory */ 227/* IO memory */
239#define WIN_MEMORY_TYPE_CM 0x00 /* default */ 228#define WIN_MEMORY_TYPE_CM 0x00 /* default */
240#define WIN_MEMORY_TYPE_AM 0x20 /* MAP_ATTRIB */ 229#define WIN_MEMORY_TYPE_AM 0x20 /* MAP_ATTRIB */
@@ -264,16 +253,17 @@ static inline int pcmcia_io_cfg_data_width(unsigned int flags)
264#define PRESENT_IOSIZE 0x200 253#define PRESENT_IOSIZE 0x200
265 254
266/* flags to be passed to pcmcia_enable_device() */ 255/* flags to be passed to pcmcia_enable_device() */
267#define CONF_ENABLE_IRQ 0x01 256#define CONF_ENABLE_IRQ 0x0001
268#define CONF_ENABLE_SPKR 0x02 257#define CONF_ENABLE_SPKR 0x0002
269#define CONF_ENABLE_PULSE_IRQ 0x04 258#define CONF_ENABLE_PULSE_IRQ 0x0004
270#define CONF_ENABLE_ESR 0x08 259#define CONF_ENABLE_ESR 0x0008
271 260
272/* flags used by pcmcia_loop_config() autoconfiguration */ 261/* flags used by pcmcia_loop_config() autoconfiguration */
273#define CONF_AUTO_CHECK_VCC 0x10 /* check for matching Vcc? */ 262#define CONF_AUTO_CHECK_VCC 0x0100 /* check for matching Vcc? */
274#define CONF_AUTO_SET_VPP 0x20 /* set Vpp? */ 263#define CONF_AUTO_SET_VPP 0x0200 /* set Vpp? */
275#define CONF_AUTO_AUDIO 0x40 /* enable audio line? */ 264#define CONF_AUTO_AUDIO 0x0400 /* enable audio line? */
276 265#define CONF_AUTO_SET_IO 0x0800 /* set ->resource[0,1] */
266#define CONF_AUTO_SET_IOMEM 0x1000 /* set ->resource[2] */
277 267
278#endif /* __KERNEL__ */ 268#endif /* __KERNEL__ */
279 269