staging: comedi: das08: Avoid zero initializers in board structure
[deliverable/linux.git] / drivers / staging / comedi / drivers / das08_cs.c
CommitLineData
0882eaa6
DS
1/*
2 comedi/drivers/das08_cs.c
3 DAS08 driver
4
5 COMEDI - Linux Control and Measurement Device Interface
6 Copyright (C) 2000 David A. Schleef <ds@schleef.org>
7 Copyright (C) 2001,2002,2003 Frank Mori Hess <fmhess@users.sourceforge.net>
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22
c332d969
HS
23 PCMCIA support code for this driver is adapted from the dummy_cs.c
24 driver of the Linux PCMCIA Card Services package.
25
26 The initial developer of the original code is David A. Hinds
27 <dahinds@users.sourceforge.net>. Portions created by David A. Hinds
28 are Copyright (C) 1999 David A. Hinds. All Rights Reserved.
29
0882eaa6
DS
30*****************************************************************
31
32*/
33/*
34Driver: das08_cs
35Description: DAS-08 PCMCIA boards
36Author: Warren Jasper, ds, Frank Hess
37Devices: [ComputerBoards] PCM-DAS08 (pcm-das08)
38Status: works
39
40This is the PCMCIA-specific support split off from the
41das08 driver.
42
43Options (for pcm-das08):
d539047c 44 NONE
0882eaa6
DS
45
46Command support does not exist, but could be added for this board.
47*/
48
49#include "../comedidev.h"
50
51#include <linux/delay.h>
52#include <linux/pci.h>
5a0e3ad6 53#include <linux/slab.h>
0882eaa6
DS
54
55#include "das08.h"
56
2696fb57 57/* pcmcia includes */
0882eaa6
DS
58#include <pcmcia/cistpl.h>
59#include <pcmcia/ds.h>
60
d539047c 61static struct pcmcia_device *cur_dev;
0882eaa6 62
0a85b6f0
MT
63static int das08_cs_attach(struct comedi_device *dev,
64 struct comedi_devconfig *it)
0882eaa6 65{
6f88a20a 66 const struct das08_board_struct *thisboard = comedi_board(dev);
0882eaa6
DS
67 int ret;
68 unsigned long iobase;
2696fb57 69 struct pcmcia_device *link = cur_dev; /* XXX hack */
0882eaa6 70
c3744138
BP
71 ret = alloc_private(dev, sizeof(struct das08_private_struct));
72 if (ret < 0)
0882eaa6
DS
73 return ret;
74
f41ad667 75 dev_info(dev->class_dev, "das08_cs: attach\n");
2696fb57 76 /* deal with a pci board */
0882eaa6
DS
77
78 if (thisboard->bustype == pcmcia) {
79 if (link == NULL) {
f41ad667 80 dev_err(dev->class_dev, "no pcmcia cards found\n");
0882eaa6
DS
81 return -EIO;
82 }
9a017a91 83 iobase = link->resource[0]->start;
0882eaa6 84 } else {
f41ad667
IA
85 dev_err(dev->class_dev,
86 "bug! board does not have PCMCIA bustype\n");
0882eaa6
DS
87 return -EINVAL;
88 }
89
0882eaa6
DS
90 return das08_common_attach(dev, iobase);
91}
92
6b7de35e
HS
93static struct comedi_driver driver_das08_cs = {
94 .driver_name = "das08_cs",
95 .module = THIS_MODULE,
96 .attach = das08_cs_attach,
97 .detach = das08_common_detach,
98 .board_name = &das08_cs_boards[0].name,
99 .num_names = ARRAY_SIZE(das08_cs_boards),
100 .offset = sizeof(struct das08_board_struct),
101};
102
55a19b39 103static int das08_pcmcia_config_loop(struct pcmcia_device *p_dev,
55a19b39
DB
104 void *priv_data)
105{
00990e7c
DB
106 if (p_dev->config_index == 0)
107 return -EINVAL;
108
109 return pcmcia_request_io(p_dev);
55a19b39
DB
110}
111
ae6eba84 112static int das08_pcmcia_attach(struct pcmcia_device *link)
0882eaa6 113{
55a19b39 114 int ret;
0882eaa6 115
00990e7c
DB
116 link->config_flags |= CONF_ENABLE_IRQ | CONF_AUTO_SET_IO;
117
55a19b39 118 ret = pcmcia_loop_config(link, das08_pcmcia_config_loop, NULL);
ae6eba84 119 if (ret)
55a19b39 120 goto failed;
0882eaa6 121
eb14120f
DB
122 if (!link->irq)
123 goto failed;
0882eaa6 124
1ac71e5a 125 ret = pcmcia_enable_device(link);
55a19b39
DB
126 if (ret)
127 goto failed;
0882eaa6 128
fb795746 129 cur_dev = link;
fb795746 130 return 0;
ae6eba84
HS
131
132failed:
133 pcmcia_disable_device(link);
134 return ret;
fb795746
HS
135}
136
137static void das08_pcmcia_detach(struct pcmcia_device *link)
138{
ae6eba84
HS
139 pcmcia_disable_device(link);
140 cur_dev = NULL;
c332d969 141}
0882eaa6 142
2202a5a7 143static const struct pcmcia_device_id das08_cs_id_table[] = {
0882eaa6
DS
144 PCMCIA_DEVICE_MANF_CARD(0x01c5, 0x4001),
145 PCMCIA_DEVICE_NULL
146};
0882eaa6
DS
147MODULE_DEVICE_TABLE(pcmcia, das08_cs_id_table);
148
27fa05bc
HS
149static struct pcmcia_driver das08_cs_driver = {
150 .name = "pcm-das08",
151 .owner = THIS_MODULE,
152 .probe = das08_pcmcia_attach,
153 .remove = das08_pcmcia_detach,
27fa05bc 154 .id_table = das08_cs_id_table,
0882eaa6
DS
155};
156
0882eaa6
DS
157static int __init das08_cs_init_module(void)
158{
159 int ret;
160
36061c84 161 ret = comedi_driver_register(&driver_das08_cs);
0882eaa6
DS
162 if (ret < 0)
163 return ret;
164
36061c84
HS
165 ret = pcmcia_register_driver(&das08_cs_driver);
166 if (ret < 0) {
167 comedi_driver_unregister(&driver_das08_cs);
168 return ret;
169 }
170
171 return 0;
172
0882eaa6 173}
46877702 174module_init(das08_cs_init_module);
0882eaa6
DS
175
176static void __exit das08_cs_exit_module(void)
177{
46877702 178 pcmcia_unregister_driver(&das08_cs_driver);
0882eaa6
DS
179 comedi_driver_unregister(&driver_das08_cs);
180}
0882eaa6 181module_exit(das08_cs_exit_module);
3a36ad17
HS
182
183MODULE_AUTHOR("David A. Schleef <ds@schleef.org>, "
184 "Frank Mori Hess <fmhess@users.sourceforge.net>");
185MODULE_DESCRIPTION("Comedi driver for ComputerBoards DAS-08 PCMCIA boards");
186MODULE_LICENSE("GPL");
This page took 0.318222 seconds and 5 git commands to generate.