aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDominik Brodowski <linux@dominikbrodowski.net>2009-10-28 19:54:49 -0400
committerDominik Brodowski <linux@dominikbrodowski.net>2009-11-09 02:30:17 -0500
commit55a19b39acb8888af8e9cfe5b762d03c52fdb48c (patch)
tree6572e3290b74171a9b317ac4324a2990a351d437
parent66024db57d5b9011e274b314affad68f370c0d6f (diff)
pcmcia/staging: update comedi drivers
Update comedi PCMCIA drivers to work with recent PCMCIA changes documented in Documentation/pcmcia/driver-changes.txt: - use pcmcia_config_loop() - don't use PCMCIA_DEBUG, but use dev_dbg() - don't use cs_error() - re-use prod_id and card_id values already stored Acked-by: Greg Kroah-Hartman <gregkh@suse.de> Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
-rw-r--r--drivers/staging/comedi/drivers/cb_das16_cs.c220
-rw-r--r--drivers/staging/comedi/drivers/das08_cs.c202
-rw-r--r--drivers/staging/comedi/drivers/ni_daq_700.c236
-rw-r--r--drivers/staging/comedi/drivers/ni_daq_dio24.c235
-rw-r--r--drivers/staging/comedi/drivers/ni_labpc_cs.c224
-rw-r--r--drivers/staging/comedi/drivers/ni_mio_cs.c127
-rw-r--r--drivers/staging/comedi/drivers/quatech_daqp_cs.c215
7 files changed, 424 insertions, 1035 deletions
diff --git a/drivers/staging/comedi/drivers/cb_das16_cs.c b/drivers/staging/comedi/drivers/cb_das16_cs.c
index 80c0df8656f..9e758027efe 100644
--- a/drivers/staging/comedi/drivers/cb_das16_cs.c
+++ b/drivers/staging/comedi/drivers/cb_das16_cs.c
@@ -141,37 +141,14 @@ static int das16cs_timer_insn_config(struct comedi_device *dev,
141 struct comedi_insn *insn, 141 struct comedi_insn *insn,
142 unsigned int *data); 142 unsigned int *data);
143 143
144static int get_prodid(struct comedi_device *dev, struct pcmcia_device *link)
145{
146 tuple_t tuple;
147 u_short buf[128];
148 int prodid = 0;
149
150 tuple.TupleData = (cisdata_t *) buf;
151 tuple.TupleOffset = 0;
152 tuple.TupleDataMax = 255;
153 tuple.DesiredTuple = CISTPL_MANFID;
154 tuple.Attributes = TUPLE_RETURN_COMMON;
155 if ((pcmcia_get_first_tuple(link, &tuple) == 0) &&
156 (pcmcia_get_tuple_data(link, &tuple) == 0)) {
157 prodid = le16_to_cpu(buf[1]);
158 }
159
160 return prodid;
161}
162
163static const struct das16cs_board *das16cs_probe(struct comedi_device *dev, 144static const struct das16cs_board *das16cs_probe(struct comedi_device *dev,
164 struct pcmcia_device *link) 145 struct pcmcia_device *link)
165{ 146{
166 int id;
167 int i; 147 int i;
168 148
169 id = get_prodid(dev, link);
170
171 for (i = 0; i < n_boards; i++) { 149 for (i = 0; i < n_boards; i++) {
172 if (das16cs_boards[i].device_id == id) { 150 if (das16cs_boards[i].device_id == link->card_id)
173 return das16cs_boards + i; 151 return das16cs_boards + i;
174 }
175 } 152 }
176 153
177 printk("unknown board!\n"); 154 printk("unknown board!\n");
@@ -660,27 +637,8 @@ static int das16cs_timer_insn_config(struct comedi_device *dev,
660 637
661======================================================================*/ 638======================================================================*/
662 639
663/*
664 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
665 you do not define PCMCIA_DEBUG at all, all the debug code will be
666 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
667 be present but disabled -- but it can then be enabled for specific
668 modules at load time with a 'pc_debug=#' option to insmod.
669*/
670#if defined(CONFIG_PCMCIA) || defined(CONFIG_PCMCIA_MODULE) 640#if defined(CONFIG_PCMCIA) || defined(CONFIG_PCMCIA_MODULE)
671 641
672#ifdef PCMCIA_DEBUG
673static int pc_debug = PCMCIA_DEBUG;
674module_param(pc_debug, int, 0644);
675#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
676static char *version =
677 "cb_das16_cs.c pcmcia code (David Schleef), modified from dummy_cs.c 1.31 2001/08/24 12:13:13 (David Hinds)";
678#else
679#define DEBUG(n, args...)
680#endif
681
682/*====================================================================*/
683
684static void das16cs_pcmcia_config(struct pcmcia_device *link); 642static void das16cs_pcmcia_config(struct pcmcia_device *link);
685static void das16cs_pcmcia_release(struct pcmcia_device *link); 643static void das16cs_pcmcia_release(struct pcmcia_device *link);
686static int das16cs_pcmcia_suspend(struct pcmcia_device *p_dev); 644static int das16cs_pcmcia_suspend(struct pcmcia_device *p_dev);
@@ -733,7 +691,7 @@ static int das16cs_pcmcia_attach(struct pcmcia_device *link)
733{ 691{
734 struct local_info_t *local; 692 struct local_info_t *local;
735 693
736 DEBUG(0, "das16cs_pcmcia_attach()\n"); 694 dev_dbg(&link->dev, "das16cs_pcmcia_attach()\n");
737 695
738 /* Allocate space for private device-specific data */ 696 /* Allocate space for private device-specific data */
739 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL); 697 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL);
@@ -760,7 +718,7 @@ static int das16cs_pcmcia_attach(struct pcmcia_device *link)
760 718
761static void das16cs_pcmcia_detach(struct pcmcia_device *link) 719static void das16cs_pcmcia_detach(struct pcmcia_device *link)
762{ 720{
763 DEBUG(0, "das16cs_pcmcia_detach(0x%p)\n", link); 721 dev_dbg(&link->dev, "das16cs_pcmcia_detach\n");
764 722
765 if (link->dev_node) { 723 if (link->dev_node) {
766 ((struct local_info_t *)link->priv)->stop = 1; 724 ((struct local_info_t *)link->priv)->stop = 1;
@@ -771,118 +729,55 @@ static void das16cs_pcmcia_detach(struct pcmcia_device *link)
771 kfree(link->priv); 729 kfree(link->priv);
772} /* das16cs_pcmcia_detach */ 730} /* das16cs_pcmcia_detach */
773 731
774static void das16cs_pcmcia_config(struct pcmcia_device *link)
775{
776 struct local_info_t *dev = link->priv;
777 tuple_t tuple;
778 cisparse_t parse;
779 int last_fn, last_ret;
780 u_char buf[64];
781 cistpl_cftable_entry_t dflt = { 0 };
782 732
783 DEBUG(0, "das16cs_pcmcia_config(0x%p)\n", link); 733static int das16cs_pcmcia_config_loop(struct pcmcia_device *p_dev,
784 734 cistpl_cftable_entry_t *cfg,
785 /* 735 cistpl_cftable_entry_t *dflt,
786 This reads the card's CONFIG tuple to find its configuration 736 unsigned int vcc,
787 registers. 737 void *priv_data)
788 */ 738{
789 tuple.DesiredTuple = CISTPL_CONFIG; 739 if (cfg->index == 0)
790 tuple.Attributes = 0; 740 return -EINVAL;
791 tuple.TupleData = buf;
792 tuple.TupleDataMax = sizeof(buf);
793 tuple.TupleOffset = 0;
794
795 last_fn = GetFirstTuple;
796 last_ret = pcmcia_get_first_tuple(link, &tuple);
797 if (last_ret != 0)
798 goto cs_failed;
799
800 last_fn = GetTupleData;
801 last_ret = pcmcia_get_tuple_data(link, &tuple);
802 if (last_ret != 0)
803 goto cs_failed;
804
805 last_fn = ParseTuple;
806 last_ret = pcmcia_parse_tuple(&tuple, &parse);
807 if (last_ret != 0)
808 goto cs_failed;
809
810 link->conf.ConfigBase = parse.config.base;
811 link->conf.Present = parse.config.rmask[0];
812 741
813 /* 742 /* Do we need to allocate an interrupt? */
814 In this loop, we scan the CIS for configuration table entries, 743 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
815 each of which describes a valid card configuration, including 744 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
816 voltage, IO window, memory window, and interrupt settings. 745
817 746 /* IO window settings */
818 We make no assumptions about the card to be configured: we use 747 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
819 just the information available in the CIS. In an ideal world, 748 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
820 this would work for any PCMCIA card, but it requires a complete 749 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
821 and accurate CIS. In practice, a driver usually "knows" most of 750 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
822 these things without consulting the CIS, and most client drivers 751 if (!(io->flags & CISTPL_IO_8BIT))
823 will only use the CIS to fill in implementation-defined details. 752 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
824 */ 753 if (!(io->flags & CISTPL_IO_16BIT))
825 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY; 754 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
826 last_fn = GetFirstTuple; 755 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
827 756 p_dev->io.BasePort1 = io->win[0].base;
828 last_ret = pcmcia_get_first_tuple(link, &tuple); 757 p_dev->io.NumPorts1 = io->win[0].len;
829 if (last_ret) 758 if (io->nwin > 1) {
830 goto cs_failed; 759 p_dev->io.Attributes2 = p_dev->io.Attributes1;
831 760 p_dev->io.BasePort2 = io->win[1].base;
832 while (1) { 761 p_dev->io.NumPorts2 = io->win[1].len;
833 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry);
834 if (pcmcia_get_tuple_data(link, &tuple))
835 goto next_entry;
836 if (pcmcia_parse_tuple(&tuple, &parse))
837 goto next_entry;
838
839 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
840 dflt = *cfg;
841 if (cfg->index == 0)
842 goto next_entry;
843 link->conf.ConfigIndex = cfg->index;
844
845 /* Does this card need audio output? */
846/* if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
847 link->conf.Attributes |= CONF_ENABLE_SPKR;
848 link->conf.Status = CCSR_AUDIO_ENA;
849 }
850*/
851 /* Do we need to allocate an interrupt? */
852 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1)
853 link->conf.Attributes |= CONF_ENABLE_IRQ;
854
855 /* IO window settings */
856 link->io.NumPorts1 = link->io.NumPorts2 = 0;
857 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
858 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
859 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
860 if (!(io->flags & CISTPL_IO_8BIT))
861 link->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
862 if (!(io->flags & CISTPL_IO_16BIT))
863 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
864 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
865 link->io.BasePort1 = io->win[0].base;
866 link->io.NumPorts1 = io->win[0].len;
867 if (io->nwin > 1) {
868 link->io.Attributes2 = link->io.Attributes1;
869 link->io.BasePort2 = io->win[1].base;
870 link->io.NumPorts2 = io->win[1].len;
871 }
872 /* This reserves IO space but doesn't actually enable it */
873 if (pcmcia_request_io(link, &link->io))
874 goto next_entry;
875 } 762 }
763 /* This reserves IO space but doesn't actually enable it */
764 return pcmcia_request_io(p_dev, &p_dev->io);
765 }
876 766
877 /* If we got this far, we're cool! */ 767 return 0;
878 break; 768}
769
770static void das16cs_pcmcia_config(struct pcmcia_device *link)
771{
772 struct local_info_t *dev = link->priv;
773 int ret;
879 774
880next_entry: 775 dev_dbg(&link->dev, "das16cs_pcmcia_config\n");
881 last_fn = GetNextTuple;
882 776
883 last_ret = pcmcia_get_next_tuple(link, &tuple); 777 ret = pcmcia_loop_config(link, das16cs_pcmcia_config_loop, NULL);
884 if (last_ret) 778 if (ret) {
885 goto cs_failed; 779 dev_warn(&link->dev, "no configuration found\n");
780 goto failed;
886 } 781 }
887 782
888 /* 783 /*
@@ -891,21 +786,18 @@ next_entry:
891 irq structure is initialized. 786 irq structure is initialized.
892 */ 787 */
893 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 788 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
894 last_fn = RequestIRQ; 789 ret = pcmcia_request_irq(link, &link->irq);
895 790 if (ret)
896 last_ret = pcmcia_request_irq(link, &link->irq); 791 goto failed;
897 if (last_ret)
898 goto cs_failed;
899 } 792 }
900 /* 793 /*
901 This actually configures the PCMCIA socket -- setting up 794 This actually configures the PCMCIA socket -- setting up
902 the I/O windows and the interrupt mapping, and putting the 795 the I/O windows and the interrupt mapping, and putting the
903 card and host interface into "Memory and IO" mode. 796 card and host interface into "Memory and IO" mode.
904 */ 797 */
905 last_fn = RequestConfiguration; 798 ret = pcmcia_request_configuration(link, &link->conf);
906 last_ret = pcmcia_request_configuration(link, &link->conf); 799 if (ret)
907 if (last_ret) 800 goto failed;
908 goto cs_failed;
909 801
910 /* 802 /*
911 At this point, the dev_node_t structure(s) need to be 803 At this point, the dev_node_t structure(s) need to be
@@ -930,14 +822,13 @@ next_entry:
930 822
931 return; 823 return;
932 824
933cs_failed: 825failed:
934 cs_error(link, last_fn, last_ret);
935 das16cs_pcmcia_release(link); 826 das16cs_pcmcia_release(link);
936} /* das16cs_pcmcia_config */ 827} /* das16cs_pcmcia_config */
937 828
938static void das16cs_pcmcia_release(struct pcmcia_device *link) 829static void das16cs_pcmcia_release(struct pcmcia_device *link)
939{ 830{
940 DEBUG(0, "das16cs_pcmcia_release(0x%p)\n", link); 831 dev_dbg(&link->dev, "das16cs_pcmcia_release\n");
941 pcmcia_disable_device(link); 832 pcmcia_disable_device(link);
942} /* das16cs_pcmcia_release */ 833} /* das16cs_pcmcia_release */
943 834
@@ -983,14 +874,13 @@ struct pcmcia_driver das16cs_driver = {
983 874
984static int __init init_das16cs_pcmcia_cs(void) 875static int __init init_das16cs_pcmcia_cs(void)
985{ 876{
986 DEBUG(0, "%s\n", version);
987 pcmcia_register_driver(&das16cs_driver); 877 pcmcia_register_driver(&das16cs_driver);
988 return 0; 878 return 0;
989} 879}
990 880
991static void __exit exit_das16cs_pcmcia_cs(void) 881static void __exit exit_das16cs_pcmcia_cs(void)
992{ 882{
993 DEBUG(0, "das16cs_pcmcia_cs: unloading\n"); 883 pr_debug("das16cs_pcmcia_cs: unloading\n");
994 pcmcia_unregister_driver(&das16cs_driver); 884 pcmcia_unregister_driver(&das16cs_driver);
995} 885}
996 886
diff --git a/drivers/staging/comedi/drivers/das08_cs.c b/drivers/staging/comedi/drivers/das08_cs.c
index 9cab21eaaa1..384a77a37c2 100644
--- a/drivers/staging/comedi/drivers/das08_cs.c
+++ b/drivers/staging/comedi/drivers/das08_cs.c
@@ -110,25 +110,6 @@ static int das08_cs_attach(struct comedi_device *dev,
110 110
111======================================================================*/ 111======================================================================*/
112 112
113/*
114 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
115 you do not define PCMCIA_DEBUG at all, all the debug code will be
116 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
117 be present but disabled -- but it can then be enabled for specific
118 modules at load time with a 'pc_debug=#' option to insmod.
119*/
120
121#ifdef PCMCIA_DEBUG
122static int pc_debug = PCMCIA_DEBUG;
123module_param(pc_debug, int, 0644);
124#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
125static const char *version =
126 "das08.c pcmcia code (Frank Hess), modified from dummy_cs.c 1.31 2001/08/24 12:13:13 (David Hinds)";
127#else
128#define DEBUG(n, args...)
129#endif
130
131/*====================================================================*/
132static void das08_pcmcia_config(struct pcmcia_device *link); 113static void das08_pcmcia_config(struct pcmcia_device *link);
133static void das08_pcmcia_release(struct pcmcia_device *link); 114static void das08_pcmcia_release(struct pcmcia_device *link);
134static int das08_pcmcia_suspend(struct pcmcia_device *p_dev); 115static int das08_pcmcia_suspend(struct pcmcia_device *p_dev);
@@ -181,7 +162,7 @@ static int das08_pcmcia_attach(struct pcmcia_device *link)
181{ 162{
182 struct local_info_t *local; 163 struct local_info_t *local;
183 164
184 DEBUG(0, "das08_pcmcia_attach()\n"); 165 dev_dbg(&link->dev, "das08_pcmcia_attach()\n");
185 166
186 /* Allocate space for private device-specific data */ 167 /* Allocate space for private device-specific data */
187 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL); 168 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL);
@@ -224,7 +205,7 @@ static int das08_pcmcia_attach(struct pcmcia_device *link)
224static void das08_pcmcia_detach(struct pcmcia_device *link) 205static void das08_pcmcia_detach(struct pcmcia_device *link)
225{ 206{
226 207
227 DEBUG(0, "das08_pcmcia_detach(0x%p)\n", link); 208 dev_dbg(&link->dev, "das08_pcmcia_detach\n");
228 209
229 if (link->dev_node) { 210 if (link->dev_node) {
230 ((struct local_info_t *)link->priv)->stop = 1; 211 ((struct local_info_t *)link->priv)->stop = 1;
@@ -237,6 +218,44 @@ static void das08_pcmcia_detach(struct pcmcia_device *link)
237 218
238} /* das08_pcmcia_detach */ 219} /* das08_pcmcia_detach */
239 220
221
222static int das08_pcmcia_config_loop(struct pcmcia_device *p_dev,
223 cistpl_cftable_entry_t *cfg,
224 cistpl_cftable_entry_t *dflt,
225 unsigned int vcc,
226 void *priv_data)
227{
228 if (cfg->index == 0)
229 return -ENODEV;
230
231 /* Do we need to allocate an interrupt? */
232 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
233 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
234
235 /* IO window settings */
236 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
237 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
238 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
239 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
240 if (!(io->flags & CISTPL_IO_8BIT))
241 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
242 if (!(io->flags & CISTPL_IO_16BIT))
243 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
244 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
245 p_dev->io.BasePort1 = io->win[0].base;
246 p_dev->io.NumPorts1 = io->win[0].len;
247 if (io->nwin > 1) {
248 p_dev->io.Attributes2 = p_dev->io.Attributes1;
249 p_dev->io.BasePort2 = io->win[1].base;
250 p_dev->io.NumPorts2 = io->win[1].len;
251 }
252 /* This reserves IO space but doesn't actually enable it */
253 return pcmcia_request_io(p_dev, &p_dev->io);
254 }
255 return 0;
256}
257
258
240/*====================================================================== 259/*======================================================================
241 260
242 das08_pcmcia_config() is scheduled to run after a CARD_INSERTION event 261 das08_pcmcia_config() is scheduled to run after a CARD_INSERTION event
@@ -248,128 +267,20 @@ static void das08_pcmcia_detach(struct pcmcia_device *link)
248static void das08_pcmcia_config(struct pcmcia_device *link) 267static void das08_pcmcia_config(struct pcmcia_device *link)
249{ 268{
250 struct local_info_t *dev = link->priv; 269 struct local_info_t *dev = link->priv;
251 tuple_t tuple; 270 int ret;
252 cisparse_t parse;
253 int last_fn, last_ret;
254 u_char buf[64];
255 cistpl_cftable_entry_t dflt = { 0 };
256
257 DEBUG(0, "das08_pcmcia_config(0x%p)\n", link);
258
259 /*
260 This reads the card's CONFIG tuple to find its configuration
261 registers.
262 */
263 tuple.DesiredTuple = CISTPL_CONFIG;
264 tuple.Attributes = 0;
265 tuple.TupleData = buf;
266 tuple.TupleDataMax = sizeof(buf);
267 tuple.TupleOffset = 0;
268 last_fn = GetFirstTuple;
269
270 last_ret = pcmcia_get_first_tuple(link, &tuple);
271 if (last_ret)
272 goto cs_failed;
273
274 last_fn = GetTupleData;
275
276 last_ret = pcmcia_get_tuple_data(link, &tuple);
277 if (last_ret)
278 goto cs_failed;
279
280 last_fn = ParseTuple;
281
282 last_ret = pcmcia_parse_tuple(&tuple, &parse);
283 if (last_ret)
284 goto cs_failed;
285
286 link->conf.ConfigBase = parse.config.base;
287 link->conf.Present = parse.config.rmask[0];
288
289 /*
290 In this loop, we scan the CIS for configuration table entries,
291 each of which describes a valid card configuration, including
292 voltage, IO window, memory window, and interrupt settings.
293
294 We make no assumptions about the card to be configured: we use
295 just the information available in the CIS. In an ideal world,
296 this would work for any PCMCIA card, but it requires a complete
297 and accurate CIS. In practice, a driver usually "knows" most of
298 these things without consulting the CIS, and most client drivers
299 will only use the CIS to fill in implementation-defined details.
300 */
301 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY;
302 last_fn = GetFirstTuple;
303
304 last_ret = pcmcia_get_first_tuple(link, &tuple);
305 if (last_ret)
306 goto cs_failed;
307
308 while (1) {
309 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry);
310
311 last_ret = pcmcia_get_tuple_data(link, &tuple);
312 if (last_ret)
313 goto next_entry;
314
315 last_ret = pcmcia_parse_tuple(&tuple, &parse);
316 if (last_ret)
317 goto next_entry;
318
319 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
320 dflt = *cfg;
321 if (cfg->index == 0)
322 goto next_entry;
323 link->conf.ConfigIndex = cfg->index;
324
325 /* Does this card need audio output? */
326/* if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
327 link->conf.Attributes |= CONF_ENABLE_SPKR;
328 link->conf.Status = CCSR_AUDIO_ENA;
329 }
330*/
331 /* Do we need to allocate an interrupt? */
332 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1)
333 link->conf.Attributes |= CONF_ENABLE_IRQ;
334
335 /* IO window settings */
336 link->io.NumPorts1 = link->io.NumPorts2 = 0;
337 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
338 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
339 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
340 if (!(io->flags & CISTPL_IO_8BIT))
341 link->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
342 if (!(io->flags & CISTPL_IO_16BIT))
343 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
344 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
345 link->io.BasePort1 = io->win[0].base;
346 link->io.NumPorts1 = io->win[0].len;
347 if (io->nwin > 1) {
348 link->io.Attributes2 = link->io.Attributes1;
349 link->io.BasePort2 = io->win[1].base;
350 link->io.NumPorts2 = io->win[1].len;
351 }
352 /* This reserves IO space but doesn't actually enable it */
353 if (pcmcia_request_io(link, &link->io) != 0)
354 goto next_entry;
355 }
356
357 /* If we got this far, we're cool! */
358 break;
359 271
360next_entry: 272 dev_dbg(&link->dev, "das08_pcmcia_config\n");
361 last_fn = GetNextTuple;
362 273
363 last_ret = pcmcia_get_next_tuple(link, &tuple); 274 ret = pcmcia_loop_config(link, das08_pcmcia_config_loop, NULL);
364 if (last_ret) 275 if (ret) {
365 goto cs_failed; 276 dev_warn(&link->dev, "no configuration found\n");
277 goto failed;
366 } 278 }
367 279
368 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 280 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
369 last_fn = RequestIRQ; 281 ret = pcmcia_request_irq(link, &link->irq);
370 last_ret = pcmcia_request_irq(link, &link->irq); 282 if (ret)
371 if (last_ret) 283 goto failed;
372 goto cs_failed;
373 } 284 }
374 285
375 /* 286 /*
@@ -377,10 +288,9 @@ next_entry:
377 the I/O windows and the interrupt mapping, and putting the 288 the I/O windows and the interrupt mapping, and putting the
378 card and host interface into "Memory and IO" mode. 289 card and host interface into "Memory and IO" mode.
379 */ 290 */
380 last_fn = RequestConfiguration; 291 ret = pcmcia_request_configuration(link, &link->conf);
381 last_ret = pcmcia_request_configuration(link, &link->conf); 292 if (ret)
382 if (last_ret) 293 goto failed;
383 goto cs_failed;
384 294
385 /* 295 /*
386 At this point, the dev_node_t structure(s) need to be 296 At this point, the dev_node_t structure(s) need to be
@@ -405,8 +315,7 @@ next_entry:
405 315
406 return; 316 return;
407 317
408cs_failed: 318failed:
409 cs_error(link, last_fn, last_ret);
410 das08_pcmcia_release(link); 319 das08_pcmcia_release(link);
411 320
412} /* das08_pcmcia_config */ 321} /* das08_pcmcia_config */
@@ -421,7 +330,7 @@ cs_failed:
421 330
422static void das08_pcmcia_release(struct pcmcia_device *link) 331static void das08_pcmcia_release(struct pcmcia_device *link)
423{ 332{
424 DEBUG(0, "das08_pcmcia_release(0x%p)\n", link); 333 dev_dbg(&link->dev, "das08_pcmcia_release\n");
425 pcmcia_disable_device(link); 334 pcmcia_disable_device(link);
426} /* das08_pcmcia_release */ 335} /* das08_pcmcia_release */
427 336
@@ -477,14 +386,13 @@ struct pcmcia_driver das08_cs_driver = {
477 386
478static int __init init_das08_pcmcia_cs(void) 387static int __init init_das08_pcmcia_cs(void)
479{ 388{
480 DEBUG(0, "%s\n", version);
481 pcmcia_register_driver(&das08_cs_driver); 389 pcmcia_register_driver(&das08_cs_driver);
482 return 0; 390 return 0;
483} 391}
484 392
485static void __exit exit_das08_pcmcia_cs(void) 393static void __exit exit_das08_pcmcia_cs(void)
486{ 394{
487 DEBUG(0, "das08_pcmcia_cs: unloading\n"); 395 pr_debug("das08_pcmcia_cs: unloading\n");
488 pcmcia_unregister_driver(&das08_cs_driver); 396 pcmcia_unregister_driver(&das08_cs_driver);
489} 397}
490 398
diff --git a/drivers/staging/comedi/drivers/ni_daq_700.c b/drivers/staging/comedi/drivers/ni_daq_700.c
index ec31a397066..e06d5b2bc33 100644
--- a/drivers/staging/comedi/drivers/ni_daq_700.c
+++ b/drivers/staging/comedi/drivers/ni_daq_700.c
@@ -436,25 +436,7 @@ static int dio700_detach(struct comedi_device *dev)
436 return 0; 436 return 0;
437}; 437};
438 438
439/* PCMCIA crap */ 439/* PCMCIA crap -- watch your words, please! */
440
441/*
442 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
443 you do not define PCMCIA_DEBUG at all, all the debug code will be
444 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
445 be present but disabled -- but it can then be enabled for specific
446 modules at load time with a 'pc_debug=#' option to insmod.
447*/
448#ifdef PCMCIA_DEBUG
449static int pc_debug = PCMCIA_DEBUG;
450module_param(pc_debug, int, 0644);
451#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
452static char *version = "ni_daq_700.c, based on dummy_cs.c";
453#else
454#define DEBUG(n, args...)
455#endif
456
457/*====================================================================*/
458 440
459static void dio700_config(struct pcmcia_device *link); 441static void dio700_config(struct pcmcia_device *link);
460static void dio700_release(struct pcmcia_device *link); 442static void dio700_release(struct pcmcia_device *link);
@@ -510,7 +492,7 @@ static int dio700_cs_attach(struct pcmcia_device *link)
510 492
511 printk(KERN_INFO "ni_daq_700: cs-attach\n"); 493 printk(KERN_INFO "ni_daq_700: cs-attach\n");
512 494
513 DEBUG(0, "dio700_cs_attach()\n"); 495 dev_dbg(&link->dev, "dio700_cs_attach()\n");
514 496
515 /* Allocate space for private device-specific data */ 497 /* Allocate space for private device-specific data */
516 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL); 498 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL);
@@ -555,7 +537,7 @@ static void dio700_cs_detach(struct pcmcia_device *link)
555 537
556 printk(KERN_INFO "ni_daq_700: cs-detach!\n"); 538 printk(KERN_INFO "ni_daq_700: cs-detach!\n");
557 539
558 DEBUG(0, "dio700_cs_detach(0x%p)\n", link); 540 dev_dbg(&link->dev, "dio700_cs_detach\n");
559 541
560 if (link->dev_node) { 542 if (link->dev_node) {
561 ((struct local_info_t *)link->priv)->stop = 1; 543 ((struct local_info_t *)link->priv)->stop = 1;
@@ -576,141 +558,85 @@ static void dio700_cs_detach(struct pcmcia_device *link)
576 558
577======================================================================*/ 559======================================================================*/
578 560
579static void dio700_config(struct pcmcia_device *link) 561static int dio700_pcmcia_config_loop(struct pcmcia_device *p_dev,
562 cistpl_cftable_entry_t *cfg,
563 cistpl_cftable_entry_t *dflt,
564 unsigned int vcc,
565 void *priv_data)
580{ 566{
581 struct local_info_t *dev = link->priv; 567 win_req_t *req = priv_data;
582 tuple_t tuple;
583 cisparse_t parse;
584 int last_ret;
585 u_char buf[64];
586 win_req_t req;
587 memreq_t map; 568 memreq_t map;
588 cistpl_cftable_entry_t dflt = { 0 };
589 569
590 printk(KERN_INFO "ni_daq_700: cs-config\n"); 570 if (cfg->index == 0)
591 571 return -ENODEV;
592 DEBUG(0, "dio700_config(0x%p)\n", link);
593 572
594 /* 573 /* Does this card need audio output? */
595 This reads the card's CONFIG tuple to find its configuration 574 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
596 registers. 575 p_dev->conf.Attributes |= CONF_ENABLE_SPKR;
597 */ 576 p_dev->conf.Status = CCSR_AUDIO_ENA;
598 tuple.DesiredTuple = CISTPL_CONFIG;
599 tuple.Attributes = 0;
600 tuple.TupleData = buf;
601 tuple.TupleDataMax = sizeof(buf);
602 tuple.TupleOffset = 0;
603
604 last_ret = pcmcia_get_first_tuple(link, &tuple);
605 if (last_ret) {
606 cs_error(link, GetFirstTuple, last_ret);
607 goto cs_failed;
608 } 577 }
609 578
610 last_ret = pcmcia_get_tuple_data(link, &tuple); 579 /* Do we need to allocate an interrupt? */
611 if (last_ret) { 580 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
612 cs_error(link, GetTupleData, last_ret); 581 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
613 goto cs_failed; 582
583 /* IO window settings */
584 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
585 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
586 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
587 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
588 if (!(io->flags & CISTPL_IO_8BIT))
589 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
590 if (!(io->flags & CISTPL_IO_16BIT))
591 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
592 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
593 p_dev->io.BasePort1 = io->win[0].base;
594 p_dev->io.NumPorts1 = io->win[0].len;
595 if (io->nwin > 1) {
596 p_dev->io.Attributes2 = p_dev->io.Attributes1;
597 p_dev->io.BasePort2 = io->win[1].base;
598 p_dev->io.NumPorts2 = io->win[1].len;
599 }
600 /* This reserves IO space but doesn't actually enable it */
601 if (pcmcia_request_io(p_dev, &p_dev->io) != 0)
602 return -ENODEV;
614 } 603 }
615 604
616 last_ret = pcmcia_parse_tuple(&tuple, &parse); 605 if ((cfg->mem.nwin > 0) || (dflt->mem.nwin > 0)) {
617 if (last_ret) { 606 cistpl_mem_t *mem =
618 cs_error(link, ParseTuple, last_ret); 607 (cfg->mem.nwin) ? &cfg->mem : &dflt->mem;
619 goto cs_failed; 608 req->Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
609 req->Attributes |= WIN_ENABLE;
610 req->Base = mem->win[0].host_addr;
611 req->Size = mem->win[0].len;
612 if (req->Size < 0x1000)
613 req->Size = 0x1000;
614 req->AccessSpeed = 0;
615 if (pcmcia_request_window(&p_dev, req, &p_dev->win))
616 return -ENODEV;
617 map.Page = 0;
618 map.CardOffset = mem->win[0].card_addr;
619 if (pcmcia_map_mem_page(p_dev->win, &map))
620 return -ENODEV;
620 } 621 }
621 link->conf.ConfigBase = parse.config.base; 622 /* If we got this far, we're cool! */
622 link->conf.Present = parse.config.rmask[0]; 623 return 0;
623 624}
624 /*
625 In this loop, we scan the CIS for configuration table entries,
626 each of which describes a valid card configuration, including
627 voltage, IO window, memory window, and interrupt settings.
628
629 We make no assumptions about the card to be configured: we use
630 just the information available in the CIS. In an ideal world,
631 this would work for any PCMCIA card, but it requires a complete
632 and accurate CIS. In practice, a driver usually "knows" most of
633 these things without consulting the CIS, and most client drivers
634 will only use the CIS to fill in implementation-defined details.
635 */
636 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY;
637 last_ret = pcmcia_get_first_tuple(link, &tuple);
638 if (last_ret != 0) {
639 cs_error(link, GetFirstTuple, last_ret);
640 goto cs_failed;
641 }
642 while (1) {
643 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry);
644 if (pcmcia_get_tuple_data(link, &tuple) != 0)
645 goto next_entry;
646 if (pcmcia_parse_tuple(&tuple, &parse) != 0)
647 goto next_entry;
648
649 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
650 dflt = *cfg;
651 if (cfg->index == 0)
652 goto next_entry;
653 link->conf.ConfigIndex = cfg->index;
654
655 /* Does this card need audio output? */
656 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
657 link->conf.Attributes |= CONF_ENABLE_SPKR;
658 link->conf.Status = CCSR_AUDIO_ENA;
659 }
660 625
661 /* Do we need to allocate an interrupt? */ 626static void dio700_config(struct pcmcia_device *link)
662 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1) 627{
663 link->conf.Attributes |= CONF_ENABLE_IRQ; 628 struct local_info_t *dev = link->priv;
664 629 win_req_t req;
665 /* IO window settings */ 630 int ret;
666 link->io.NumPorts1 = link->io.NumPorts2 = 0;
667 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
668 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
669 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
670 if (!(io->flags & CISTPL_IO_8BIT))
671 link->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
672 if (!(io->flags & CISTPL_IO_16BIT))
673 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
674 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
675 link->io.BasePort1 = io->win[0].base;
676 link->io.NumPorts1 = io->win[0].len;
677 if (io->nwin > 1) {
678 link->io.Attributes2 = link->io.Attributes1;
679 link->io.BasePort2 = io->win[1].base;
680 link->io.NumPorts2 = io->win[1].len;
681 }
682 /* This reserves IO space but doesn't actually enable it */
683 if (pcmcia_request_io(link, &link->io) != 0)
684 goto next_entry;
685 }
686 631
687 if ((cfg->mem.nwin > 0) || (dflt.mem.nwin > 0)) { 632 printk(KERN_INFO "ni_daq_700: cs-config\n");
688 cistpl_mem_t *mem =
689 (cfg->mem.nwin) ? &cfg->mem : &dflt.mem;
690 req.Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
691 req.Attributes |= WIN_ENABLE;
692 req.Base = mem->win[0].host_addr;
693 req.Size = mem->win[0].len;
694 if (req.Size < 0x1000)
695 req.Size = 0x1000;
696 req.AccessSpeed = 0;
697 if (pcmcia_request_window(&link, &req, &link->win))
698 goto next_entry;
699 map.Page = 0;
700 map.CardOffset = mem->win[0].card_addr;
701 if (pcmcia_map_mem_page(link->win, &map))
702 goto next_entry;
703 }
704 /* If we got this far, we're cool! */
705 break;
706 633
707next_entry: 634 dev_dbg(&link->dev, "dio700_config\n");
708 635
709 last_ret = pcmcia_get_next_tuple(link, &tuple); 636 ret = pcmcia_loop_config(link, dio700_pcmcia_config_loop, &req);
710 if (last_ret) { 637 if (ret) {
711 cs_error(link, GetNextTuple, last_ret); 638 dev_warn(&link->dev, "no configuration found\n");
712 goto cs_failed; 639 goto failed;
713 }
714 } 640 }
715 641
716 /* 642 /*
@@ -719,11 +645,9 @@ next_entry:
719 irq structure is initialized. 645 irq structure is initialized.
720 */ 646 */
721 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 647 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
722 last_ret = pcmcia_request_irq(link, &link->irq); 648 ret = pcmcia_request_irq(link, &link->irq);
723 if (last_ret) { 649 if (ret)
724 cs_error(link, RequestIRQ, last_ret); 650 goto failed;
725 goto cs_failed;
726 }
727 } 651 }
728 652
729 /* 653 /*
@@ -731,11 +655,9 @@ next_entry:
731 the I/O windows and the interrupt mapping, and putting the 655 the I/O windows and the interrupt mapping, and putting the
732 card and host interface into "Memory and IO" mode. 656 card and host interface into "Memory and IO" mode.
733 */ 657 */
734 last_ret = pcmcia_request_configuration(link, &link->conf); 658 ret = pcmcia_request_configuration(link, &link->conf);
735 if (last_ret != 0) { 659 if (ret != 0)
736 cs_error(link, RequestConfiguration, last_ret); 660 goto failed;
737 goto cs_failed;
738 }
739 661
740 /* 662 /*
741 At this point, the dev_node_t structure(s) need to be 663 At this point, the dev_node_t structure(s) need to be
@@ -763,7 +685,7 @@ next_entry:
763 685
764 return; 686 return;
765 687
766cs_failed: 688failed:
767 printk(KERN_INFO "ni_daq_700 cs failed"); 689 printk(KERN_INFO "ni_daq_700 cs failed");
768 dio700_release(link); 690 dio700_release(link);
769 691
@@ -771,7 +693,7 @@ cs_failed:
771 693
772static void dio700_release(struct pcmcia_device *link) 694static void dio700_release(struct pcmcia_device *link)
773{ 695{
774 DEBUG(0, "dio700_release(0x%p)\n", link); 696 dev_dbg(&link->dev, "dio700_release\n");
775 697
776 pcmcia_disable_device(link); 698 pcmcia_disable_device(link);
777} /* dio700_release */ 699} /* dio700_release */
@@ -830,15 +752,13 @@ struct pcmcia_driver dio700_cs_driver = {
830 752
831static int __init init_dio700_cs(void) 753static int __init init_dio700_cs(void)
832{ 754{
833 printk("ni_daq_700: cs-init \n");
834 DEBUG(0, "%s\n", version);
835 pcmcia_register_driver(&dio700_cs_driver); 755 pcmcia_register_driver(&dio700_cs_driver);
836 return 0; 756 return 0;
837} 757}
838 758
839static void __exit exit_dio700_cs(void) 759static void __exit exit_dio700_cs(void)
840{ 760{
841 DEBUG(0, "ni_daq_700: unloading\n"); 761 pr_debug("ni_daq_700: unloading\n");
842 pcmcia_unregister_driver(&dio700_cs_driver); 762 pcmcia_unregister_driver(&dio700_cs_driver);
843} 763}
844 764
diff --git a/drivers/staging/comedi/drivers/ni_daq_dio24.c b/drivers/staging/comedi/drivers/ni_daq_dio24.c
index 0700a8bddd1..9257a4224ea 100644
--- a/drivers/staging/comedi/drivers/ni_daq_dio24.c
+++ b/drivers/staging/comedi/drivers/ni_daq_dio24.c
@@ -187,25 +187,7 @@ static int dio24_detach(struct comedi_device *dev)
187 return 0; 187 return 0;
188}; 188};
189 189
190/* PCMCIA crap */ 190/* PCMCIA crap -- watch your words! */
191
192/*
193 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
194 you do not define PCMCIA_DEBUG at all, all the debug code will be
195 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
196 be present but disabled -- but it can then be enabled for specific
197 modules at load time with a 'pc_debug=#' option to insmod.
198*/
199#ifdef PCMCIA_DEBUG
200static int pc_debug = PCMCIA_DEBUG;
201module_param(pc_debug, int, 0644);
202#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
203static char *version = "ni_daq_dio24.c, based on dummy_cs.c";
204#else
205#define DEBUG(n, args...)
206#endif
207
208/*====================================================================*/
209 191
210static void dio24_config(struct pcmcia_device *link); 192static void dio24_config(struct pcmcia_device *link);
211static void dio24_release(struct pcmcia_device *link); 193static void dio24_release(struct pcmcia_device *link);
@@ -261,7 +243,7 @@ static int dio24_cs_attach(struct pcmcia_device *link)
261 243
262 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO - CS-attach!\n"); 244 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO - CS-attach!\n");
263 245
264 DEBUG(0, "dio24_cs_attach()\n"); 246 dev_dbg(&link->dev, "dio24_cs_attach()\n");
265 247
266 /* Allocate space for private device-specific data */ 248 /* Allocate space for private device-specific data */
267 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL); 249 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL);
@@ -306,7 +288,7 @@ static void dio24_cs_detach(struct pcmcia_device *link)
306 288
307 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO - cs-detach!\n"); 289 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO - cs-detach!\n");
308 290
309 DEBUG(0, "dio24_cs_detach(0x%p)\n", link); 291 dev_dbg(&link->dev, "dio24_cs_detach\n");
310 292
311 if (link->dev_node) { 293 if (link->dev_node) {
312 ((struct local_info_t *)link->priv)->stop = 1; 294 ((struct local_info_t *)link->priv)->stop = 1;
@@ -327,142 +309,85 @@ static void dio24_cs_detach(struct pcmcia_device *link)
327 309
328======================================================================*/ 310======================================================================*/
329 311
330static void dio24_config(struct pcmcia_device *link) 312static int dio24_pcmcia_config_loop(struct pcmcia_device *p_dev,
313 cistpl_cftable_entry_t *cfg,
314 cistpl_cftable_entry_t *dflt,
315 unsigned int vcc,
316 void *priv_data)
331{ 317{
332 struct local_info_t *dev = link->priv; 318 win_req_t *req = priv_data;
333 tuple_t tuple;
334 cisparse_t parse;
335 int last_ret;
336 u_char buf[64];
337 win_req_t req;
338 memreq_t map; 319 memreq_t map;
339 cistpl_cftable_entry_t dflt = { 0 };
340 320
341 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO! - config\n"); 321 if (cfg->index == 0)
342 322 return -ENODEV;
343 DEBUG(0, "dio24_config(0x%p)\n", link);
344
345 /*
346 This reads the card's CONFIG tuple to find its configuration
347 registers.
348 */
349 tuple.DesiredTuple = CISTPL_CONFIG;
350 tuple.Attributes = 0;
351 tuple.TupleData = buf;
352 tuple.TupleDataMax = sizeof(buf);
353 tuple.TupleOffset = 0;
354
355 last_ret = pcmcia_get_first_tuple(link, &tuple);
356 if (last_ret) {
357 cs_error(link, GetFirstTuple, last_ret);
358 goto cs_failed;
359 }
360 323
361 last_ret = pcmcia_get_tuple_data(link, &tuple); 324 /* Does this card need audio output? */
362 if (last_ret) { 325 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
363 cs_error(link, GetTupleData, last_ret); 326 p_dev->conf.Attributes |= CONF_ENABLE_SPKR;
364 goto cs_failed; 327 p_dev->conf.Status = CCSR_AUDIO_ENA;
365 } 328 }
366 329
367 last_ret = pcmcia_parse_tuple(&tuple, &parse); 330 /* Do we need to allocate an interrupt? */
368 if (last_ret) { 331 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
369 cs_error(link, ParseTuple, last_ret); 332 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
370 goto cs_failed; 333
334 /* IO window settings */
335 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
336 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
337 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
338 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
339 if (!(io->flags & CISTPL_IO_8BIT))
340 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
341 if (!(io->flags & CISTPL_IO_16BIT))
342 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
343 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
344 p_dev->io.BasePort1 = io->win[0].base;
345 p_dev->io.NumPorts1 = io->win[0].len;
346 if (io->nwin > 1) {
347 p_dev->io.Attributes2 = p_dev->io.Attributes1;
348 p_dev->io.BasePort2 = io->win[1].base;
349 p_dev->io.NumPorts2 = io->win[1].len;
350 }
351 /* This reserves IO space but doesn't actually enable it */
352 if (pcmcia_request_io(p_dev, &p_dev->io) != 0)
353 return -ENODEV;
371 } 354 }
372 link->conf.ConfigBase = parse.config.base;
373 link->conf.Present = parse.config.rmask[0];
374
375 /*
376 In this loop, we scan the CIS for configuration table entries,
377 each of which describes a valid card configuration, including
378 voltage, IO window, memory window, and interrupt settings.
379
380 We make no assumptions about the card to be configured: we use
381 just the information available in the CIS. In an ideal world,
382 this would work for any PCMCIA card, but it requires a complete
383 and accurate CIS. In practice, a driver usually "knows" most of
384 these things without consulting the CIS, and most client drivers
385 will only use the CIS to fill in implementation-defined details.
386 */
387 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY;
388 355
389 last_ret = pcmcia_get_first_tuple(link, &tuple); 356 if ((cfg->mem.nwin > 0) || (dflt->mem.nwin > 0)) {
390 if (last_ret) { 357 cistpl_mem_t *mem =
391 cs_error(link, GetFirstTuple, last_ret); 358 (cfg->mem.nwin) ? &cfg->mem : &dflt->mem;
392 goto cs_failed; 359 req->Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
360 req->Attributes |= WIN_ENABLE;
361 req->Base = mem->win[0].host_addr;
362 req->Size = mem->win[0].len;
363 if (req->Size < 0x1000)
364 req->Size = 0x1000;
365 req->AccessSpeed = 0;
366 if (pcmcia_request_window(&p_dev, req, &p_dev->win))
367 return -ENODEV;
368 map.Page = 0;
369 map.CardOffset = mem->win[0].card_addr;
370 if (pcmcia_map_mem_page(p_dev->win, &map))
371 return -ENODEV;
393 } 372 }
394 while (1) { 373 /* If we got this far, we're cool! */
395 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry); 374 return 0;
396 if (pcmcia_get_tuple_data(link, &tuple) != 0) 375}
397 goto next_entry;
398 if (pcmcia_parse_tuple(&tuple, &parse) != 0)
399 goto next_entry;
400
401 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
402 dflt = *cfg;
403 if (cfg->index == 0)
404 goto next_entry;
405 link->conf.ConfigIndex = cfg->index;
406
407 /* Does this card need audio output? */
408 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
409 link->conf.Attributes |= CONF_ENABLE_SPKR;
410 link->conf.Status = CCSR_AUDIO_ENA;
411 }
412 376
413 /* Do we need to allocate an interrupt? */ 377static void dio24_config(struct pcmcia_device *link)
414 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1) 378{
415 link->conf.Attributes |= CONF_ENABLE_IRQ; 379 struct local_info_t *dev = link->priv;
416 380 int ret;
417 /* IO window settings */ 381 win_req_t req;
418 link->io.NumPorts1 = link->io.NumPorts2 = 0;
419 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
420 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
421 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
422 if (!(io->flags & CISTPL_IO_8BIT))
423 link->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
424 if (!(io->flags & CISTPL_IO_16BIT))
425 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
426 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
427 link->io.BasePort1 = io->win[0].base;
428 link->io.NumPorts1 = io->win[0].len;
429 if (io->nwin > 1) {
430 link->io.Attributes2 = link->io.Attributes1;
431 link->io.BasePort2 = io->win[1].base;
432 link->io.NumPorts2 = io->win[1].len;
433 }
434 /* This reserves IO space but doesn't actually enable it */
435 if (pcmcia_request_io(link, &link->io) != 0)
436 goto next_entry;
437 }
438 382
439 if ((cfg->mem.nwin > 0) || (dflt.mem.nwin > 0)) { 383 printk(KERN_INFO "ni_daq_dio24: HOLA SOY YO! - config\n");
440 cistpl_mem_t *mem =
441 (cfg->mem.nwin) ? &cfg->mem : &dflt.mem;
442 req.Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
443 req.Attributes |= WIN_ENABLE;
444 req.Base = mem->win[0].host_addr;
445 req.Size = mem->win[0].len;
446 if (req.Size < 0x1000)
447 req.Size = 0x1000;
448 req.AccessSpeed = 0;
449 if (pcmcia_request_window(&link, &req, &link->win))
450 goto next_entry;
451 map.Page = 0;
452 map.CardOffset = mem->win[0].card_addr;
453 if (pcmcia_map_mem_page(link->win, &map))
454 goto next_entry;
455 }
456 /* If we got this far, we're cool! */
457 break;
458 384
459next_entry: 385 dev_dbg(&link->dev, "dio24_config\n");
460 386
461 last_ret = pcmcia_get_next_tuple(link, &tuple); 387 ret = pcmcia_loop_config(link, dio24_pcmcia_config_loop, &req);
462 if (last_ret) { 388 if (ret) {
463 cs_error(link, GetNextTuple, last_ret); 389 dev_warn(&link->dev, "no configuration found\n");
464 goto cs_failed; 390 goto failed;
465 }
466 } 391 }
467 392
468 /* 393 /*
@@ -471,11 +396,9 @@ next_entry:
471 irq structure is initialized. 396 irq structure is initialized.
472 */ 397 */
473 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 398 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
474 last_ret = pcmcia_request_irq(link, &link->irq); 399 ret = pcmcia_request_irq(link, &link->irq);
475 if (last_ret) { 400 if (ret)
476 cs_error(link, RequestIRQ, last_ret); 401 goto failed;
477 goto cs_failed;
478 }
479 } 402 }
480 403
481 /* 404 /*
@@ -483,11 +406,9 @@ next_entry:
483 the I/O windows and the interrupt mapping, and putting the 406 the I/O windows and the interrupt mapping, and putting the
484 card and host interface into "Memory and IO" mode. 407 card and host interface into "Memory and IO" mode.
485 */ 408 */
486 last_ret = pcmcia_request_configuration(link, &link->conf); 409 ret = pcmcia_request_configuration(link, &link->conf);
487 if (last_ret) { 410 if (ret)
488 cs_error(link, RequestConfiguration, last_ret); 411 goto failed;
489 goto cs_failed;
490 }
491 412
492 /* 413 /*
493 At this point, the dev_node_t structure(s) need to be 414 At this point, the dev_node_t structure(s) need to be
@@ -515,7 +436,7 @@ next_entry:
515 436
516 return; 437 return;
517 438
518cs_failed: 439failed:
519 printk(KERN_INFO "Fallo"); 440 printk(KERN_INFO "Fallo");
520 dio24_release(link); 441 dio24_release(link);
521 442
@@ -523,7 +444,7 @@ cs_failed:
523 444
524static void dio24_release(struct pcmcia_device *link) 445static void dio24_release(struct pcmcia_device *link)
525{ 446{
526 DEBUG(0, "dio24_release(0x%p)\n", link); 447 dev_dbg(&link->dev, "dio24_release\n");
527 448
528 pcmcia_disable_device(link); 449 pcmcia_disable_device(link);
529} /* dio24_release */ 450} /* dio24_release */
@@ -582,14 +503,12 @@ struct pcmcia_driver dio24_cs_driver = {
582static int __init init_dio24_cs(void) 503static int __init init_dio24_cs(void)
583{ 504{
584 printk("ni_daq_dio24: HOLA SOY YO!\n"); 505 printk("ni_daq_dio24: HOLA SOY YO!\n");
585 DEBUG(0, "%s\n", version);
586 pcmcia_register_driver(&dio24_cs_driver); 506 pcmcia_register_driver(&dio24_cs_driver);
587 return 0; 507 return 0;
588} 508}
589 509
590static void __exit exit_dio24_cs(void) 510static void __exit exit_dio24_cs(void)
591{ 511{
592 DEBUG(0, "ni_dio24: unloading\n");
593 pcmcia_unregister_driver(&dio24_cs_driver); 512 pcmcia_unregister_driver(&dio24_cs_driver);
594} 513}
595 514
diff --git a/drivers/staging/comedi/drivers/ni_labpc_cs.c b/drivers/staging/comedi/drivers/ni_labpc_cs.c
index a3053b8da1c..28ff4a68cab 100644
--- a/drivers/staging/comedi/drivers/ni_labpc_cs.c
+++ b/drivers/staging/comedi/drivers/ni_labpc_cs.c
@@ -153,23 +153,6 @@ static int labpc_attach(struct comedi_device *dev, struct comedi_devconfig *it)
153 return labpc_common_attach(dev, iobase, irq, 0); 153 return labpc_common_attach(dev, iobase, irq, 0);
154} 154}
155 155
156/*
157 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
158 you do not define PCMCIA_DEBUG at all, all the debug code will be
159 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
160 be present but disabled -- but it can then be enabled for specific
161 modules at load time with a 'pc_debug=#' option to insmod.
162*/
163#ifdef PCMCIA_DEBUG
164static int pc_debug = PCMCIA_DEBUG;
165module_param(pc_debug, int, 0644);
166#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
167static const char *version =
168 "ni_labpc.c, based on dummy_cs.c 1.31 2001/08/24 12:13:13";
169#else
170#define DEBUG(n, args...)
171#endif
172
173/*====================================================================*/ 156/*====================================================================*/
174 157
175/* 158/*
@@ -236,7 +219,7 @@ static int labpc_cs_attach(struct pcmcia_device *link)
236{ 219{
237 struct local_info_t *local; 220 struct local_info_t *local;
238 221
239 DEBUG(0, "labpc_cs_attach()\n"); 222 dev_dbg(&link->dev, "labpc_cs_attach()\n");
240 223
241 /* Allocate space for private device-specific data */ 224 /* Allocate space for private device-specific data */
242 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL); 225 local = kzalloc(sizeof(struct local_info_t), GFP_KERNEL);
@@ -278,7 +261,7 @@ static int labpc_cs_attach(struct pcmcia_device *link)
278 261
279static void labpc_cs_detach(struct pcmcia_device *link) 262static void labpc_cs_detach(struct pcmcia_device *link)
280{ 263{
281 DEBUG(0, "labpc_cs_detach(0x%p)\n", link); 264 dev_dbg(&link->dev, "labpc_cs_detach\n");
282 265
283 /* 266 /*
284 If the device is currently configured and active, we won't 267 If the device is currently configured and active, we won't
@@ -305,135 +288,84 @@ static void labpc_cs_detach(struct pcmcia_device *link)
305 288
306======================================================================*/ 289======================================================================*/
307 290
308static void labpc_config(struct pcmcia_device *link) 291static int labpc_pcmcia_config_loop(struct pcmcia_device *p_dev,
292 cistpl_cftable_entry_t *cfg,
293 cistpl_cftable_entry_t *dflt,
294 unsigned int vcc,
295 void *priv_data)
309{ 296{
310 struct local_info_t *dev = link->priv; 297 win_req_t *req = priv_data;
311 tuple_t tuple;
312 cisparse_t parse;
313 int last_ret;
314 u_char buf[64];
315 win_req_t req;
316 memreq_t map; 298 memreq_t map;
317 cistpl_cftable_entry_t dflt = { 0 };
318 299
319 DEBUG(0, "labpc_config(0x%p)\n", link); 300 if (cfg->index == 0)
301 return -ENODEV;
320 302
321 /* 303 /* Does this card need audio output? */
322 This reads the card's CONFIG tuple to find its configuration 304 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
323 registers. 305 p_dev->conf.Attributes |= CONF_ENABLE_SPKR;
324 */ 306 p_dev->conf.Status = CCSR_AUDIO_ENA;
325 tuple.DesiredTuple = CISTPL_CONFIG;
326 tuple.Attributes = 0;
327 tuple.TupleData = buf;
328 tuple.TupleDataMax = sizeof(buf);
329 tuple.TupleOffset = 0;
330
331 last_ret = pcmcia_get_first_tuple(link, &tuple);
332 if (last_ret) {
333 cs_error(link, GetFirstTuple, last_ret);
334 goto cs_failed;
335 } 307 }
336 308
337 last_ret = pcmcia_get_tuple_data(link, &tuple); 309 /* Do we need to allocate an interrupt? */
338 if (last_ret) { 310 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
339 cs_error(link, GetTupleData, last_ret); 311 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
340 goto cs_failed; 312
313 /* IO window settings */
314 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
315 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
316 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
317 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
318 if (!(io->flags & CISTPL_IO_8BIT))
319 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
320 if (!(io->flags & CISTPL_IO_16BIT))
321 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
322 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
323 p_dev->io.BasePort1 = io->win[0].base;
324 p_dev->io.NumPorts1 = io->win[0].len;
325 if (io->nwin > 1) {
326 p_dev->io.Attributes2 = p_dev->io.Attributes1;
327 p_dev->io.BasePort2 = io->win[1].base;
328 p_dev->io.NumPorts2 = io->win[1].len;
329 }
330 /* This reserves IO space but doesn't actually enable it */
331 if (pcmcia_request_io(p_dev, &p_dev->io) != 0)
332 return -ENODEV;
341 } 333 }
342 334
343 last_ret = pcmcia_parse_tuple(&tuple, &parse); 335 if ((cfg->mem.nwin > 0) || (dflt->mem.nwin > 0)) {
344 if (last_ret) { 336 cistpl_mem_t *mem =
345 cs_error(link, ParseTuple, last_ret); 337 (cfg->mem.nwin) ? &cfg->mem : &dflt->mem;
346 goto cs_failed; 338 req->Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
339 req->Attributes |= WIN_ENABLE;
340 req->Base = mem->win[0].host_addr;
341 req->Size = mem->win[0].len;
342 if (req->Size < 0x1000)
343 req->Size = 0x1000;
344 req->AccessSpeed = 0;
345 if (pcmcia_request_window(&p_dev, req, &p_dev->win))
346 return -ENODEV;
347 map.Page = 0;
348 map.CardOffset = mem->win[0].card_addr;
349 if (pcmcia_map_mem_page(p_dev->win, &map))
350 return -ENODEV;
347 } 351 }
348 link->conf.ConfigBase = parse.config.base; 352 /* If we got this far, we're cool! */
349 link->conf.Present = parse.config.rmask[0]; 353 return 0;
354}
350 355
351 /*
352 In this loop, we scan the CIS for configuration table entries,
353 each of which describes a valid card configuration, including
354 voltage, IO window, memory window, and interrupt settings.
355
356 We make no assumptions about the card to be configured: we use
357 just the information available in the CIS. In an ideal world,
358 this would work for any PCMCIA card, but it requires a complete
359 and accurate CIS. In practice, a driver usually "knows" most of
360 these things without consulting the CIS, and most client drivers
361 will only use the CIS to fill in implementation-defined details.
362 */
363 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY;
364 last_ret = pcmcia_get_first_tuple(link, &tuple);
365 if (last_ret) {
366 cs_error(link, GetFirstTuple, last_ret);
367 goto cs_failed;
368 }
369 while (1) {
370 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry);
371 if (pcmcia_get_tuple_data(link, &tuple))
372 goto next_entry;
373 if (pcmcia_parse_tuple(&tuple, &parse))
374 goto next_entry;
375
376 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
377 dflt = *cfg;
378 if (cfg->index == 0)
379 goto next_entry;
380 link->conf.ConfigIndex = cfg->index;
381
382 /* Does this card need audio output? */
383 if (cfg->flags & CISTPL_CFTABLE_AUDIO) {
384 link->conf.Attributes |= CONF_ENABLE_SPKR;
385 link->conf.Status = CCSR_AUDIO_ENA;
386 }
387 356
388 /* Do we need to allocate an interrupt? */ 357static void labpc_config(struct pcmcia_device *link)
389 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1) 358{
390 link->conf.Attributes |= CONF_ENABLE_IRQ; 359 struct local_info_t *dev = link->priv;
391 360 int ret;
392 /* IO window settings */ 361 win_req_t req;
393 link->io.NumPorts1 = link->io.NumPorts2 = 0;
394 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
395 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
396 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
397 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
398 link->io.BasePort1 = io->win[0].base;
399 link->io.NumPorts1 = io->win[0].len;
400 if (io->nwin > 1) {
401 link->io.Attributes2 = link->io.Attributes1;
402 link->io.BasePort2 = io->win[1].base;
403 link->io.NumPorts2 = io->win[1].len;
404 }
405 /* This reserves IO space but doesn't actually enable it */
406 if (pcmcia_request_io(link, &link->io))
407 goto next_entry;
408 }
409 362
410 if ((cfg->mem.nwin > 0) || (dflt.mem.nwin > 0)) { 363 dev_dbg(&link->dev, "labpc_config\n");
411 cistpl_mem_t *mem =
412 (cfg->mem.nwin) ? &cfg->mem : &dflt.mem;
413 req.Attributes = WIN_DATA_WIDTH_16 | WIN_MEMORY_TYPE_CM;
414 req.Attributes |= WIN_ENABLE;
415 req.Base = mem->win[0].host_addr;
416 req.Size = mem->win[0].len;
417 if (req.Size < 0x1000)
418 req.Size = 0x1000;
419 req.AccessSpeed = 0;
420 link->win = (window_handle_t) link;
421 if (pcmcia_request_window(&link, &req, &link->win))
422 goto next_entry;
423 map.Page = 0;
424 map.CardOffset = mem->win[0].card_addr;
425 if (pcmcia_map_mem_page(link->win, &map))
426 goto next_entry;
427 }
428 /* If we got this far, we're cool! */
429 break;
430 364
431next_entry: 365 ret = pcmcia_loop_config(link, labpc_pcmcia_config_loop, &req);
432 last_ret = pcmcia_get_next_tuple(link, &tuple); 366 if (ret) {
433 if (last_ret) { 367 dev_warn(&link->dev, "no configuration found\n");
434 cs_error(link, GetNextTuple, last_ret); 368 goto failed;
435 goto cs_failed;
436 }
437 } 369 }
438 370
439 /* 371 /*
@@ -442,11 +374,9 @@ next_entry:
442 irq structure is initialized. 374 irq structure is initialized.
443 */ 375 */
444 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 376 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
445 last_ret = pcmcia_request_irq(link, &link->irq); 377 ret = pcmcia_request_irq(link, &link->irq);
446 if (last_ret) { 378 if (ret)
447 cs_error(link, RequestIRQ, last_ret); 379 goto failed;
448 goto cs_failed;
449 }
450 } 380 }
451 381
452 /* 382 /*
@@ -454,11 +384,9 @@ next_entry:
454 the I/O windows and the interrupt mapping, and putting the 384 the I/O windows and the interrupt mapping, and putting the
455 card and host interface into "Memory and IO" mode. 385 card and host interface into "Memory and IO" mode.
456 */ 386 */
457 last_ret = pcmcia_request_configuration(link, &link->conf); 387 ret = pcmcia_request_configuration(link, &link->conf);
458 if (last_ret) { 388 if (ret)
459 cs_error(link, RequestConfiguration, last_ret); 389 goto failed;
460 goto cs_failed;
461 }
462 390
463 /* 391 /*
464 At this point, the dev_node_t structure(s) need to be 392 At this point, the dev_node_t structure(s) need to be
@@ -486,14 +414,14 @@ next_entry:
486 414
487 return; 415 return;
488 416
489cs_failed: 417failed:
490 labpc_release(link); 418 labpc_release(link);
491 419
492} /* labpc_config */ 420} /* labpc_config */
493 421
494static void labpc_release(struct pcmcia_device *link) 422static void labpc_release(struct pcmcia_device *link)
495{ 423{
496 DEBUG(0, "labpc_release(0x%p)\n", link); 424 dev_dbg(&link->dev, "labpc_release\n");
497 425
498 pcmcia_disable_device(link); 426 pcmcia_disable_device(link);
499} /* labpc_release */ 427} /* labpc_release */
@@ -551,14 +479,12 @@ struct pcmcia_driver labpc_cs_driver = {
551 479
552static int __init init_labpc_cs(void) 480static int __init init_labpc_cs(void)
553{ 481{
554 DEBUG(0, "%s\n", version);
555 pcmcia_register_driver(&labpc_cs_driver); 482 pcmcia_register_driver(&labpc_cs_driver);
556 return 0; 483 return 0;
557} 484}
558 485
559static void __exit exit_labpc_cs(void) 486static void __exit exit_labpc_cs(void)
560{ 487{
561 DEBUG(0, "ni_labpc: unloading\n");
562 pcmcia_unregister_driver(&labpc_cs_driver); 488 pcmcia_unregister_driver(&labpc_cs_driver);
563} 489}
564 490
diff --git a/drivers/staging/comedi/drivers/ni_mio_cs.c b/drivers/staging/comedi/drivers/ni_mio_cs.c
index 9aef87fc81d..ca7ab4abdc2 100644
--- a/drivers/staging/comedi/drivers/ni_mio_cs.c
+++ b/drivers/staging/comedi/drivers/ni_mio_cs.c
@@ -312,96 +312,50 @@ static int mio_cs_resume(struct pcmcia_device *link)
312 return 0; 312 return 0;
313} 313}
314 314
315static void mio_cs_config(struct pcmcia_device *link)
316{
317 tuple_t tuple;
318 u_short buf[128];
319 cisparse_t parse;
320 int manfid = 0, prodid = 0;
321 int ret;
322 315
323 DPRINTK("mio_cs_config(link=%p)\n", link); 316static int mio_pcmcia_config_loop(struct pcmcia_device *p_dev,
324 317 cistpl_cftable_entry_t *cfg,
325 tuple.TupleData = (cisdata_t *) buf; 318 cistpl_cftable_entry_t *dflt,
326 tuple.TupleOffset = 0; 319 unsigned int vcc,
327 tuple.TupleDataMax = 255; 320 void *priv_data)
328 tuple.Attributes = 0; 321{
322 int base, ret;
329 323
330 tuple.DesiredTuple = CISTPL_CONFIG; 324 p_dev->io.NumPorts1 = cfg->io.win[0].len;
331 ret = pcmcia_get_first_tuple(link, &tuple); 325 p_dev->io.IOAddrLines = cfg->io.flags & CISTPL_IO_LINES_MASK;
332 ret = pcmcia_get_tuple_data(link, &tuple); 326 p_dev->io.NumPorts2 = 0;
333 ret = pcmcia_parse_tuple(&tuple, &parse);
334 link->conf.ConfigBase = parse.config.base;
335 link->conf.Present = parse.config.rmask[0];
336 327
337#if 0 328 p_dev->irq.IRQInfo1 = cfg->irq.IRQInfo1;
338 tuple.DesiredTuple = CISTPL_LONGLINK_MFC; 329 p_dev->irq.IRQInfo2 = cfg->irq.IRQInfo2;
339 tuple.Attributes = TUPLE_RETURN_COMMON | TUPLE_RETURN_LINK;
340 info->multi(first_tuple(link, &tuple, &parse) == 0);
341#endif
342 330
343 tuple.DesiredTuple = CISTPL_MANFID; 331 for (base = 0x000; base < 0x400; base += 0x20) {
344 tuple.Attributes = TUPLE_RETURN_COMMON; 332 p_dev->io.BasePort1 = base;
345 if ((pcmcia_get_first_tuple(link, &tuple) == 0) && 333 ret = pcmcia_request_io(p_dev, &p_dev->io);
346 (pcmcia_get_tuple_data(link, &tuple) == 0)) { 334 if (!ret)
347 manfid = le16_to_cpu(buf[0]); 335 return 0;
348 prodid = le16_to_cpu(buf[1]);
349 } 336 }
350 /* printk("manfid = 0x%04x, 0x%04x\n",manfid,prodid); */ 337 return -ENODEV;
338}
351 339
352 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY;
353 tuple.Attributes = 0;
354 ret = pcmcia_get_first_tuple(link, &tuple);
355 ret = pcmcia_get_tuple_data(link, &tuple);
356 ret = pcmcia_parse_tuple(&tuple, &parse);
357 340
358#if 0 341static void mio_cs_config(struct pcmcia_device *link)
359 printk(" index: 0x%x\n", parse.cftable_entry.index); 342{
360 printk(" flags: 0x%x\n", parse.cftable_entry.flags); 343 int ret;
361 printk(" io flags: 0x%x\n", parse.cftable_entry.io.flags);
362 printk(" io nwin: 0x%x\n", parse.cftable_entry.io.nwin);
363 printk(" io base: 0x%x\n", parse.cftable_entry.io.win[0].base);
364 printk(" io len: 0x%x\n", parse.cftable_entry.io.win[0].len);
365 printk(" irq1: 0x%x\n", parse.cftable_entry.irq.IRQInfo1);
366 printk(" irq2: 0x%x\n", parse.cftable_entry.irq.IRQInfo2);
367 printk(" mem flags: 0x%x\n", parse.cftable_entry.mem.flags);
368 printk(" mem nwin: 0x%x\n", parse.cftable_entry.mem.nwin);
369 printk(" subtuples: 0x%x\n", parse.cftable_entry.subtuples);
370#endif
371 344
372#if 0 345 DPRINTK("mio_cs_config(link=%p)\n", link);
373 link->io.NumPorts1 = 0x20;
374 link->io.IOAddrLines = 5;
375 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
376#endif
377 link->io.NumPorts1 = parse.cftable_entry.io.win[0].len;
378 link->io.IOAddrLines =
379 parse.cftable_entry.io.flags & CISTPL_IO_LINES_MASK;
380 link->io.NumPorts2 = 0;
381 346
382 { 347 ret = pcmcia_loop_config(link, mio_pcmcia_config_loop, NULL);
383 int base; 348 if (ret) {
384 for (base = 0x000; base < 0x400; base += 0x20) { 349 dev_warn(&link->dev, "no configuration found\n");
385 link->io.BasePort1 = base; 350 return;
386 ret = pcmcia_request_io(link, &link->io);
387 /* printk("RequestIO 0x%02x\n",ret); */
388 if (!ret)
389 break;
390 }
391 } 351 }
392 352
393 link->irq.IRQInfo1 = parse.cftable_entry.irq.IRQInfo1;
394 link->irq.IRQInfo2 = parse.cftable_entry.irq.IRQInfo2;
395 ret = pcmcia_request_irq(link, &link->irq); 353 ret = pcmcia_request_irq(link, &link->irq);
396 if (ret) { 354 if (ret) {
397 printk("pcmcia_request_irq() returned error: %i\n", ret); 355 printk("pcmcia_request_irq() returned error: %i\n", ret);
398 } 356 }
399 /* printk("RequestIRQ 0x%02x\n",ret); */
400
401 link->conf.ConfigIndex = 1;
402 357
403 ret = pcmcia_request_configuration(link, &link->conf); 358 ret = pcmcia_request_configuration(link, &link->conf);
404 /* printk("RequestConfiguration %d\n",ret); */
405 359
406 link->dev_node = &dev_node; 360 link->dev_node = &dev_node;
407} 361}
@@ -475,40 +429,17 @@ static int mio_cs_attach(struct comedi_device *dev, struct comedi_devconfig *it)
475 return 0; 429 return 0;
476} 430}
477 431
478static int get_prodid(struct comedi_device *dev, struct pcmcia_device *link)
479{
480 tuple_t tuple;
481 u_short buf[128];
482 int prodid = 0;
483
484 tuple.TupleData = (cisdata_t *) buf;
485 tuple.TupleOffset = 0;
486 tuple.TupleDataMax = 255;
487 tuple.DesiredTuple = CISTPL_MANFID;
488 tuple.Attributes = TUPLE_RETURN_COMMON;
489 if ((pcmcia_get_first_tuple(link, &tuple) == 0) &&
490 (pcmcia_get_tuple_data(link, &tuple) == 0)) {
491 prodid = le16_to_cpu(buf[1]);
492 }
493
494 return prodid;
495}
496
497static int ni_getboardtype(struct comedi_device *dev, 432static int ni_getboardtype(struct comedi_device *dev,
498 struct pcmcia_device *link) 433 struct pcmcia_device *link)
499{ 434{
500 int id;
501 int i; 435 int i;
502 436
503 id = get_prodid(dev, link);
504
505 for (i = 0; i < n_ni_boards; i++) { 437 for (i = 0; i < n_ni_boards; i++) {
506 if (ni_boards[i].device_id == id) { 438 if (ni_boards[i].device_id == link->card_id)
507 return i; 439 return i;
508 }
509 } 440 }
510 441
511 printk("unknown board 0x%04x -- pretend it is a ", id); 442 printk("unknown board 0x%04x -- pretend it is a ", link->card_id);
512 443
513 return 0; 444 return 0;
514} 445}
diff --git a/drivers/staging/comedi/drivers/quatech_daqp_cs.c b/drivers/staging/comedi/drivers/quatech_daqp_cs.c
index 344b82353e0..48e7c27ed87 100644
--- a/drivers/staging/comedi/drivers/quatech_daqp_cs.c
+++ b/drivers/staging/comedi/drivers/quatech_daqp_cs.c
@@ -55,23 +55,6 @@ Devices: [Quatech] DAQP-208 (daqp), DAQP-308
55#include <pcmcia/cisreg.h> 55#include <pcmcia/cisreg.h>
56#include <pcmcia/ds.h> 56#include <pcmcia/ds.h>
57 57
58/*
59 All the PCMCIA modules use PCMCIA_DEBUG to control debugging. If
60 you do not define PCMCIA_DEBUG at all, all the debug code will be
61 left out. If you compile with PCMCIA_DEBUG=0, the debug code will
62 be present but disabled -- but it can then be enabled for specific
63 modules at load time with a 'pc_debug=#' option to insmod.
64*/
65
66#ifdef PCMCIA_DEBUG
67static int pc_debug = PCMCIA_DEBUG;
68module_param(pc_debug, int, 0644);
69#define DEBUG(n, args...) if (pc_debug>(n)) printk(KERN_DEBUG args)
70static char *version = "quatech_daqp_cs.c 1.10 2003/04/21 (Brent Baccala)";
71#else
72#define DEBUG(n, args...)
73#endif
74
75/* Maximum number of separate DAQP devices we'll allow */ 58/* Maximum number of separate DAQP devices we'll allow */
76#define MAX_DEV 4 59#define MAX_DEV 4
77 60
@@ -863,8 +846,6 @@ static int daqp_attach(struct comedi_device *dev, struct comedi_devconfig *it)
863{ 846{
864 int ret; 847 int ret;
865 struct local_info_t *local = dev_table[it->options[0]]; 848 struct local_info_t *local = dev_table[it->options[0]];
866 tuple_t tuple;
867 int i;
868 struct comedi_subdevice *s; 849 struct comedi_subdevice *s;
869 850
870 if (it->options[0] < 0 || it->options[0] >= MAX_DEV || !local) { 851 if (it->options[0] < 0 || it->options[0] >= MAX_DEV || !local) {
@@ -883,29 +864,10 @@ static int daqp_attach(struct comedi_device *dev, struct comedi_devconfig *it)
883 864
884 strcpy(local->board_name, "DAQP"); 865 strcpy(local->board_name, "DAQP");
885 dev->board_name = local->board_name; 866 dev->board_name = local->board_name;
886 867 if (local->link->prod_id[2]) {
887 tuple.DesiredTuple = CISTPL_VERS_1; 868 if (strncmp(local->link->prod_id[2], "DAQP", 4) == 0) {
888 if (pcmcia_get_first_tuple(local->link, &tuple) == 0) { 869 strncpy(local->board_name, local->link->prod_id[2],
889 u_char buf[128]; 870 sizeof(local->board_name));
890
891 buf[0] = buf[sizeof(buf) - 1] = 0;
892 tuple.TupleData = buf;
893 tuple.TupleDataMax = sizeof(buf);
894 tuple.TupleOffset = 2;
895 if (pcmcia_get_tuple_data(local->link, &tuple) == 0) {
896
897 for (i = 0; i < tuple.TupleDataLen - 4; i++)
898 if (buf[i] == 0)
899 break;
900 for (i++; i < tuple.TupleDataLen - 4; i++)
901 if (buf[i] == 0)
902 break;
903 i++;
904 if ((i < tuple.TupleDataLen - 4)
905 && (strncmp(buf + i, "DAQP", 4) == 0)) {
906 strncpy(local->board_name, buf + i,
907 sizeof(local->board_name));
908 }
909 } 871 }
910 } 872 }
911 873
@@ -1058,7 +1020,7 @@ static int daqp_cs_attach(struct pcmcia_device *link)
1058 struct local_info_t *local; 1020 struct local_info_t *local;
1059 int i; 1021 int i;
1060 1022
1061 DEBUG(0, "daqp_cs_attach()\n"); 1023 dev_dbg(&link->dev, "daqp_cs_attach()\n");
1062 1024
1063 for (i = 0; i < MAX_DEV; i++) 1025 for (i = 0; i < MAX_DEV; i++)
1064 if (dev_table[i] == NULL) 1026 if (dev_table[i] == NULL)
@@ -1112,7 +1074,7 @@ static void daqp_cs_detach(struct pcmcia_device *link)
1112{ 1074{
1113 struct local_info_t *dev = link->priv; 1075 struct local_info_t *dev = link->priv;
1114 1076
1115 DEBUG(0, "daqp_cs_detach(0x%p)\n", link); 1077 dev_dbg(&link->dev, "daqp_cs_detach\n");
1116 1078
1117 if (link->dev_node) { 1079 if (link->dev_node) {
1118 dev->stop = 1; 1080 dev->stop = 1;
@@ -1134,115 +1096,54 @@ static void daqp_cs_detach(struct pcmcia_device *link)
1134 1096
1135======================================================================*/ 1097======================================================================*/
1136 1098
1137static void daqp_cs_config(struct pcmcia_device *link)
1138{
1139 struct local_info_t *dev = link->priv;
1140 tuple_t tuple;
1141 cisparse_t parse;
1142 int last_ret;
1143 u_char buf[64];
1144
1145 DEBUG(0, "daqp_cs_config(0x%p)\n", link);
1146
1147 /*
1148 This reads the card's CONFIG tuple to find its configuration
1149 registers.
1150 */
1151 tuple.DesiredTuple = CISTPL_CONFIG;
1152 tuple.Attributes = 0;
1153 tuple.TupleData = buf;
1154 tuple.TupleDataMax = sizeof(buf);
1155 tuple.TupleOffset = 0;
1156
1157 last_ret = pcmcia_get_first_tuple(link, &tuple);
1158 if (last_ret) {
1159 cs_error(link, GetFirstTuple, last_ret);
1160 goto cs_failed;
1161 }
1162 1099
1163 last_ret = pcmcia_get_tuple_data(link, &tuple); 1100static int daqp_pcmcia_config_loop(struct pcmcia_device *p_dev,
1164 if (last_ret) { 1101 cistpl_cftable_entry_t *cfg,
1165 cs_error(link, GetTupleData, last_ret); 1102 cistpl_cftable_entry_t *dflt,
1166 goto cs_failed; 1103 unsigned int vcc,
1167 } 1104 void *priv_data)
1168 1105{
1169 last_ret = pcmcia_parse_tuple(&tuple, &parse); 1106 if (cfg->index == 0)
1170 if (last_ret) { 1107 return -ENODEV;
1171 cs_error(link, ParseTuple, last_ret);
1172 goto cs_failed;
1173 }
1174 link->conf.ConfigBase = parse.config.base;
1175 link->conf.Present = parse.config.rmask[0];
1176 1108
1177 /* 1109 /* Do we need to allocate an interrupt? */
1178 In this loop, we scan the CIS for configuration table entries, 1110 if (cfg->irq.IRQInfo1 || dflt->irq.IRQInfo1)
1179 each of which describes a valid card configuration, including 1111 p_dev->conf.Attributes |= CONF_ENABLE_IRQ;
1180 voltage, IO window, memory window, and interrupt settings. 1112
1181 1113 /* IO window settings */
1182 We make no assumptions about the card to be configured: we use 1114 p_dev->io.NumPorts1 = p_dev->io.NumPorts2 = 0;
1183 just the information available in the CIS. In an ideal world, 1115 if ((cfg->io.nwin > 0) || (dflt->io.nwin > 0)) {
1184 this would work for any PCMCIA card, but it requires a complete 1116 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt->io;
1185 and accurate CIS. In practice, a driver usually "knows" most of 1117 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
1186 these things without consulting the CIS, and most client drivers 1118 if (!(io->flags & CISTPL_IO_8BIT))
1187 will only use the CIS to fill in implementation-defined details. 1119 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
1188 */ 1120 if (!(io->flags & CISTPL_IO_16BIT))
1189 tuple.DesiredTuple = CISTPL_CFTABLE_ENTRY; 1121 p_dev->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
1190 last_ret = pcmcia_get_first_tuple(link, &tuple); 1122 p_dev->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
1191 if (last_ret) { 1123 p_dev->io.BasePort1 = io->win[0].base;
1192 cs_error(link, GetFirstTuple, last_ret); 1124 p_dev->io.NumPorts1 = io->win[0].len;
1193 goto cs_failed; 1125 if (io->nwin > 1) {
1126 p_dev->io.Attributes2 = p_dev->io.Attributes1;
1127 p_dev->io.BasePort2 = io->win[1].base;
1128 p_dev->io.NumPorts2 = io->win[1].len;
1129 }
1194 } 1130 }
1195 1131
1196 while (1) { 1132 /* This reserves IO space but doesn't actually enable it */
1197 cistpl_cftable_entry_t dflt = { 0 }; 1133 return pcmcia_request_io(p_dev, &p_dev->io);
1198 cistpl_cftable_entry_t *cfg = &(parse.cftable_entry); 1134}
1199 if (pcmcia_get_tuple_data(link, &tuple))
1200 goto next_entry;
1201 if (pcmcia_parse_tuple(&tuple, &parse))
1202 goto next_entry;
1203
1204 if (cfg->flags & CISTPL_CFTABLE_DEFAULT)
1205 dflt = *cfg;
1206 if (cfg->index == 0)
1207 goto next_entry;
1208 link->conf.ConfigIndex = cfg->index;
1209
1210 /* Do we need to allocate an interrupt? */
1211 if (cfg->irq.IRQInfo1 || dflt.irq.IRQInfo1)
1212 link->conf.Attributes |= CONF_ENABLE_IRQ;
1213
1214 /* IO window settings */
1215 link->io.NumPorts1 = link->io.NumPorts2 = 0;
1216 if ((cfg->io.nwin > 0) || (dflt.io.nwin > 0)) {
1217 cistpl_io_t *io = (cfg->io.nwin) ? &cfg->io : &dflt.io;
1218 link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
1219 if (!(io->flags & CISTPL_IO_8BIT))
1220 link->io.Attributes1 = IO_DATA_PATH_WIDTH_16;
1221 if (!(io->flags & CISTPL_IO_16BIT))
1222 link->io.Attributes1 = IO_DATA_PATH_WIDTH_8;
1223 link->io.IOAddrLines = io->flags & CISTPL_IO_LINES_MASK;
1224 link->io.BasePort1 = io->win[0].base;
1225 link->io.NumPorts1 = io->win[0].len;
1226 if (io->nwin > 1) {
1227 link->io.Attributes2 = link->io.Attributes1;
1228 link->io.BasePort2 = io->win[1].base;
1229 link->io.NumPorts2 = io->win[1].len;
1230 }
1231 }
1232 1135
1233 /* This reserves IO space but doesn't actually enable it */ 1136static void daqp_cs_config(struct pcmcia_device *link)
1234 if (pcmcia_request_io(link, &link->io)) 1137{
1235 goto next_entry; 1138 struct local_info_t *dev = link->priv;
1139 int ret;
1236 1140
1237 /* If we got this far, we're cool! */ 1141 dev_dbg(&link->dev, "daqp_cs_config\n");
1238 break;
1239 1142
1240next_entry: 1143 ret = pcmcia_loop_config(link, daqp_pcmcia_config_loop, NULL);
1241 last_ret = pcmcia_get_next_tuple(link, &tuple); 1144 if (ret) {
1242 if (last_ret) { 1145 dev_warn(&link->dev, "no configuration found\n");
1243 cs_error(link, GetNextTuple, last_ret); 1146 goto failed;
1244 goto cs_failed;
1245 }
1246 } 1147 }
1247 1148
1248 /* 1149 /*
@@ -1251,11 +1152,9 @@ next_entry:
1251 irq structure is initialized. 1152 irq structure is initialized.
1252 */ 1153 */
1253 if (link->conf.Attributes & CONF_ENABLE_IRQ) { 1154 if (link->conf.Attributes & CONF_ENABLE_IRQ) {
1254 last_ret = pcmcia_request_irq(link, &link->irq); 1155 ret = pcmcia_request_irq(link, &link->irq);
1255 if (last_ret) { 1156 if (ret)
1256 cs_error(link, RequestIRQ, last_ret); 1157 goto failed;
1257 goto cs_failed;
1258 }
1259 } 1158 }
1260 1159
1261 /* 1160 /*
@@ -1263,11 +1162,9 @@ next_entry:
1263 the I/O windows and the interrupt mapping, and putting the 1162 the I/O windows and the interrupt mapping, and putting the
1264 card and host interface into "Memory and IO" mode. 1163 card and host interface into "Memory and IO" mode.
1265 */ 1164 */
1266 last_ret = pcmcia_request_configuration(link, &link->conf); 1165 ret = pcmcia_request_configuration(link, &link->conf);
1267 if (last_ret) { 1166 if (ret)
1268 cs_error(link, RequestConfiguration, last_ret); 1167 goto failed;
1269 goto cs_failed;
1270 }
1271 1168
1272 /* 1169 /*
1273 At this point, the dev_node_t structure(s) need to be 1170 At this point, the dev_node_t structure(s) need to be
@@ -1296,14 +1193,14 @@ next_entry:
1296 1193
1297 return; 1194 return;
1298 1195
1299cs_failed: 1196failed:
1300 daqp_cs_release(link); 1197 daqp_cs_release(link);
1301 1198
1302} /* daqp_cs_config */ 1199} /* daqp_cs_config */
1303 1200
1304static void daqp_cs_release(struct pcmcia_device *link) 1201static void daqp_cs_release(struct pcmcia_device *link)
1305{ 1202{
1306 DEBUG(0, "daqp_cs_release(0x%p)\n", link); 1203 dev_dbg(&link->dev, "daqp_cs_release\n");
1307 1204
1308 pcmcia_disable_device(link); 1205 pcmcia_disable_device(link);
1309} /* daqp_cs_release */ 1206} /* daqp_cs_release */
@@ -1363,7 +1260,6 @@ struct pcmcia_driver daqp_cs_driver = {
1363 1260
1364int __init init_module(void) 1261int __init init_module(void)
1365{ 1262{
1366 DEBUG(0, "%s\n", version);
1367 pcmcia_register_driver(&daqp_cs_driver); 1263 pcmcia_register_driver(&daqp_cs_driver);
1368 comedi_driver_register(&driver_daqp); 1264 comedi_driver_register(&driver_daqp);
1369 return 0; 1265 return 0;
@@ -1371,7 +1267,6 @@ int __init init_module(void)
1371 1267
1372void __exit cleanup_module(void) 1268void __exit cleanup_module(void)
1373{ 1269{
1374 DEBUG(0, "daqp_cs: unloading\n");
1375 comedi_driver_unregister(&driver_daqp); 1270 comedi_driver_unregister(&driver_daqp);
1376 pcmcia_unregister_driver(&daqp_cs_driver); 1271 pcmcia_unregister_driver(&daqp_cs_driver);
1377} 1272}