]> Git Repo - linux.git/blob - drivers/platform/x86/touchscreen_dmi.c
Merge tag 'pwm/for-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/thierry...
[linux.git] / drivers / platform / x86 / touchscreen_dmi.c
1 /*
2  * Touchscreen driver DMI based configuration code
3  *
4  * Copyright (c) 2017 Red Hat Inc.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Red Hat authors:
12  * Hans de Goede <[email protected]>
13  */
14
15 #include <linux/acpi.h>
16 #include <linux/device.h>
17 #include <linux/dmi.h>
18 #include <linux/i2c.h>
19 #include <linux/notifier.h>
20 #include <linux/property.h>
21 #include <linux/string.h>
22
23 struct ts_dmi_data {
24         const char *acpi_name;
25         const struct property_entry *properties;
26 };
27
28 /* NOTE: Please keep all entries sorted alphabetically */
29
30 static const struct property_entry chuwi_hi8_props[] = {
31         PROPERTY_ENTRY_U32("touchscreen-size-x", 1665),
32         PROPERTY_ENTRY_U32("touchscreen-size-y", 1140),
33         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
34         PROPERTY_ENTRY_BOOL("silead,home-button"),
35         PROPERTY_ENTRY_STRING("firmware-name", "gsl1680-chuwi-hi8.fw"),
36         { }
37 };
38
39 static const struct ts_dmi_data chuwi_hi8_data = {
40         .acpi_name      = "MSSL0001:00",
41         .properties     = chuwi_hi8_props,
42 };
43
44 static const struct property_entry chuwi_hi8_pro_props[] = {
45         PROPERTY_ENTRY_U32("touchscreen-min-x", 6),
46         PROPERTY_ENTRY_U32("touchscreen-min-y", 3),
47         PROPERTY_ENTRY_U32("touchscreen-size-x", 1728),
48         PROPERTY_ENTRY_U32("touchscreen-size-y", 1148),
49         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
50         PROPERTY_ENTRY_STRING("firmware-name", "gsl3680-chuwi-hi8-pro.fw"),
51         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
52         PROPERTY_ENTRY_BOOL("silead,home-button"),
53         { }
54 };
55
56 static const struct ts_dmi_data chuwi_hi8_pro_data = {
57         .acpi_name      = "MSSL1680:00",
58         .properties     = chuwi_hi8_pro_props,
59 };
60
61 static const struct property_entry chuwi_vi8_props[] = {
62         PROPERTY_ENTRY_U32("touchscreen-min-x", 4),
63         PROPERTY_ENTRY_U32("touchscreen-min-y", 6),
64         PROPERTY_ENTRY_U32("touchscreen-size-x", 1724),
65         PROPERTY_ENTRY_U32("touchscreen-size-y", 1140),
66         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
67         PROPERTY_ENTRY_STRING("firmware-name", "gsl3676-chuwi-vi8.fw"),
68         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
69         PROPERTY_ENTRY_BOOL("silead,home-button"),
70         { }
71 };
72
73 static const struct ts_dmi_data chuwi_vi8_data = {
74         .acpi_name      = "MSSL1680:00",
75         .properties     = chuwi_vi8_props,
76 };
77
78 static const struct property_entry chuwi_vi10_props[] = {
79         PROPERTY_ENTRY_U32("touchscreen-min-x", 0),
80         PROPERTY_ENTRY_U32("touchscreen-min-y", 4),
81         PROPERTY_ENTRY_U32("touchscreen-size-x", 1858),
82         PROPERTY_ENTRY_U32("touchscreen-size-y", 1280),
83         PROPERTY_ENTRY_STRING("firmware-name", "gsl3680-chuwi-vi10.fw"),
84         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
85         PROPERTY_ENTRY_BOOL("silead,home-button"),
86         { }
87 };
88
89 static const struct ts_dmi_data chuwi_vi10_data = {
90         .acpi_name      = "MSSL0002:00",
91         .properties     = chuwi_vi10_props,
92 };
93
94 static const struct property_entry connect_tablet9_props[] = {
95         PROPERTY_ENTRY_U32("touchscreen-min-x", 9),
96         PROPERTY_ENTRY_U32("touchscreen-min-y", 10),
97         PROPERTY_ENTRY_U32("touchscreen-size-x", 1664),
98         PROPERTY_ENTRY_U32("touchscreen-size-y", 880),
99         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
100         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
101         PROPERTY_ENTRY_STRING("firmware-name", "gsl1680-connect-tablet9.fw"),
102         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
103         { }
104 };
105
106 static const struct ts_dmi_data connect_tablet9_data = {
107         .acpi_name      = "MSSL1680:00",
108         .properties     = connect_tablet9_props,
109 };
110
111 static const struct property_entry cube_iwork8_air_props[] = {
112         PROPERTY_ENTRY_U32("touchscreen-min-x", 1),
113         PROPERTY_ENTRY_U32("touchscreen-min-y", 3),
114         PROPERTY_ENTRY_U32("touchscreen-size-x", 1664),
115         PROPERTY_ENTRY_U32("touchscreen-size-y", 896),
116         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
117         PROPERTY_ENTRY_STRING("firmware-name", "gsl3670-cube-iwork8-air.fw"),
118         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
119         { }
120 };
121
122 static const struct ts_dmi_data cube_iwork8_air_data = {
123         .acpi_name      = "MSSL1680:00",
124         .properties     = cube_iwork8_air_props,
125 };
126
127 static const struct property_entry cube_knote_i1101_props[] = {
128         PROPERTY_ENTRY_U32("touchscreen-min-x", 20),
129         PROPERTY_ENTRY_U32("touchscreen-min-y",  22),
130         PROPERTY_ENTRY_U32("touchscreen-size-x", 1961),
131         PROPERTY_ENTRY_U32("touchscreen-size-y", 1513),
132         PROPERTY_ENTRY_STRING("firmware-name", "gsl3692-cube-knote-i1101.fw"),
133         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
134         PROPERTY_ENTRY_BOOL("silead,home-button"),
135         { }
136 };
137
138 static const struct ts_dmi_data cube_knote_i1101_data = {
139         .acpi_name      = "MSSL1680:00",
140         .properties     = cube_knote_i1101_props,
141 };
142
143 static const struct property_entry dexp_ursus_7w_props[] = {
144         PROPERTY_ENTRY_U32("touchscreen-size-x", 890),
145         PROPERTY_ENTRY_U32("touchscreen-size-y", 630),
146         PROPERTY_ENTRY_STRING("firmware-name", "gsl1686-dexp-ursus-7w.fw"),
147         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
148         PROPERTY_ENTRY_BOOL("silead,home-button"),
149         { }
150 };
151
152 static const struct ts_dmi_data dexp_ursus_7w_data = {
153         .acpi_name      = "MSSL1680:00",
154         .properties     = dexp_ursus_7w_props,
155 };
156
157 static const struct property_entry digma_citi_e200_props[] = {
158         PROPERTY_ENTRY_U32("touchscreen-size-x", 1980),
159         PROPERTY_ENTRY_U32("touchscreen-size-y", 1500),
160         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
161         PROPERTY_ENTRY_STRING("firmware-name",
162                               "gsl1686-digma_citi_e200.fw"),
163         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
164         PROPERTY_ENTRY_BOOL("silead,home-button"),
165         { }
166 };
167
168 static const struct ts_dmi_data digma_citi_e200_data = {
169         .acpi_name      = "MSSL1680:00",
170         .properties     = digma_citi_e200_props,
171 };
172
173 static const struct property_entry gp_electronic_t701_props[] = {
174         PROPERTY_ENTRY_U32("touchscreen-size-x", 960),
175         PROPERTY_ENTRY_U32("touchscreen-size-y", 640),
176         PROPERTY_ENTRY_BOOL("touchscreen-inverted-x"),
177         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
178         PROPERTY_ENTRY_STRING("firmware-name",
179                               "gsl1680-gp-electronic-t701.fw"),
180         { }
181 };
182
183 static const struct ts_dmi_data gp_electronic_t701_data = {
184         .acpi_name      = "MSSL1680:00",
185         .properties     = gp_electronic_t701_props,
186 };
187
188 static const struct property_entry itworks_tw891_props[] = {
189         PROPERTY_ENTRY_U32("touchscreen-min-x", 1),
190         PROPERTY_ENTRY_U32("touchscreen-min-y", 5),
191         PROPERTY_ENTRY_U32("touchscreen-size-x", 1600),
192         PROPERTY_ENTRY_U32("touchscreen-size-y", 896),
193         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
194         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
195         PROPERTY_ENTRY_STRING("firmware-name", "gsl3670-itworks-tw891.fw"),
196         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
197         { }
198 };
199
200 static const struct ts_dmi_data itworks_tw891_data = {
201         .acpi_name      = "MSSL1680:00",
202         .properties     = itworks_tw891_props,
203 };
204
205 static const struct property_entry jumper_ezpad_6_pro_props[] = {
206         PROPERTY_ENTRY_U32("touchscreen-size-x", 1980),
207         PROPERTY_ENTRY_U32("touchscreen-size-y", 1500),
208         PROPERTY_ENTRY_STRING("firmware-name", "gsl3692-jumper-ezpad-6-pro.fw"),
209         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
210         PROPERTY_ENTRY_BOOL("silead,home-button"),
211         { }
212 };
213
214 static const struct ts_dmi_data jumper_ezpad_6_pro_data = {
215         .acpi_name      = "MSSL1680:00",
216         .properties     = jumper_ezpad_6_pro_props,
217 };
218
219 static const struct property_entry jumper_ezpad_mini3_props[] = {
220         PROPERTY_ENTRY_U32("touchscreen-min-x", 23),
221         PROPERTY_ENTRY_U32("touchscreen-min-y", 16),
222         PROPERTY_ENTRY_U32("touchscreen-size-x", 1700),
223         PROPERTY_ENTRY_U32("touchscreen-size-y", 1138),
224         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
225         PROPERTY_ENTRY_STRING("firmware-name", "gsl3676-jumper-ezpad-mini3.fw"),
226         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
227         { }
228 };
229
230 static const struct ts_dmi_data jumper_ezpad_mini3_data = {
231         .acpi_name      = "MSSL1680:00",
232         .properties     = jumper_ezpad_mini3_props,
233 };
234
235 static const struct property_entry onda_obook_20_plus_props[] = {
236         PROPERTY_ENTRY_U32("touchscreen-size-x", 1728),
237         PROPERTY_ENTRY_U32("touchscreen-size-y", 1148),
238         PROPERTY_ENTRY_BOOL("touchscreen-inverted-x"),
239         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
240         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
241         PROPERTY_ENTRY_STRING("firmware-name", "gsl3676-onda-obook-20-plus.fw"),
242         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
243         PROPERTY_ENTRY_BOOL("silead,home-button"),
244         { }
245 };
246
247 static const struct ts_dmi_data onda_obook_20_plus_data = {
248         .acpi_name      = "MSSL1680:00",
249         .properties     = onda_obook_20_plus_props,
250 };
251
252 static const struct property_entry onda_v80_plus_v3_props[] = {
253         PROPERTY_ENTRY_U32("touchscreen-min-x", 22),
254         PROPERTY_ENTRY_U32("touchscreen-min-y", 15),
255         PROPERTY_ENTRY_U32("touchscreen-size-x", 1698),
256         PROPERTY_ENTRY_U32("touchscreen-size-y", 1140),
257         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
258         PROPERTY_ENTRY_STRING("firmware-name",
259                               "gsl3676-onda-v80-plus-v3.fw"),
260         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
261         PROPERTY_ENTRY_BOOL("silead,home-button"),
262         { }
263 };
264
265 static const struct ts_dmi_data onda_v80_plus_v3_data = {
266         .acpi_name      = "MSSL1680:00",
267         .properties     = onda_v80_plus_v3_props,
268 };
269
270 static const struct property_entry onda_v820w_32g_props[] = {
271         PROPERTY_ENTRY_U32("touchscreen-size-x", 1665),
272         PROPERTY_ENTRY_U32("touchscreen-size-y", 1140),
273         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
274         PROPERTY_ENTRY_STRING("firmware-name",
275                               "gsl1680-onda-v820w-32g.fw"),
276         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
277         PROPERTY_ENTRY_BOOL("silead,home-button"),
278         { }
279 };
280
281 static const struct ts_dmi_data onda_v820w_32g_data = {
282         .acpi_name      = "MSSL1680:00",
283         .properties     = onda_v820w_32g_props,
284 };
285
286 static const struct property_entry onda_v891w_v1_props[] = {
287         PROPERTY_ENTRY_U32("touchscreen-min-x", 46),
288         PROPERTY_ENTRY_U32("touchscreen-min-y",  8),
289         PROPERTY_ENTRY_U32("touchscreen-size-x", 1676),
290         PROPERTY_ENTRY_U32("touchscreen-size-y", 1130),
291         PROPERTY_ENTRY_STRING("firmware-name",
292                               "gsl3680-onda-v891w-v1.fw"),
293         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
294         PROPERTY_ENTRY_BOOL("silead,home-button"),
295         { }
296 };
297
298 static const struct ts_dmi_data onda_v891w_v1_data = {
299         .acpi_name      = "MSSL1680:00",
300         .properties     = onda_v891w_v1_props,
301 };
302
303 static const struct property_entry onda_v891w_v3_props[] = {
304         PROPERTY_ENTRY_U32("touchscreen-min-x", 35),
305         PROPERTY_ENTRY_U32("touchscreen-min-y", 15),
306         PROPERTY_ENTRY_U32("touchscreen-size-x", 1625),
307         PROPERTY_ENTRY_U32("touchscreen-size-y", 1135),
308         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
309         PROPERTY_ENTRY_STRING("firmware-name",
310                               "gsl3676-onda-v891w-v3.fw"),
311         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
312         PROPERTY_ENTRY_BOOL("silead,home-button"),
313         { }
314 };
315
316 static const struct ts_dmi_data onda_v891w_v3_data = {
317         .acpi_name      = "MSSL1680:00",
318         .properties     = onda_v891w_v3_props,
319 };
320
321 static const struct property_entry pipo_w2s_props[] = {
322         PROPERTY_ENTRY_U32("touchscreen-size-x", 1660),
323         PROPERTY_ENTRY_U32("touchscreen-size-y", 880),
324         PROPERTY_ENTRY_BOOL("touchscreen-inverted-x"),
325         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
326         PROPERTY_ENTRY_STRING("firmware-name",
327                               "gsl1680-pipo-w2s.fw"),
328         { }
329 };
330
331 static const struct ts_dmi_data pipo_w2s_data = {
332         .acpi_name      = "MSSL1680:00",
333         .properties     = pipo_w2s_props,
334 };
335
336 static const struct property_entry pov_mobii_wintab_p800w_v20_props[] = {
337         PROPERTY_ENTRY_U32("touchscreen-min-x", 32),
338         PROPERTY_ENTRY_U32("touchscreen-min-y", 16),
339         PROPERTY_ENTRY_U32("touchscreen-size-x", 1692),
340         PROPERTY_ENTRY_U32("touchscreen-size-y", 1146),
341         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
342         PROPERTY_ENTRY_STRING("firmware-name",
343                               "gsl3680-pov-mobii-wintab-p800w-v20.fw"),
344         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
345         PROPERTY_ENTRY_BOOL("silead,home-button"),
346         { }
347 };
348
349 static const struct ts_dmi_data pov_mobii_wintab_p800w_v20_data = {
350         .acpi_name      = "MSSL1680:00",
351         .properties     = pov_mobii_wintab_p800w_v20_props,
352 };
353
354 static const struct property_entry pov_mobii_wintab_p800w_v21_props[] = {
355         PROPERTY_ENTRY_U32("touchscreen-min-x", 1),
356         PROPERTY_ENTRY_U32("touchscreen-min-y", 8),
357         PROPERTY_ENTRY_U32("touchscreen-size-x", 1794),
358         PROPERTY_ENTRY_U32("touchscreen-size-y", 1148),
359         PROPERTY_ENTRY_BOOL("touchscreen-swapped-x-y"),
360         PROPERTY_ENTRY_STRING("firmware-name",
361                               "gsl3692-pov-mobii-wintab-p800w.fw"),
362         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
363         PROPERTY_ENTRY_BOOL("silead,home-button"),
364         { }
365 };
366
367 static const struct ts_dmi_data pov_mobii_wintab_p800w_v21_data = {
368         .acpi_name      = "MSSL1680:00",
369         .properties     = pov_mobii_wintab_p800w_v21_props,
370 };
371
372 static const struct property_entry teclast_x3_plus_props[] = {
373         PROPERTY_ENTRY_U32("touchscreen-size-x", 1980),
374         PROPERTY_ENTRY_U32("touchscreen-size-y", 1500),
375         PROPERTY_ENTRY_STRING("firmware-name", "gsl1680-teclast-x3-plus.fw"),
376         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
377         PROPERTY_ENTRY_BOOL("silead,home-button"),
378         { }
379 };
380
381 static const struct ts_dmi_data teclast_x3_plus_data = {
382         .acpi_name      = "MSSL1680:00",
383         .properties     = teclast_x3_plus_props,
384 };
385
386 static const struct property_entry teclast_x98plus2_props[] = {
387         PROPERTY_ENTRY_U32("touchscreen-size-x", 2048),
388         PROPERTY_ENTRY_U32("touchscreen-size-y", 1280),
389         PROPERTY_ENTRY_BOOL("touchscreen-inverted-x"),
390         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
391         PROPERTY_ENTRY_STRING("firmware-name",
392                               "gsl1686-teclast_x98plus2.fw"),
393         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
394         { }
395 };
396
397 static const struct ts_dmi_data teclast_x98plus2_data = {
398         .acpi_name      = "MSSL1680:00",
399         .properties     = teclast_x98plus2_props,
400 };
401
402 static const struct property_entry trekstor_primebook_c11_props[] = {
403         PROPERTY_ENTRY_U32("touchscreen-size-x", 1970),
404         PROPERTY_ENTRY_U32("touchscreen-size-y", 1530),
405         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
406         PROPERTY_ENTRY_STRING("firmware-name",
407                               "gsl1680-trekstor-primebook-c11.fw"),
408         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
409         PROPERTY_ENTRY_BOOL("silead,home-button"),
410         { }
411 };
412
413 static const struct ts_dmi_data trekstor_primebook_c11_data = {
414         .acpi_name      = "MSSL1680:00",
415         .properties     = trekstor_primebook_c11_props,
416 };
417
418 static const struct property_entry trekstor_primebook_c13_props[] = {
419         PROPERTY_ENTRY_U32("touchscreen-size-x", 2624),
420         PROPERTY_ENTRY_U32("touchscreen-size-y", 1920),
421         PROPERTY_ENTRY_STRING("firmware-name",
422                               "gsl1680-trekstor-primebook-c13.fw"),
423         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
424         PROPERTY_ENTRY_BOOL("silead,home-button"),
425         { }
426 };
427
428 static const struct ts_dmi_data trekstor_primebook_c13_data = {
429         .acpi_name      = "MSSL1680:00",
430         .properties     = trekstor_primebook_c13_props,
431 };
432
433 static const struct property_entry trekstor_primetab_t13b_props[] = {
434         PROPERTY_ENTRY_U32("touchscreen-size-x", 2500),
435         PROPERTY_ENTRY_U32("touchscreen-size-y", 1900),
436         PROPERTY_ENTRY_STRING("firmware-name",
437                               "gsl1680-trekstor-primetab-t13b.fw"),
438         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
439         PROPERTY_ENTRY_BOOL("silead,home-button"),
440         PROPERTY_ENTRY_BOOL("touchscreen-inverted-y"),
441         { }
442 };
443
444 static const struct ts_dmi_data trekstor_primetab_t13b_data = {
445         .acpi_name  = "MSSL1680:00",
446         .properties = trekstor_primetab_t13b_props,
447 };
448
449 static const struct property_entry trekstor_surftab_twin_10_1_props[] = {
450         PROPERTY_ENTRY_U32("touchscreen-size-x", 1900),
451         PROPERTY_ENTRY_U32("touchscreen-size-y", 1280),
452         PROPERTY_ENTRY_U32("touchscreen-inverted-y", 1),
453         PROPERTY_ENTRY_STRING("firmware-name",
454                               "gsl3670-surftab-twin-10-1-st10432-8.fw"),
455         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
456         { }
457 };
458
459 static const struct ts_dmi_data trekstor_surftab_twin_10_1_data = {
460         .acpi_name      = "MSSL1680:00",
461         .properties     = trekstor_surftab_twin_10_1_props,
462 };
463
464 static const struct property_entry trekstor_surftab_wintron70_props[] = {
465         PROPERTY_ENTRY_U32("touchscreen-min-x", 12),
466         PROPERTY_ENTRY_U32("touchscreen-min-y", 8),
467         PROPERTY_ENTRY_U32("touchscreen-size-x", 884),
468         PROPERTY_ENTRY_U32("touchscreen-size-y", 632),
469         PROPERTY_ENTRY_STRING("firmware-name",
470                               "gsl1686-surftab-wintron70-st70416-6.fw"),
471         PROPERTY_ENTRY_U32("silead,max-fingers", 10),
472         PROPERTY_ENTRY_BOOL("silead,home-button"),
473         { }
474 };
475
476 static const struct ts_dmi_data trekstor_surftab_wintron70_data = {
477         .acpi_name      = "MSSL1680:00",
478         .properties     = trekstor_surftab_wintron70_props,
479 };
480
481 /* NOTE: Please keep this table sorted alphabetically */
482 static const struct dmi_system_id touchscreen_dmi_table[] = {
483         {
484                 /* Chuwi Hi8 */
485                 .driver_data = (void *)&chuwi_hi8_data,
486                 .matches = {
487                         DMI_MATCH(DMI_SYS_VENDOR, "ilife"),
488                         DMI_MATCH(DMI_PRODUCT_NAME, "S806"),
489                 },
490         },
491         {
492                 /* Chuwi Hi8 (H1D_S806_206) */
493                 .driver_data = (void *)&chuwi_hi8_data,
494                 .matches = {
495                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
496                         DMI_MATCH(DMI_PRODUCT_NAME, "BayTrail"),
497                         DMI_MATCH(DMI_BIOS_VERSION, "H1D_S806_206"),
498                 },
499         },
500         {
501                 /* Chuwi Hi8 Pro (CWI513) */
502                 .driver_data = (void *)&chuwi_hi8_pro_data,
503                 .matches = {
504                         DMI_MATCH(DMI_SYS_VENDOR, "Hampoo"),
505                         DMI_MATCH(DMI_PRODUCT_NAME, "X1D3_C806N"),
506                 },
507         },
508         {
509                 /* Chuwi Vi8 (CWI506) */
510                 .driver_data = (void *)&chuwi_vi8_data,
511                 .matches = {
512                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
513                         DMI_MATCH(DMI_PRODUCT_NAME, "i86"),
514                         DMI_MATCH(DMI_BIOS_VERSION, "CHUWI.D86JLBNR"),
515                 },
516         },
517         {
518                 /* Chuwi Vi10 (CWI505) */
519                 .driver_data = (void *)&chuwi_vi10_data,
520                 .matches = {
521                         DMI_MATCH(DMI_BOARD_VENDOR, "Hampoo"),
522                         DMI_MATCH(DMI_BOARD_NAME, "BYT-PF02"),
523                         DMI_MATCH(DMI_SYS_VENDOR, "ilife"),
524                         DMI_MATCH(DMI_PRODUCT_NAME, "S165"),
525                 },
526         },
527         {
528                 /* Connect Tablet 9 */
529                 .driver_data = (void *)&connect_tablet9_data,
530                 .matches = {
531                         DMI_MATCH(DMI_SYS_VENDOR, "Connect"),
532                         DMI_MATCH(DMI_PRODUCT_NAME, "Tablet 9"),
533                 },
534         },
535         {
536                 /* CUBE iwork8 Air */
537                 .driver_data = (void *)&cube_iwork8_air_data,
538                 .matches = {
539                         DMI_MATCH(DMI_SYS_VENDOR, "cube"),
540                         DMI_MATCH(DMI_PRODUCT_NAME, "i1-TF"),
541                         DMI_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"),
542                 },
543         },
544         {
545                 /* Cube KNote i1101 */
546                 .driver_data = (void *)&cube_knote_i1101_data,
547                 .matches = {
548                         DMI_MATCH(DMI_BOARD_VENDOR, "Hampoo"),
549                         DMI_MATCH(DMI_BOARD_NAME, "L1W6_I1101"),
550                         DMI_MATCH(DMI_SYS_VENDOR, "ALLDOCUBE"),
551                         DMI_MATCH(DMI_PRODUCT_NAME, "i1101"),
552                 },
553         },
554         {
555                 /* DEXP Ursus 7W */
556                 .driver_data = (void *)&dexp_ursus_7w_data,
557                 .matches = {
558                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
559                         DMI_MATCH(DMI_PRODUCT_NAME, "7W"),
560                 },
561         },
562         {
563                 /* Digma Citi E200 */
564                 .driver_data = (void *)&digma_citi_e200_data,
565                 .matches = {
566                         DMI_MATCH(DMI_SYS_VENDOR, "Digma"),
567                         DMI_MATCH(DMI_PRODUCT_NAME, "CITI E200"),
568                         DMI_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"),
569                 },
570         },
571         {
572                 /* GP-electronic T701 */
573                 .driver_data = (void *)&gp_electronic_t701_data,
574                 .matches = {
575                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
576                         DMI_MATCH(DMI_PRODUCT_NAME, "T701"),
577                         DMI_MATCH(DMI_BIOS_VERSION, "BYT70A.YNCHENG.WIN.007"),
578                 },
579         },
580         {
581                 /* I.T.Works TW701 (same hardware as the Trekstor ST70416-6) */
582                 .driver_data = (void *)&trekstor_surftab_wintron70_data,
583                 .matches = {
584                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
585                         DMI_MATCH(DMI_PRODUCT_NAME, "i71c"),
586                         DMI_MATCH(DMI_BIOS_VERSION, "itWORKS.G.WI71C.JGBMRB"),
587                 },
588         },
589         {
590                 /* I.T.Works TW891 */
591                 .driver_data = (void *)&itworks_tw891_data,
592                 .matches = {
593                         DMI_MATCH(DMI_SYS_VENDOR, "To be filled by O.E.M."),
594                         DMI_MATCH(DMI_PRODUCT_NAME, "TW891"),
595                 },
596         },
597         {
598                 /* Jumper EZpad 6 Pro */
599                 .driver_data = (void *)&jumper_ezpad_6_pro_data,
600                 .matches = {
601                         DMI_MATCH(DMI_SYS_VENDOR, "Jumper"),
602                         DMI_MATCH(DMI_PRODUCT_NAME, "EZpad"),
603                         DMI_MATCH(DMI_BIOS_VERSION, "5.12"),
604                         /* Above matches are too generic, add bios-date match */
605                         DMI_MATCH(DMI_BIOS_DATE, "08/18/2017"),
606                 },
607         },
608         {
609                 /* Jumper EZpad mini3 */
610                 .driver_data = (void *)&jumper_ezpad_mini3_data,
611                 .matches = {
612                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
613                         /* jumperx.T87.KFBNEEA02 with the version-nr dropped */
614                         DMI_MATCH(DMI_BIOS_VERSION, "jumperx.T87.KFBNEEA"),
615                 },
616         },
617         {
618                 /* Onda oBook 20 Plus */
619                 .driver_data = (void *)&onda_obook_20_plus_data,
620                 .matches = {
621                         DMI_MATCH(DMI_SYS_VENDOR, "ONDA"),
622                         DMI_MATCH(DMI_PRODUCT_NAME, "OBOOK 20 PLUS"),
623                 },
624         },
625         {
626                 /* ONDA V80 plus v3 (P80PSBG9V3A01501) */
627                 .driver_data = (void *)&onda_v80_plus_v3_data,
628                 .matches = {
629                         DMI_EXACT_MATCH(DMI_SYS_VENDOR, "ONDA"),
630                         DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "V80 PLUS")
631                 },
632         },
633         {
634                 /* ONDA V820w DualOS */
635                 .driver_data = (void *)&onda_v820w_32g_data,
636                 .matches = {
637                         DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "ONDA"),
638                         DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "V820w DualOS")
639                 },
640         },
641         {
642                 /* ONDA V891w revision P891WBEBV1B00 aka v1 */
643                 .driver_data = (void *)&onda_v891w_v1_data,
644                 .matches = {
645                         DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "ONDA"),
646                         DMI_EXACT_MATCH(DMI_BOARD_NAME, "ONDA Tablet"),
647                         DMI_EXACT_MATCH(DMI_BOARD_VERSION, "V001"),
648                         /* Exact match, different versions need different fw */
649                         DMI_EXACT_MATCH(DMI_BIOS_VERSION, "ONDA.W89EBBN08"),
650                 },
651         },
652         {
653                 /* ONDA V891w Dual OS P891DCF2V1A01274 64GB */
654                 .driver_data = (void *)&onda_v891w_v3_data,
655                 .matches = {
656                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
657                         DMI_MATCH(DMI_PRODUCT_NAME, "ONDA Tablet"),
658                         DMI_MATCH(DMI_BIOS_VERSION, "ONDA.D890HBBNR0A"),
659                 },
660         },
661         {
662                 /* Pipo W2S */
663                 .driver_data = (void *)&pipo_w2s_data,
664                 .matches = {
665                         DMI_MATCH(DMI_SYS_VENDOR, "PIPO"),
666                         DMI_MATCH(DMI_PRODUCT_NAME, "W2S"),
667                 },
668         },
669         {
670                 /* Ployer Momo7w (same hardware as the Trekstor ST70416-6) */
671                 .driver_data = (void *)&trekstor_surftab_wintron70_data,
672                 .matches = {
673                         DMI_MATCH(DMI_SYS_VENDOR, "Shenzhen PLOYER"),
674                         DMI_MATCH(DMI_PRODUCT_NAME, "MOMO7W"),
675                         /* Exact match, different versions need different fw */
676                         DMI_MATCH(DMI_BIOS_VERSION, "MOMO.G.WI71C.MABMRBA02"),
677                 },
678         },
679         {
680                 /* Point of View mobii wintab p800w (v2.0) */
681                 .driver_data = (void *)&pov_mobii_wintab_p800w_v20_data,
682                 .matches = {
683                         DMI_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"),
684                         DMI_MATCH(DMI_BOARD_NAME, "Aptio CRB"),
685                         DMI_MATCH(DMI_BIOS_VERSION, "3BAIR1014"),
686                         /* Above matches are too generic, add bios-date match */
687                         DMI_MATCH(DMI_BIOS_DATE, "10/24/2014"),
688                 },
689         },
690         {
691                 /* Point of View mobii wintab p800w (v2.1) */
692                 .driver_data = (void *)&pov_mobii_wintab_p800w_v21_data,
693                 .matches = {
694                         DMI_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"),
695                         DMI_MATCH(DMI_BOARD_NAME, "Aptio CRB"),
696                         DMI_MATCH(DMI_BIOS_VERSION, "3BAIR1013"),
697                         /* Above matches are too generic, add bios-date match */
698                         DMI_MATCH(DMI_BIOS_DATE, "08/22/2014"),
699                 },
700         },
701         {
702                 /* Teclast X3 Plus */
703                 .driver_data = (void *)&teclast_x3_plus_data,
704                 .matches = {
705                         DMI_MATCH(DMI_SYS_VENDOR, "TECLAST"),
706                         DMI_MATCH(DMI_PRODUCT_NAME, "X3 Plus"),
707                         DMI_MATCH(DMI_BOARD_NAME, "X3 Plus"),
708                 },
709         },
710         {
711                 /* Teclast X98 Plus II */
712                 .driver_data = (void *)&teclast_x98plus2_data,
713                 .matches = {
714                         DMI_MATCH(DMI_SYS_VENDOR, "TECLAST"),
715                         DMI_MATCH(DMI_PRODUCT_NAME, "X98 Plus II"),
716                 },
717         },
718         {
719                 /* Trekstor Primebook C11 */
720                 .driver_data = (void *)&trekstor_primebook_c11_data,
721                 .matches = {
722                         DMI_MATCH(DMI_SYS_VENDOR, "TREKSTOR"),
723                         DMI_MATCH(DMI_PRODUCT_NAME, "Primebook C11"),
724                 },
725         },
726         {
727                 /* Trekstor Primebook C13 */
728                 .driver_data = (void *)&trekstor_primebook_c13_data,
729                 .matches = {
730                         DMI_MATCH(DMI_SYS_VENDOR, "TREKSTOR"),
731                         DMI_MATCH(DMI_PRODUCT_NAME, "Primebook C13"),
732                 },
733         },
734         {
735                 /* Trekstor Primetab T13B */
736                 .driver_data = (void *)&trekstor_primetab_t13b_data,
737                 .matches = {
738                         DMI_MATCH(DMI_SYS_VENDOR, "TREKSTOR"),
739                         DMI_MATCH(DMI_PRODUCT_NAME, "Primetab T13B"),
740                 },
741         },
742         {
743                 /* TrekStor SurfTab twin 10.1 ST10432-8 */
744                 .driver_data = (void *)&trekstor_surftab_twin_10_1_data,
745                 .matches = {
746                         DMI_MATCH(DMI_SYS_VENDOR, "TrekStor"),
747                         DMI_MATCH(DMI_PRODUCT_NAME, "SurfTab twin 10.1"),
748                 },
749         },
750         {
751                 /* Trekstor Surftab Wintron 7.0 ST70416-6 */
752                 .driver_data = (void *)&trekstor_surftab_wintron70_data,
753                 .matches = {
754                         DMI_MATCH(DMI_SYS_VENDOR, "Insyde"),
755                         DMI_MATCH(DMI_PRODUCT_NAME, "ST70416-6"),
756                         /* Exact match, different versions need different fw */
757                         DMI_MATCH(DMI_BIOS_VERSION, "TREK.G.WI71C.JGBMRBA04"),
758                 },
759         },
760         {
761                 /* Trekstor Surftab Wintron 7.0 ST70416-6, newer BIOS */
762                 .driver_data = (void *)&trekstor_surftab_wintron70_data,
763                 .matches = {
764                         DMI_MATCH(DMI_SYS_VENDOR, "TrekStor"),
765                         DMI_MATCH(DMI_PRODUCT_NAME,
766                                              "SurfTab wintron 7.0 ST70416-6"),
767                         /* Exact match, different versions need different fw */
768                         DMI_MATCH(DMI_BIOS_VERSION, "TREK.G.WI71C.JGBMRBA05"),
769                 },
770         },
771         {
772                 /* Yours Y8W81, same case and touchscreen as Chuwi Vi8 */
773                 .driver_data = (void *)&chuwi_vi8_data,
774                 .matches = {
775                         DMI_MATCH(DMI_SYS_VENDOR, "YOURS"),
776                         DMI_MATCH(DMI_PRODUCT_NAME, "Y8W81"),
777                 },
778         },
779         { },
780 };
781
782 static const struct ts_dmi_data *ts_data;
783
784 static void ts_dmi_add_props(struct i2c_client *client)
785 {
786         struct device *dev = &client->dev;
787         int error;
788
789         if (has_acpi_companion(dev) &&
790             !strncmp(ts_data->acpi_name, client->name, I2C_NAME_SIZE)) {
791                 error = device_add_properties(dev, ts_data->properties);
792                 if (error)
793                         dev_err(dev, "failed to add properties: %d\n", error);
794         }
795 }
796
797 static int ts_dmi_notifier_call(struct notifier_block *nb,
798                                        unsigned long action, void *data)
799 {
800         struct device *dev = data;
801         struct i2c_client *client;
802
803         switch (action) {
804         case BUS_NOTIFY_ADD_DEVICE:
805                 client = i2c_verify_client(dev);
806                 if (client)
807                         ts_dmi_add_props(client);
808                 break;
809
810         default:
811                 break;
812         }
813
814         return 0;
815 }
816
817 static struct notifier_block ts_dmi_notifier = {
818         .notifier_call = ts_dmi_notifier_call,
819 };
820
821 static int __init ts_dmi_init(void)
822 {
823         const struct dmi_system_id *dmi_id;
824         int error;
825
826         dmi_id = dmi_first_match(touchscreen_dmi_table);
827         if (!dmi_id)
828                 return 0; /* Not an error */
829
830         ts_data = dmi_id->driver_data;
831
832         error = bus_register_notifier(&i2c_bus_type, &ts_dmi_notifier);
833         if (error)
834                 pr_err("%s: failed to register i2c bus notifier: %d\n",
835                         __func__, error);
836
837         return error;
838 }
839
840 /*
841  * We are registering out notifier after i2c core is initialized and i2c bus
842  * itself is ready (which happens at postcore initcall level), but before
843  * ACPI starts enumerating devices (at subsys initcall level).
844  */
845 arch_initcall(ts_dmi_init);
This page took 0.094702 seconds and 4 git commands to generate.