1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40#include <linux/module.h>
41#include "../comedidev.h"
42
43#include "das08.h"
44
45static const struct das08_board_struct das08_isa_boards[] = {
46 {
47
48 .name = "isa-das08",
49 .ai_nbits = 12,
50 .ai_pg = das08_pg_none,
51 .ai_encoding = das08_encode12,
52 .di_nchan = 3,
53 .do_nchan = 4,
54 .i8255_offset = 8,
55 .i8254_offset = 4,
56 .iosize = 16,
57 }, {
58
59 .name = "das08-pgm",
60 .ai_nbits = 12,
61 .ai_pg = das08_pgm,
62 .ai_encoding = das08_encode12,
63 .di_nchan = 3,
64 .do_nchan = 4,
65 .i8255_offset = 0,
66 .i8254_offset = 0x04,
67 .iosize = 16,
68 }, {
69
70 .name = "das08-pgh",
71 .ai_nbits = 12,
72 .ai_pg = das08_pgh,
73 .ai_encoding = das08_encode12,
74 .di_nchan = 3,
75 .do_nchan = 4,
76 .i8254_offset = 0x04,
77 .iosize = 16,
78 }, {
79
80 .name = "das08-pgl",
81 .ai_nbits = 12,
82 .ai_pg = das08_pgl,
83 .ai_encoding = das08_encode12,
84 .di_nchan = 3,
85 .do_nchan = 4,
86 .i8254_offset = 0x04,
87 .iosize = 16,
88 }, {
89
90 .name = "das08-aoh",
91 .ai_nbits = 12,
92 .ai_pg = das08_pgh,
93 .ai_encoding = das08_encode12,
94 .ao_nbits = 12,
95 .di_nchan = 3,
96 .do_nchan = 4,
97 .i8255_offset = 0x0c,
98 .i8254_offset = 0x04,
99 .iosize = 16,
100 }, {
101
102 .name = "das08-aol",
103 .ai_nbits = 12,
104 .ai_pg = das08_pgl,
105 .ai_encoding = das08_encode12,
106 .ao_nbits = 12,
107 .di_nchan = 3,
108 .do_nchan = 4,
109 .i8255_offset = 0x0c,
110 .i8254_offset = 0x04,
111 .iosize = 16,
112 }, {
113
114 .name = "das08-aom",
115 .ai_nbits = 12,
116 .ai_pg = das08_pgm,
117 .ai_encoding = das08_encode12,
118 .ao_nbits = 12,
119 .di_nchan = 3,
120 .do_nchan = 4,
121 .i8255_offset = 0x0c,
122 .i8254_offset = 0x04,
123 .iosize = 16,
124 }, {
125
126 .name = "das08/jr-ao",
127 .is_jr = true,
128 .ai_nbits = 12,
129 .ai_pg = das08_pg_none,
130 .ai_encoding = das08_encode12,
131 .ao_nbits = 12,
132 .di_nchan = 8,
133 .do_nchan = 8,
134 .iosize = 16,
135 }, {
136
137 .name = "das08jr-16-ao",
138 .is_jr = true,
139 .ai_nbits = 16,
140 .ai_pg = das08_pg_none,
141 .ai_encoding = das08_encode16,
142 .ao_nbits = 16,
143 .di_nchan = 8,
144 .do_nchan = 8,
145 .i8254_offset = 0x04,
146 .iosize = 16,
147 }, {
148 .name = "pc104-das08",
149 .ai_nbits = 12,
150 .ai_pg = das08_pg_none,
151 .ai_encoding = das08_encode12,
152 .di_nchan = 3,
153 .do_nchan = 4,
154 .i8254_offset = 4,
155 .iosize = 16,
156 }, {
157 .name = "das08jr/16",
158 .is_jr = true,
159 .ai_nbits = 16,
160 .ai_pg = das08_pg_none,
161 .ai_encoding = das08_encode16,
162 .di_nchan = 8,
163 .do_nchan = 8,
164 .iosize = 16,
165 },
166};
167
168static int das08_isa_attach(struct comedi_device *dev,
169 struct comedi_devconfig *it)
170{
171 const struct das08_board_struct *board = dev->board_ptr;
172 struct das08_private_struct *devpriv;
173 int ret;
174
175 devpriv = comedi_alloc_devpriv(dev, sizeof(*devpriv));
176 if (!devpriv)
177 return -ENOMEM;
178
179 ret = comedi_request_region(dev, it->options[0], board->iosize);
180 if (ret)
181 return ret;
182
183 return das08_common_attach(dev, dev->iobase);
184}
185
186static struct comedi_driver das08_isa_driver = {
187 .driver_name = "isa-das08",
188 .module = THIS_MODULE,
189 .attach = das08_isa_attach,
190 .detach = comedi_legacy_detach,
191 .board_name = &das08_isa_boards[0].name,
192 .num_names = ARRAY_SIZE(das08_isa_boards),
193 .offset = sizeof(das08_isa_boards[0]),
194};
195module_comedi_driver(das08_isa_driver);
196
197MODULE_AUTHOR("Comedi http://www.comedi.org");
198MODULE_DESCRIPTION("Comedi low-level driver");
199MODULE_LICENSE("GPL");
200