Revert "tty: hvc: Fix data abort due to race in hvc_open"
[linux/fpc-iii.git] / include / pcmcia / device_id.h
blob52b9f5eda8a7f75cde09da8d1bbf0ef7dbe2e21e
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * device_id.h -- PCMCIA driver matching helpers
5 * (C) 2003 - 2004 David Woodhouse
6 * (C) 2003 - 2004 Dominik Brodowski
7 */
9 #ifndef _LINUX_PCMCIA_DEVICE_ID_H
10 #define _LINUX_PCMCIA_DEVICE_ID_H
12 #ifdef __KERNEL__
14 #define PCMCIA_DEVICE_MANF_CARD(manf, card) { \
15 .match_flags = PCMCIA_DEV_ID_MATCH_MANF_ID| \
16 PCMCIA_DEV_ID_MATCH_CARD_ID, \
17 .manf_id = (manf), \
18 .card_id = (card), }
20 #define PCMCIA_DEVICE_FUNC_ID(func) { \
21 .match_flags = PCMCIA_DEV_ID_MATCH_FUNC_ID, \
22 .func_id = (func), }
24 #define PCMCIA_DEVICE_PROD_ID1(v1, vh1) { \
25 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1, \
26 .prod_id = { (v1), NULL, NULL, NULL }, \
27 .prod_id_hash = { (vh1), 0, 0, 0 }, }
29 #define PCMCIA_DEVICE_PROD_ID2(v2, vh2) { \
30 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID2, \
31 .prod_id = { NULL, (v2), NULL, NULL }, \
32 .prod_id_hash = { 0, (vh2), 0, 0 }, }
34 #define PCMCIA_DEVICE_PROD_ID3(v3, vh3) { \
35 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID3, \
36 .prod_id = { NULL, NULL, (v3), NULL }, \
37 .prod_id_hash = { 0, 0, (vh3), 0 }, }
39 #define PCMCIA_DEVICE_PROD_ID12(v1, v2, vh1, vh2) { \
40 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
41 PCMCIA_DEV_ID_MATCH_PROD_ID2, \
42 .prod_id = { (v1), (v2), NULL, NULL }, \
43 .prod_id_hash = { (vh1), (vh2), 0, 0 }, }
45 #define PCMCIA_DEVICE_PROD_ID13(v1, v3, vh1, vh3) { \
46 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
47 PCMCIA_DEV_ID_MATCH_PROD_ID3, \
48 .prod_id = { (v1), NULL, (v3), NULL }, \
49 .prod_id_hash = { (vh1), 0, (vh3), 0 }, }
51 #define PCMCIA_DEVICE_PROD_ID14(v1, v4, vh1, vh4) { \
52 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
53 PCMCIA_DEV_ID_MATCH_PROD_ID4, \
54 .prod_id = { (v1), NULL, NULL, (v4) }, \
55 .prod_id_hash = { (vh1), 0, 0, (vh4) }, }
57 #define PCMCIA_DEVICE_PROD_ID123(v1, v2, v3, vh1, vh2, vh3) { \
58 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
59 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
60 PCMCIA_DEV_ID_MATCH_PROD_ID3, \
61 .prod_id = { (v1), (v2), (v3), NULL },\
62 .prod_id_hash = { (vh1), (vh2), (vh3), 0 }, }
64 #define PCMCIA_DEVICE_PROD_ID124(v1, v2, v4, vh1, vh2, vh4) { \
65 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
66 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
67 PCMCIA_DEV_ID_MATCH_PROD_ID4, \
68 .prod_id = { (v1), (v2), NULL, (v4) }, \
69 .prod_id_hash = { (vh1), (vh2), 0, (vh4) }, }
71 #define PCMCIA_DEVICE_PROD_ID134(v1, v3, v4, vh1, vh3, vh4) { \
72 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
73 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
74 PCMCIA_DEV_ID_MATCH_PROD_ID4, \
75 .prod_id = { (v1), NULL, (v3), (v4) }, \
76 .prod_id_hash = { (vh1), 0, (vh3), (vh4) }, }
78 #define PCMCIA_DEVICE_PROD_ID1234(v1, v2, v3, v4, vh1, vh2, vh3, vh4) { \
79 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
80 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
81 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
82 PCMCIA_DEV_ID_MATCH_PROD_ID4, \
83 .prod_id = { (v1), (v2), (v3), (v4) }, \
84 .prod_id_hash = { (vh1), (vh2), (vh3), (vh4) }, }
86 #define PCMCIA_DEVICE_MANF_CARD_PROD_ID1(manf, card, v1, vh1) { \
87 .match_flags = PCMCIA_DEV_ID_MATCH_MANF_ID| \
88 PCMCIA_DEV_ID_MATCH_CARD_ID| \
89 PCMCIA_DEV_ID_MATCH_PROD_ID1, \
90 .manf_id = (manf), \
91 .card_id = (card), \
92 .prod_id = { (v1), NULL, NULL, NULL }, \
93 .prod_id_hash = { (vh1), 0, 0, 0 }, }
95 #define PCMCIA_DEVICE_MANF_CARD_PROD_ID3(manf, card, v3, vh3) { \
96 .match_flags = PCMCIA_DEV_ID_MATCH_MANF_ID| \
97 PCMCIA_DEV_ID_MATCH_CARD_ID| \
98 PCMCIA_DEV_ID_MATCH_PROD_ID3, \
99 .manf_id = (manf), \
100 .card_id = (card), \
101 .prod_id = { NULL, NULL, (v3), NULL }, \
102 .prod_id_hash = { 0, 0, (vh3), 0 }, }
105 /* multi-function devices */
107 #define PCMCIA_MFC_DEVICE_MANF_CARD(mfc, manf, card) { \
108 .match_flags = PCMCIA_DEV_ID_MATCH_MANF_ID| \
109 PCMCIA_DEV_ID_MATCH_CARD_ID| \
110 PCMCIA_DEV_ID_MATCH_FUNCTION, \
111 .manf_id = (manf), \
112 .card_id = (card), \
113 .function = (mfc), }
115 #define PCMCIA_MFC_DEVICE_PROD_ID1(mfc, v1, vh1) { \
116 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
117 PCMCIA_DEV_ID_MATCH_FUNCTION, \
118 .prod_id = { (v1), NULL, NULL, NULL }, \
119 .prod_id_hash = { (vh1), 0, 0, 0 }, \
120 .function = (mfc), }
122 #define PCMCIA_MFC_DEVICE_PROD_ID2(mfc, v2, vh2) { \
123 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID2| \
124 PCMCIA_DEV_ID_MATCH_FUNCTION, \
125 .prod_id = { NULL, (v2), NULL, NULL }, \
126 .prod_id_hash = { 0, (vh2), 0, 0 }, \
127 .function = (mfc), }
129 #define PCMCIA_MFC_DEVICE_PROD_ID12(mfc, v1, v2, vh1, vh2) { \
130 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
131 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
132 PCMCIA_DEV_ID_MATCH_FUNCTION, \
133 .prod_id = { (v1), (v2), NULL, NULL }, \
134 .prod_id_hash = { (vh1), (vh2), 0, 0 }, \
135 .function = (mfc), }
137 #define PCMCIA_MFC_DEVICE_PROD_ID13(mfc, v1, v3, vh1, vh3) { \
138 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
139 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
140 PCMCIA_DEV_ID_MATCH_FUNCTION, \
141 .prod_id = { (v1), NULL, (v3), NULL }, \
142 .prod_id_hash = { (vh1), 0, (vh3), 0 }, \
143 .function = (mfc), }
145 #define PCMCIA_MFC_DEVICE_PROD_ID123(mfc, v1, v2, v3, vh1, vh2, vh3) { \
146 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
147 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
148 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
149 PCMCIA_DEV_ID_MATCH_FUNCTION, \
150 .prod_id = { (v1), (v2), (v3), NULL },\
151 .prod_id_hash = { (vh1), (vh2), (vh3), 0 }, \
152 .function = (mfc), }
154 /* pseudo multi-function devices */
156 #define PCMCIA_PFC_DEVICE_MANF_CARD(mfc, manf, card) { \
157 .match_flags = PCMCIA_DEV_ID_MATCH_MANF_ID| \
158 PCMCIA_DEV_ID_MATCH_CARD_ID| \
159 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
160 .manf_id = (manf), \
161 .card_id = (card), \
162 .device_no = (mfc), }
164 #define PCMCIA_PFC_DEVICE_PROD_ID1(mfc, v1, vh1) { \
165 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
166 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
167 .prod_id = { (v1), NULL, NULL, NULL }, \
168 .prod_id_hash = { (vh1), 0, 0, 0 }, \
169 .device_no = (mfc), }
171 #define PCMCIA_PFC_DEVICE_PROD_ID2(mfc, v2, vh2) { \
172 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID2| \
173 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
174 .prod_id = { NULL, (v2), NULL, NULL }, \
175 .prod_id_hash = { 0, (vh2), 0, 0 }, \
176 .device_no = (mfc), }
178 #define PCMCIA_PFC_DEVICE_PROD_ID12(mfc, v1, v2, vh1, vh2) { \
179 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
180 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
181 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
182 .prod_id = { (v1), (v2), NULL, NULL }, \
183 .prod_id_hash = { (vh1), (vh2), 0, 0 }, \
184 .device_no = (mfc), }
186 #define PCMCIA_PFC_DEVICE_PROD_ID13(mfc, v1, v3, vh1, vh3) { \
187 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
188 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
189 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
190 .prod_id = { (v1), NULL, (v3), NULL }, \
191 .prod_id_hash = { (vh1), 0, (vh3), 0 }, \
192 .device_no = (mfc), }
194 #define PCMCIA_PFC_DEVICE_PROD_ID123(mfc, v1, v2, v3, vh1, vh2, vh3) { \
195 .match_flags = PCMCIA_DEV_ID_MATCH_PROD_ID1| \
196 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
197 PCMCIA_DEV_ID_MATCH_PROD_ID3| \
198 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
199 .prod_id = { (v1), (v2), (v3), NULL },\
200 .prod_id_hash = { (vh1), (vh2), (vh3), 0 }, \
201 .device_no = (mfc), }
203 /* cards needing a CIS override */
205 #define PCMCIA_DEVICE_CIS_MANF_CARD(manf, card, _cisfile) { \
206 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
207 PCMCIA_DEV_ID_MATCH_MANF_ID| \
208 PCMCIA_DEV_ID_MATCH_CARD_ID, \
209 .manf_id = (manf), \
210 .card_id = (card), \
211 .cisfile = (_cisfile)}
213 #define PCMCIA_DEVICE_CIS_PROD_ID12(v1, v2, vh1, vh2, _cisfile) { \
214 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
215 PCMCIA_DEV_ID_MATCH_PROD_ID1| \
216 PCMCIA_DEV_ID_MATCH_PROD_ID2, \
217 .prod_id = { (v1), (v2), NULL, NULL }, \
218 .prod_id_hash = { (vh1), (vh2), 0, 0 }, \
219 .cisfile = (_cisfile)}
221 #define PCMCIA_DEVICE_CIS_PROD_ID123(v1, v2, v3, vh1, vh2, vh3, _cisfile) { \
222 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
223 PCMCIA_DEV_ID_MATCH_PROD_ID1| \
224 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
225 PCMCIA_DEV_ID_MATCH_PROD_ID3, \
226 .prod_id = { (v1), (v2), (v3), NULL },\
227 .prod_id_hash = { (vh1), (vh2), (vh3), 0 }, \
228 .cisfile = (_cisfile)}
231 #define PCMCIA_DEVICE_CIS_PROD_ID2(v2, vh2, _cisfile) { \
232 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
233 PCMCIA_DEV_ID_MATCH_PROD_ID2, \
234 .prod_id = { NULL, (v2), NULL, NULL }, \
235 .prod_id_hash = { 0, (vh2), 0, 0 }, \
236 .cisfile = (_cisfile)}
238 #define PCMCIA_PFC_DEVICE_CIS_PROD_ID12(mfc, v1, v2, vh1, vh2, _cisfile) { \
239 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
240 PCMCIA_DEV_ID_MATCH_PROD_ID1| \
241 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
242 PCMCIA_DEV_ID_MATCH_DEVICE_NO, \
243 .prod_id = { (v1), (v2), NULL, NULL }, \
244 .prod_id_hash = { (vh1), (vh2), 0, 0 },\
245 .device_no = (mfc), \
246 .cisfile = (_cisfile)}
248 #define PCMCIA_MFC_DEVICE_CIS_MANF_CARD(mfc, manf, card, _cisfile) { \
249 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
250 PCMCIA_DEV_ID_MATCH_MANF_ID| \
251 PCMCIA_DEV_ID_MATCH_CARD_ID| \
252 PCMCIA_DEV_ID_MATCH_FUNCTION, \
253 .manf_id = (manf), \
254 .card_id = (card), \
255 .function = (mfc), \
256 .cisfile = (_cisfile)}
258 #define PCMCIA_MFC_DEVICE_CIS_PROD_ID12(mfc, v1, v2, vh1, vh2, _cisfile) { \
259 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
260 PCMCIA_DEV_ID_MATCH_PROD_ID1| \
261 PCMCIA_DEV_ID_MATCH_PROD_ID2| \
262 PCMCIA_DEV_ID_MATCH_FUNCTION, \
263 .prod_id = { (v1), (v2), NULL, NULL }, \
264 .prod_id_hash = { (vh1), (vh2), 0, 0 }, \
265 .function = (mfc), \
266 .cisfile = (_cisfile)}
268 #define PCMCIA_MFC_DEVICE_CIS_PROD_ID4(mfc, v4, vh4, _cisfile) { \
269 .match_flags = PCMCIA_DEV_ID_MATCH_FAKE_CIS | \
270 PCMCIA_DEV_ID_MATCH_PROD_ID4| \
271 PCMCIA_DEV_ID_MATCH_FUNCTION, \
272 .prod_id = { NULL, NULL, NULL, (v4) }, \
273 .prod_id_hash = { 0, 0, 0, (vh4) }, \
274 .function = (mfc), \
275 .cisfile = (_cisfile)}
278 #define PCMCIA_DEVICE_NULL { .match_flags = 0, }
280 #endif /* __KERNEL__ */
281 #endif /* _LINUX_PCMCIA_DEVICE_ID_H */