acpi_pnp.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  1. /*
  2. * ACPI support for PNP bus type
  3. *
  4. * Copyright (C) 2014, Intel Corporation
  5. * Authors: Zhang Rui <rui.zhang@intel.com>
  6. * Rafael J. Wysocki <rafael.j.wysocki@intel.com>
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License version 2 as
  10. * published by the Free Software Foundation.
  11. */
  12. #include <linux/acpi.h>
  13. #include <linux/module.h>
  14. #include <linux/ctype.h>
  15. static const struct acpi_device_id acpi_pnp_device_ids[] = {
  16. /* pata_isapnp */
  17. {"PNP0600"}, /* Generic ESDI/IDE/ATA compatible hard disk controller */
  18. /* floppy */
  19. {"PNP0700"},
  20. /* ipmi_si */
  21. {"IPI0001"},
  22. /* tpm_inf_pnp */
  23. {"IFX0101"}, /* Infineon TPMs */
  24. {"IFX0102"}, /* Infineon TPMs */
  25. /*tpm_tis */
  26. {"PNP0C31"}, /* TPM */
  27. {"ATM1200"}, /* Atmel */
  28. {"IFX0102"}, /* Infineon */
  29. {"BCM0101"}, /* Broadcom */
  30. {"BCM0102"}, /* Broadcom */
  31. {"NSC1200"}, /* National */
  32. {"ICO0102"}, /* Intel */
  33. /* ide */
  34. {"PNP0600"}, /* Generic ESDI/IDE/ATA compatible hard disk controller */
  35. /* ns558 */
  36. {"ASB16fd"}, /* AdLib NSC16 */
  37. {"AZT3001"}, /* AZT1008 */
  38. {"CDC0001"}, /* Opl3-SAx */
  39. {"CSC0001"}, /* CS4232 */
  40. {"CSC000f"}, /* CS4236 */
  41. {"CSC0101"}, /* CS4327 */
  42. {"CTL7001"}, /* SB16 */
  43. {"CTL7002"}, /* AWE64 */
  44. {"CTL7005"}, /* Vibra16 */
  45. {"ENS2020"}, /* SoundscapeVIVO */
  46. {"ESS0001"}, /* ES1869 */
  47. {"ESS0005"}, /* ES1878 */
  48. {"ESS6880"}, /* ES688 */
  49. {"IBM0012"}, /* CS4232 */
  50. {"OPT0001"}, /* OPTi Audio16 */
  51. {"YMH0006"}, /* Opl3-SA */
  52. {"YMH0022"}, /* Opl3-SAx */
  53. {"PNPb02f"}, /* Generic */
  54. /* i8042 kbd */
  55. {"PNP0300"},
  56. {"PNP0301"},
  57. {"PNP0302"},
  58. {"PNP0303"},
  59. {"PNP0304"},
  60. {"PNP0305"},
  61. {"PNP0306"},
  62. {"PNP0309"},
  63. {"PNP030a"},
  64. {"PNP030b"},
  65. {"PNP0320"},
  66. {"PNP0343"},
  67. {"PNP0344"},
  68. {"PNP0345"},
  69. {"CPQA0D7"},
  70. /* i8042 aux */
  71. {"AUI0200"},
  72. {"FJC6000"},
  73. {"FJC6001"},
  74. {"PNP0f03"},
  75. {"PNP0f0b"},
  76. {"PNP0f0e"},
  77. {"PNP0f12"},
  78. {"PNP0f13"},
  79. {"PNP0f19"},
  80. {"PNP0f1c"},
  81. {"SYN0801"},
  82. /* fcpnp */
  83. {"AVM0900"},
  84. /* radio-cadet */
  85. {"MSM0c24"}, /* ADS Cadet AM/FM Radio Card */
  86. /* radio-gemtek */
  87. {"ADS7183"}, /* AOpen FX-3D/Pro Radio */
  88. /* radio-sf16fmr2 */
  89. {"MFRad13"}, /* tuner subdevice of SF16-FMD2 */
  90. /* ene_ir */
  91. {"ENE0100"},
  92. {"ENE0200"},
  93. {"ENE0201"},
  94. {"ENE0202"},
  95. /* fintek-cir */
  96. {"FIT0002"}, /* CIR */
  97. /* ite-cir */
  98. {"ITE8704"}, /* Default model */
  99. {"ITE8713"}, /* CIR found in EEEBox 1501U */
  100. {"ITE8708"}, /* Bridged IT8512 */
  101. {"ITE8709"}, /* SRAM-Bridged IT8512 */
  102. /* nuvoton-cir */
  103. {"WEC0530"}, /* CIR */
  104. {"NTN0530"}, /* CIR for new chip's pnp id */
  105. /* Winbond CIR */
  106. {"WEC1022"},
  107. /* wbsd */
  108. {"WEC0517"},
  109. {"WEC0518"},
  110. /* Winbond CIR */
  111. {"TCM5090"}, /* 3Com Etherlink III (TP) */
  112. {"TCM5091"}, /* 3Com Etherlink III */
  113. {"TCM5094"}, /* 3Com Etherlink III (combo) */
  114. {"TCM5095"}, /* 3Com Etherlink III (TPO) */
  115. {"TCM5098"}, /* 3Com Etherlink III (TPC) */
  116. {"PNP80f7"}, /* 3Com Etherlink III compatible */
  117. {"PNP80f8"}, /* 3Com Etherlink III compatible */
  118. /* nsc-ircc */
  119. {"NSC6001"},
  120. {"HWPC224"},
  121. {"IBM0071"},
  122. /* smsc-ircc2 */
  123. {"SMCf010"},
  124. /* sb1000 */
  125. {"GIC1000"},
  126. /* parport_pc */
  127. {"PNP0400"}, /* Standard LPT Printer Port */
  128. {"PNP0401"}, /* ECP Printer Port */
  129. /* apple-gmux */
  130. {"APP000B"},
  131. /* system */
  132. {"PNP0c02"}, /* General ID for reserving resources */
  133. {"PNP0c01"}, /* memory controller */
  134. /* rtc_cmos */
  135. {"PNP0b00"},
  136. {"PNP0b01"},
  137. {"PNP0b02"},
  138. /* c6xdigio */
  139. {"PNP0400"}, /* Standard LPT Printer Port */
  140. {"PNP0401"}, /* ECP Printer Port */
  141. /* ni_atmio.c */
  142. {"NIC1900"},
  143. {"NIC2400"},
  144. {"NIC2500"},
  145. {"NIC2600"},
  146. {"NIC2700"},
  147. /* serial */
  148. {"AAC000F"}, /* Archtek America Corp. Archtek SmartLink Modem 3334BT Plug & Play */
  149. {"ADC0001"}, /* Anchor Datacomm BV. SXPro 144 External Data Fax Modem Plug & Play */
  150. {"ADC0002"}, /* SXPro 288 External Data Fax Modem Plug & Play */
  151. {"AEI0250"}, /* PROLiNK 1456VH ISA PnP K56flex Fax Modem */
  152. {"AEI1240"}, /* Actiontec ISA PNP 56K X2 Fax Modem */
  153. {"AKY1021"}, /* Rockwell 56K ACF II Fax+Data+Voice Modem */
  154. {"AZT4001"}, /* AZT3005 PnP SOUND DEVICE */
  155. {"BDP3336"}, /* Best Data Products Inc. Smart One 336F PnP Modem */
  156. {"BRI0A49"}, /* Boca Complete Ofc Communicator 14.4 Data-FAX */
  157. {"BRI1400"}, /* Boca Research 33,600 ACF Modem */
  158. {"BRI3400"}, /* Boca 33.6 Kbps Internal FD34FSVD */
  159. {"BRI0A49"}, /* Boca 33.6 Kbps Internal FD34FSVD */
  160. {"BDP3336"}, /* Best Data Products Inc. Smart One 336F PnP Modem */
  161. {"CPI4050"}, /* Computer Peripherals Inc. EuroViVa CommCenter-33.6 SP PnP */
  162. {"CTL3001"}, /* Creative Labs Phone Blaster 28.8 DSVD PnP Voice */
  163. {"CTL3011"}, /* Creative Labs Modem Blaster 28.8 DSVD PnP Voice */
  164. {"DAV0336"}, /* Davicom ISA 33.6K Modem */
  165. {"DMB1032"}, /* Creative Modem Blaster Flash56 DI5601-1 */
  166. {"DMB2001"}, /* Creative Modem Blaster V.90 DI5660 */
  167. {"ETT0002"}, /* E-Tech CyberBULLET PC56RVP */
  168. {"FUJ0202"}, /* Fujitsu 33600 PnP-I2 R Plug & Play */
  169. {"FUJ0205"}, /* Fujitsu FMV-FX431 Plug & Play */
  170. {"FUJ0206"}, /* Fujitsu 33600 PnP-I4 R Plug & Play */
  171. {"FUJ0209"}, /* Fujitsu Fax Voice 33600 PNP-I5 R Plug & Play */
  172. {"GVC000F"}, /* Archtek SmartLink Modem 3334BT Plug & Play */
  173. {"GVC0303"}, /* Archtek SmartLink Modem 3334BRV 33.6K Data Fax Voice */
  174. {"HAY0001"}, /* Hayes Optima 288 V.34-V.FC + FAX + Voice Plug & Play */
  175. {"HAY000C"}, /* Hayes Optima 336 V.34 + FAX + Voice PnP */
  176. {"HAY000D"}, /* Hayes Optima 336B V.34 + FAX + Voice PnP */
  177. {"HAY5670"}, /* Hayes Accura 56K Ext Fax Modem PnP */
  178. {"HAY5674"}, /* Hayes Accura 56K Ext Fax Modem PnP */
  179. {"HAY5675"}, /* Hayes Accura 56K Fax Modem PnP */
  180. {"HAYF000"}, /* Hayes 288, V.34 + FAX */
  181. {"HAYF001"}, /* Hayes Optima 288 V.34 + FAX + Voice, Plug & Play */
  182. {"IBM0033"}, /* IBM Thinkpad 701 Internal Modem Voice */
  183. {"PNP4972"}, /* Intermec CV60 touchscreen port */
  184. {"IXDC801"}, /* Intertex 28k8 33k6 Voice EXT PnP */
  185. {"IXDC901"}, /* Intertex 33k6 56k Voice EXT PnP */
  186. {"IXDD801"}, /* Intertex 28k8 33k6 Voice SP EXT PnP */
  187. {"IXDD901"}, /* Intertex 33k6 56k Voice SP EXT PnP */
  188. {"IXDF401"}, /* Intertex 28k8 33k6 Voice SP INT PnP */
  189. {"IXDF801"}, /* Intertex 28k8 33k6 Voice SP EXT PnP */
  190. {"IXDF901"}, /* Intertex 33k6 56k Voice SP EXT PnP */
  191. {"KOR4522"}, /* KORTEX 28800 Externe PnP */
  192. {"KORF661"}, /* KXPro 33.6 Vocal ASVD PnP */
  193. {"LAS4040"}, /* LASAT Internet 33600 PnP */
  194. {"LAS4540"}, /* Lasat Safire 560 PnP */
  195. {"LAS5440"}, /* Lasat Safire 336 PnP */
  196. {"MNP0281"}, /* Microcom TravelPorte FAST V.34 Plug & Play */
  197. {"MNP0336"}, /* Microcom DeskPorte V.34 FAST or FAST+ Plug & Play */
  198. {"MNP0339"}, /* Microcom DeskPorte FAST EP 28.8 Plug & Play */
  199. {"MNP0342"}, /* Microcom DeskPorte 28.8P Plug & Play */
  200. {"MNP0500"}, /* Microcom DeskPorte FAST ES 28.8 Plug & Play */
  201. {"MNP0501"}, /* Microcom DeskPorte FAST ES 28.8 Plug & Play */
  202. {"MNP0502"}, /* Microcom DeskPorte 28.8S Internal Plug & Play */
  203. {"MOT1105"}, /* Motorola BitSURFR Plug & Play */
  204. {"MOT1111"}, /* Motorola TA210 Plug & Play */
  205. {"MOT1114"}, /* Motorola HMTA 200 (ISDN) Plug & Play */
  206. {"MOT1115"}, /* Motorola BitSURFR Plug & Play */
  207. {"MOT1190"}, /* Motorola Lifestyle 28.8 Internal */
  208. {"MOT1501"}, /* Motorola V.3400 Plug & Play */
  209. {"MOT1502"}, /* Motorola Lifestyle 28.8 V.34 Plug & Play */
  210. {"MOT1505"}, /* Motorola Power 28.8 V.34 Plug & Play */
  211. {"MOT1509"}, /* Motorola ModemSURFR External 28.8 Plug & Play */
  212. {"MOT150A"}, /* Motorola Premier 33.6 Desktop Plug & Play */
  213. {"MOT150F"}, /* Motorola VoiceSURFR 56K External PnP */
  214. {"MOT1510"}, /* Motorola ModemSURFR 56K External PnP */
  215. {"MOT1550"}, /* Motorola ModemSURFR 56K Internal PnP */
  216. {"MOT1560"}, /* Motorola ModemSURFR Internal 28.8 Plug & Play */
  217. {"MOT1580"}, /* Motorola Premier 33.6 Internal Plug & Play */
  218. {"MOT15B0"}, /* Motorola OnlineSURFR 28.8 Internal Plug & Play */
  219. {"MOT15F0"}, /* Motorola VoiceSURFR 56K Internal PnP */
  220. {"MVX00A1"}, /* Deskline K56 Phone System PnP */
  221. {"MVX00F2"}, /* PC Rider K56 Phone System PnP */
  222. {"nEC8241"}, /* NEC 98NOTE SPEAKER PHONE FAX MODEM(33600bps) */
  223. {"PMC2430"}, /* Pace 56 Voice Internal Plug & Play Modem */
  224. {"PNP0500"}, /* Generic standard PC COM port */
  225. {"PNP0501"}, /* Generic 16550A-compatible COM port */
  226. {"PNPC000"}, /* Compaq 14400 Modem */
  227. {"PNPC001"}, /* Compaq 2400/9600 Modem */
  228. {"PNPC031"}, /* Dial-Up Networking Serial Cable between 2 PCs */
  229. {"PNPC032"}, /* Dial-Up Networking Parallel Cable between 2 PCs */
  230. {"PNPC100"}, /* Standard 9600 bps Modem */
  231. {"PNPC101"}, /* Standard 14400 bps Modem */
  232. {"PNPC102"}, /* Standard 28800 bps Modem */
  233. {"PNPC103"}, /* Standard Modem */
  234. {"PNPC104"}, /* Standard 9600 bps Modem */
  235. {"PNPC105"}, /* Standard 14400 bps Modem */
  236. {"PNPC106"}, /* Standard 28800 bps Modem */
  237. {"PNPC107"}, /* Standard Modem */
  238. {"PNPC108"}, /* Standard 9600 bps Modem */
  239. {"PNPC109"}, /* Standard 14400 bps Modem */
  240. {"PNPC10A"}, /* Standard 28800 bps Modem */
  241. {"PNPC10B"}, /* Standard Modem */
  242. {"PNPC10C"}, /* Standard 9600 bps Modem */
  243. {"PNPC10D"}, /* Standard 14400 bps Modem */
  244. {"PNPC10E"}, /* Standard 28800 bps Modem */
  245. {"PNPC10F"}, /* Standard Modem */
  246. {"PNP2000"}, /* Standard PCMCIA Card Modem */
  247. {"ROK0030"}, /* Rockwell 33.6 DPF Internal PnP, Modular Technology 33.6 Internal PnP */
  248. {"ROK0100"}, /* KORTEX 14400 Externe PnP */
  249. {"ROK4120"}, /* Rockwell 28.8 */
  250. {"ROK4920"}, /* Viking 28.8 INTERNAL Fax+Data+Voice PnP */
  251. {"RSS00A0"}, /* Rockwell 33.6 DPF External PnP, BT Prologue 33.6 External PnP, Modular Technology 33.6 External PnP */
  252. {"RSS0262"}, /* Viking 56K FAX INT */
  253. {"RSS0250"}, /* K56 par,VV,Voice,Speakphone,AudioSpan,PnP */
  254. {"SUP1310"}, /* SupraExpress 28.8 Data/Fax PnP modem */
  255. {"SUP1381"}, /* SupraExpress 336i PnP Voice Modem */
  256. {"SUP1421"}, /* SupraExpress 33.6 Data/Fax PnP modem */
  257. {"SUP1590"}, /* SupraExpress 33.6 Data/Fax PnP modem */
  258. {"SUP1620"}, /* SupraExpress 336i Sp ASVD */
  259. {"SUP1760"}, /* SupraExpress 33.6 Data/Fax PnP modem */
  260. {"SUP2171"}, /* SupraExpress 56i Sp Intl */
  261. {"TEX0011"}, /* Phoebe Micro 33.6 Data Fax 1433VQH Plug & Play */
  262. {"UAC000F"}, /* Archtek SmartLink Modem 3334BT Plug & Play */
  263. {"USR0000"}, /* 3Com Corp. Gateway Telepath IIvi 33.6 */
  264. {"USR0002"}, /* U.S. Robotics Sporster 33.6K Fax INT PnP */
  265. {"USR0004"}, /* Sportster Vi 14.4 PnP FAX Voicemail */
  266. {"USR0006"}, /* U.S. Robotics 33.6K Voice INT PnP */
  267. {"USR0007"}, /* U.S. Robotics 33.6K Voice EXT PnP */
  268. {"USR0009"}, /* U.S. Robotics Courier V.Everything INT PnP */
  269. {"USR2002"}, /* U.S. Robotics 33.6K Voice INT PnP */
  270. {"USR2070"}, /* U.S. Robotics 56K Voice INT PnP */
  271. {"USR2080"}, /* U.S. Robotics 56K Voice EXT PnP */
  272. {"USR3031"}, /* U.S. Robotics 56K FAX INT */
  273. {"USR3050"}, /* U.S. Robotics 56K FAX INT */
  274. {"USR3070"}, /* U.S. Robotics 56K Voice INT PnP */
  275. {"USR3080"}, /* U.S. Robotics 56K Voice EXT PnP */
  276. {"USR3090"}, /* U.S. Robotics 56K Voice INT PnP */
  277. {"USR9100"}, /* U.S. Robotics 56K Message */
  278. {"USR9160"}, /* U.S. Robotics 56K FAX EXT PnP */
  279. {"USR9170"}, /* U.S. Robotics 56K FAX INT PnP */
  280. {"USR9180"}, /* U.S. Robotics 56K Voice EXT PnP */
  281. {"USR9190"}, /* U.S. Robotics 56K Voice INT PnP */
  282. {"WACFXXX"}, /* Wacom tablets */
  283. {"FPI2002"}, /* Compaq touchscreen */
  284. {"FUJ02B2"}, /* Fujitsu Stylistic touchscreens */
  285. {"FUJ02B3"},
  286. {"FUJ02B4"}, /* Fujitsu Stylistic LT touchscreens */
  287. {"FUJ02B6"}, /* Passive Fujitsu Stylistic touchscreens */
  288. {"FUJ02B7"},
  289. {"FUJ02B8"},
  290. {"FUJ02B9"},
  291. {"FUJ02BC"},
  292. {"FUJ02E5"}, /* Fujitsu Wacom Tablet PC device */
  293. {"FUJ02E6"}, /* Fujitsu P-series tablet PC device */
  294. {"FUJ02E7"}, /* Fujitsu Wacom 2FGT Tablet PC device */
  295. {"FUJ02E9"}, /* Fujitsu Wacom 1FGT Tablet PC device */
  296. {"LTS0001"}, /* LG C1 EXPRESS DUAL (C1-PB11A3) touch screen (actually a FUJ02E6 in disguise) */
  297. {"WCI0003"}, /* Rockwell's (PORALiNK) 33600 INT PNP */
  298. {"WEC1022"}, /* Winbond CIR port, should not be probed. We should keep track of it to prevent the legacy serial driver from probing it */
  299. /* scl200wdt */
  300. {"NSC0800"}, /* National Semiconductor PC87307/PC97307 watchdog component */
  301. /* mpu401 */
  302. {"PNPb006"},
  303. /* cs423x-pnpbios */
  304. {"CSC0100"},
  305. {"CSC0103"},
  306. {"CSC0110"},
  307. {"CSC0000"},
  308. {"GIM0100"}, /* Guillemot Turtlebeach something appears to be cs4232 compatible */
  309. /* es18xx-pnpbios */
  310. {"ESS1869"},
  311. {"ESS1879"},
  312. /* snd-opl3sa2-pnpbios */
  313. {"YMH0021"},
  314. {"NMX2210"}, /* Gateway Solo 2500 */
  315. {""},
  316. };
  317. static bool matching_id(char *idstr, char *list_id)
  318. {
  319. int i;
  320. if (memcmp(idstr, list_id, 3))
  321. return false;
  322. for (i = 3; i < 7; i++) {
  323. char c = toupper(idstr[i]);
  324. if (!isxdigit(c)
  325. || (list_id[i] != 'X' && c != toupper(list_id[i])))
  326. return false;
  327. }
  328. return true;
  329. }
  330. static bool acpi_pnp_match(char *idstr, const struct acpi_device_id **matchid)
  331. {
  332. const struct acpi_device_id *devid;
  333. for (devid = acpi_pnp_device_ids; devid->id[0]; devid++)
  334. if (matching_id(idstr, (char *)devid->id)) {
  335. if (matchid)
  336. *matchid = devid;
  337. return true;
  338. }
  339. return false;
  340. }
  341. static int acpi_pnp_attach(struct acpi_device *adev,
  342. const struct acpi_device_id *id)
  343. {
  344. return 1;
  345. }
  346. static struct acpi_scan_handler acpi_pnp_handler = {
  347. .ids = acpi_pnp_device_ids,
  348. .match = acpi_pnp_match,
  349. .attach = acpi_pnp_attach,
  350. };
  351. /*
  352. * For CMOS RTC devices, the PNP ACPI scan handler does not work, because
  353. * there is a CMOS RTC ACPI scan handler installed already, so we need to
  354. * check those devices and enumerate them to the PNP bus directly.
  355. */
  356. static int is_cmos_rtc_device(struct acpi_device *adev)
  357. {
  358. struct acpi_device_id ids[] = {
  359. { "PNP0B00" },
  360. { "PNP0B01" },
  361. { "PNP0B02" },
  362. {""},
  363. };
  364. return !acpi_match_device_ids(adev, ids);
  365. }
  366. bool acpi_is_pnp_device(struct acpi_device *adev)
  367. {
  368. return adev->handler == &acpi_pnp_handler || is_cmos_rtc_device(adev);
  369. }
  370. EXPORT_SYMBOL_GPL(acpi_is_pnp_device);
  371. void __init acpi_pnp_init(void)
  372. {
  373. acpi_scan_add_handler(&acpi_pnp_handler);
  374. }