pinctrl-tigerlake.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Intel Tiger Lake PCH pinctrl/GPIO driver
  4. *
  5. * Copyright (C) 2019 - 2020, Intel Corporation
  6. * Authors: Andy Shevchenko <[email protected]>
  7. * Mika Westerberg <[email protected]>
  8. */
  9. #include <linux/mod_devicetable.h>
  10. #include <linux/module.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/pinctrl/pinctrl.h>
  13. #include "pinctrl-intel.h"
  14. #define TGL_PAD_OWN 0x020
  15. #define TGL_LP_PADCFGLOCK 0x080
  16. #define TGL_H_PADCFGLOCK 0x090
  17. #define TGL_LP_HOSTSW_OWN 0x0b0
  18. #define TGL_H_HOSTSW_OWN 0x0c0
  19. #define TGL_GPI_IS 0x100
  20. #define TGL_GPI_IE 0x120
  21. #define TGL_GPP(r, s, e, g) \
  22. { \
  23. .reg_num = (r), \
  24. .base = (s), \
  25. .size = ((e) - (s) + 1), \
  26. .gpio_base = (g), \
  27. }
  28. #define TGL_COMMUNITY(b, s, e, pl, ho, g) \
  29. { \
  30. .barno = (b), \
  31. .padown_offset = TGL_PAD_OWN, \
  32. .padcfglock_offset = (pl), \
  33. .hostown_offset = (ho), \
  34. .is_offset = TGL_GPI_IS, \
  35. .ie_offset = TGL_GPI_IE, \
  36. .pin_base = (s), \
  37. .npins = ((e) - (s) + 1), \
  38. .gpps = (g), \
  39. .ngpps = ARRAY_SIZE(g), \
  40. }
  41. #define TGL_LP_COMMUNITY(b, s, e, g) \
  42. TGL_COMMUNITY(b, s, e, TGL_LP_PADCFGLOCK, TGL_LP_HOSTSW_OWN, g)
  43. #define TGL_H_COMMUNITY(b, s, e, g) \
  44. TGL_COMMUNITY(b, s, e, TGL_H_PADCFGLOCK, TGL_H_HOSTSW_OWN, g)
  45. /* Tiger Lake-LP */
  46. static const struct pinctrl_pin_desc tgllp_pins[] = {
  47. /* GPP_B */
  48. PINCTRL_PIN(0, "CORE_VID_0"),
  49. PINCTRL_PIN(1, "CORE_VID_1"),
  50. PINCTRL_PIN(2, "VRALERTB"),
  51. PINCTRL_PIN(3, "CPU_GP_2"),
  52. PINCTRL_PIN(4, "CPU_GP_3"),
  53. PINCTRL_PIN(5, "ISH_I2C0_SDA"),
  54. PINCTRL_PIN(6, "ISH_I2C0_SCL"),
  55. PINCTRL_PIN(7, "ISH_I2C1_SDA"),
  56. PINCTRL_PIN(8, "ISH_I2C1_SCL"),
  57. PINCTRL_PIN(9, "I2C5_SDA"),
  58. PINCTRL_PIN(10, "I2C5_SCL"),
  59. PINCTRL_PIN(11, "PMCALERTB"),
  60. PINCTRL_PIN(12, "SLP_S0B"),
  61. PINCTRL_PIN(13, "PLTRSTB"),
  62. PINCTRL_PIN(14, "SPKR"),
  63. PINCTRL_PIN(15, "GSPI0_CS0B"),
  64. PINCTRL_PIN(16, "GSPI0_CLK"),
  65. PINCTRL_PIN(17, "GSPI0_MISO"),
  66. PINCTRL_PIN(18, "GSPI0_MOSI"),
  67. PINCTRL_PIN(19, "GSPI1_CS0B"),
  68. PINCTRL_PIN(20, "GSPI1_CLK"),
  69. PINCTRL_PIN(21, "GSPI1_MISO"),
  70. PINCTRL_PIN(22, "GSPI1_MOSI"),
  71. PINCTRL_PIN(23, "SML1ALERTB"),
  72. PINCTRL_PIN(24, "GSPI0_CLK_LOOPBK"),
  73. PINCTRL_PIN(25, "GSPI1_CLK_LOOPBK"),
  74. /* GPP_T */
  75. PINCTRL_PIN(26, "I2C6_SDA"),
  76. PINCTRL_PIN(27, "I2C6_SCL"),
  77. PINCTRL_PIN(28, "I2C7_SDA"),
  78. PINCTRL_PIN(29, "I2C7_SCL"),
  79. PINCTRL_PIN(30, "UART4_RXD"),
  80. PINCTRL_PIN(31, "UART4_TXD"),
  81. PINCTRL_PIN(32, "UART4_RTSB"),
  82. PINCTRL_PIN(33, "UART4_CTSB"),
  83. PINCTRL_PIN(34, "UART5_RXD"),
  84. PINCTRL_PIN(35, "UART5_TXD"),
  85. PINCTRL_PIN(36, "UART5_RTSB"),
  86. PINCTRL_PIN(37, "UART5_CTSB"),
  87. PINCTRL_PIN(38, "UART6_RXD"),
  88. PINCTRL_PIN(39, "UART6_TXD"),
  89. PINCTRL_PIN(40, "UART6_RTSB"),
  90. PINCTRL_PIN(41, "UART6_CTSB"),
  91. /* GPP_A */
  92. PINCTRL_PIN(42, "ESPI_IO_0"),
  93. PINCTRL_PIN(43, "ESPI_IO_1"),
  94. PINCTRL_PIN(44, "ESPI_IO_2"),
  95. PINCTRL_PIN(45, "ESPI_IO_3"),
  96. PINCTRL_PIN(46, "ESPI_CSB"),
  97. PINCTRL_PIN(47, "ESPI_CLK"),
  98. PINCTRL_PIN(48, "ESPI_RESETB"),
  99. PINCTRL_PIN(49, "I2S2_SCLK"),
  100. PINCTRL_PIN(50, "I2S2_SFRM"),
  101. PINCTRL_PIN(51, "I2S2_TXD"),
  102. PINCTRL_PIN(52, "I2S2_RXD"),
  103. PINCTRL_PIN(53, "PMC_I2C_SDA"),
  104. PINCTRL_PIN(54, "SATAXPCIE_1"),
  105. PINCTRL_PIN(55, "PMC_I2C_SCL"),
  106. PINCTRL_PIN(56, "USB2_OCB_1"),
  107. PINCTRL_PIN(57, "USB2_OCB_2"),
  108. PINCTRL_PIN(58, "USB2_OCB_3"),
  109. PINCTRL_PIN(59, "DDSP_HPD_C"),
  110. PINCTRL_PIN(60, "DDSP_HPD_B"),
  111. PINCTRL_PIN(61, "DDSP_HPD_1"),
  112. PINCTRL_PIN(62, "DDSP_HPD_2"),
  113. PINCTRL_PIN(63, "GPPC_A_21"),
  114. PINCTRL_PIN(64, "GPPC_A_22"),
  115. PINCTRL_PIN(65, "I2S1_SCLK"),
  116. PINCTRL_PIN(66, "ESPI_CLK_LOOPBK"),
  117. /* GPP_S */
  118. PINCTRL_PIN(67, "SNDW0_CLK"),
  119. PINCTRL_PIN(68, "SNDW0_DATA"),
  120. PINCTRL_PIN(69, "SNDW1_CLK"),
  121. PINCTRL_PIN(70, "SNDW1_DATA"),
  122. PINCTRL_PIN(71, "SNDW2_CLK"),
  123. PINCTRL_PIN(72, "SNDW2_DATA"),
  124. PINCTRL_PIN(73, "SNDW3_CLK"),
  125. PINCTRL_PIN(74, "SNDW3_DATA"),
  126. /* GPP_H */
  127. PINCTRL_PIN(75, "GPPC_H_0"),
  128. PINCTRL_PIN(76, "GPPC_H_1"),
  129. PINCTRL_PIN(77, "GPPC_H_2"),
  130. PINCTRL_PIN(78, "SX_EXIT_HOLDOFFB"),
  131. PINCTRL_PIN(79, "I2C2_SDA"),
  132. PINCTRL_PIN(80, "I2C2_SCL"),
  133. PINCTRL_PIN(81, "I2C3_SDA"),
  134. PINCTRL_PIN(82, "I2C3_SCL"),
  135. PINCTRL_PIN(83, "I2C4_SDA"),
  136. PINCTRL_PIN(84, "I2C4_SCL"),
  137. PINCTRL_PIN(85, "SRCCLKREQB_4"),
  138. PINCTRL_PIN(86, "SRCCLKREQB_5"),
  139. PINCTRL_PIN(87, "M2_SKT2_CFG_0"),
  140. PINCTRL_PIN(88, "M2_SKT2_CFG_1"),
  141. PINCTRL_PIN(89, "M2_SKT2_CFG_2"),
  142. PINCTRL_PIN(90, "M2_SKT2_CFG_3"),
  143. PINCTRL_PIN(91, "DDPB_CTRLCLK"),
  144. PINCTRL_PIN(92, "DDPB_CTRLDATA"),
  145. PINCTRL_PIN(93, "CPU_C10_GATEB"),
  146. PINCTRL_PIN(94, "TIME_SYNC_0"),
  147. PINCTRL_PIN(95, "IMGCLKOUT_1"),
  148. PINCTRL_PIN(96, "IMGCLKOUT_2"),
  149. PINCTRL_PIN(97, "IMGCLKOUT_3"),
  150. PINCTRL_PIN(98, "IMGCLKOUT_4"),
  151. /* GPP_D */
  152. PINCTRL_PIN(99, "ISH_GP_0"),
  153. PINCTRL_PIN(100, "ISH_GP_1"),
  154. PINCTRL_PIN(101, "ISH_GP_2"),
  155. PINCTRL_PIN(102, "ISH_GP_3"),
  156. PINCTRL_PIN(103, "IMGCLKOUT_0"),
  157. PINCTRL_PIN(104, "SRCCLKREQB_0"),
  158. PINCTRL_PIN(105, "SRCCLKREQB_1"),
  159. PINCTRL_PIN(106, "SRCCLKREQB_2"),
  160. PINCTRL_PIN(107, "SRCCLKREQB_3"),
  161. PINCTRL_PIN(108, "ISH_SPI_CSB"),
  162. PINCTRL_PIN(109, "ISH_SPI_CLK"),
  163. PINCTRL_PIN(110, "ISH_SPI_MISO"),
  164. PINCTRL_PIN(111, "ISH_SPI_MOSI"),
  165. PINCTRL_PIN(112, "ISH_UART0_RXD"),
  166. PINCTRL_PIN(113, "ISH_UART0_TXD"),
  167. PINCTRL_PIN(114, "ISH_UART0_RTSB"),
  168. PINCTRL_PIN(115, "ISH_UART0_CTSB"),
  169. PINCTRL_PIN(116, "ISH_GP_4"),
  170. PINCTRL_PIN(117, "ISH_GP_5"),
  171. PINCTRL_PIN(118, "I2S_MCLK1_OUT"),
  172. PINCTRL_PIN(119, "GSPI2_CLK_LOOPBK"),
  173. /* GPP_U */
  174. PINCTRL_PIN(120, "UART3_RXD"),
  175. PINCTRL_PIN(121, "UART3_TXD"),
  176. PINCTRL_PIN(122, "UART3_RTSB"),
  177. PINCTRL_PIN(123, "UART3_CTSB"),
  178. PINCTRL_PIN(124, "GSPI3_CS0B"),
  179. PINCTRL_PIN(125, "GSPI3_CLK"),
  180. PINCTRL_PIN(126, "GSPI3_MISO"),
  181. PINCTRL_PIN(127, "GSPI3_MOSI"),
  182. PINCTRL_PIN(128, "GSPI4_CS0B"),
  183. PINCTRL_PIN(129, "GSPI4_CLK"),
  184. PINCTRL_PIN(130, "GSPI4_MISO"),
  185. PINCTRL_PIN(131, "GSPI4_MOSI"),
  186. PINCTRL_PIN(132, "GSPI5_CS0B"),
  187. PINCTRL_PIN(133, "GSPI5_CLK"),
  188. PINCTRL_PIN(134, "GSPI5_MISO"),
  189. PINCTRL_PIN(135, "GSPI5_MOSI"),
  190. PINCTRL_PIN(136, "GSPI6_CS0B"),
  191. PINCTRL_PIN(137, "GSPI6_CLK"),
  192. PINCTRL_PIN(138, "GSPI6_MISO"),
  193. PINCTRL_PIN(139, "GSPI6_MOSI"),
  194. PINCTRL_PIN(140, "GSPI3_CLK_LOOPBK"),
  195. PINCTRL_PIN(141, "GSPI4_CLK_LOOPBK"),
  196. PINCTRL_PIN(142, "GSPI5_CLK_LOOPBK"),
  197. PINCTRL_PIN(143, "GSPI6_CLK_LOOPBK"),
  198. /* vGPIO */
  199. PINCTRL_PIN(144, "CNV_BTEN"),
  200. PINCTRL_PIN(145, "CNV_BT_HOST_WAKEB"),
  201. PINCTRL_PIN(146, "CNV_BT_IF_SELECT"),
  202. PINCTRL_PIN(147, "vCNV_BT_UART_TXD"),
  203. PINCTRL_PIN(148, "vCNV_BT_UART_RXD"),
  204. PINCTRL_PIN(149, "vCNV_BT_UART_CTS_B"),
  205. PINCTRL_PIN(150, "vCNV_BT_UART_RTS_B"),
  206. PINCTRL_PIN(151, "vCNV_MFUART1_TXD"),
  207. PINCTRL_PIN(152, "vCNV_MFUART1_RXD"),
  208. PINCTRL_PIN(153, "vCNV_MFUART1_CTS_B"),
  209. PINCTRL_PIN(154, "vCNV_MFUART1_RTS_B"),
  210. PINCTRL_PIN(155, "vUART0_TXD"),
  211. PINCTRL_PIN(156, "vUART0_RXD"),
  212. PINCTRL_PIN(157, "vUART0_CTS_B"),
  213. PINCTRL_PIN(158, "vUART0_RTS_B"),
  214. PINCTRL_PIN(159, "vISH_UART0_TXD"),
  215. PINCTRL_PIN(160, "vISH_UART0_RXD"),
  216. PINCTRL_PIN(161, "vISH_UART0_CTS_B"),
  217. PINCTRL_PIN(162, "vISH_UART0_RTS_B"),
  218. PINCTRL_PIN(163, "vCNV_BT_I2S_BCLK"),
  219. PINCTRL_PIN(164, "vCNV_BT_I2S_WS_SYNC"),
  220. PINCTRL_PIN(165, "vCNV_BT_I2S_SDO"),
  221. PINCTRL_PIN(166, "vCNV_BT_I2S_SDI"),
  222. PINCTRL_PIN(167, "vI2S2_SCLK"),
  223. PINCTRL_PIN(168, "vI2S2_SFRM"),
  224. PINCTRL_PIN(169, "vI2S2_TXD"),
  225. PINCTRL_PIN(170, "vI2S2_RXD"),
  226. /* GPP_C */
  227. PINCTRL_PIN(171, "SMBCLK"),
  228. PINCTRL_PIN(172, "SMBDATA"),
  229. PINCTRL_PIN(173, "SMBALERTB"),
  230. PINCTRL_PIN(174, "SML0CLK"),
  231. PINCTRL_PIN(175, "SML0DATA"),
  232. PINCTRL_PIN(176, "SML0ALERTB"),
  233. PINCTRL_PIN(177, "SML1CLK"),
  234. PINCTRL_PIN(178, "SML1DATA"),
  235. PINCTRL_PIN(179, "UART0_RXD"),
  236. PINCTRL_PIN(180, "UART0_TXD"),
  237. PINCTRL_PIN(181, "UART0_RTSB"),
  238. PINCTRL_PIN(182, "UART0_CTSB"),
  239. PINCTRL_PIN(183, "UART1_RXD"),
  240. PINCTRL_PIN(184, "UART1_TXD"),
  241. PINCTRL_PIN(185, "UART1_RTSB"),
  242. PINCTRL_PIN(186, "UART1_CTSB"),
  243. PINCTRL_PIN(187, "I2C0_SDA"),
  244. PINCTRL_PIN(188, "I2C0_SCL"),
  245. PINCTRL_PIN(189, "I2C1_SDA"),
  246. PINCTRL_PIN(190, "I2C1_SCL"),
  247. PINCTRL_PIN(191, "UART2_RXD"),
  248. PINCTRL_PIN(192, "UART2_TXD"),
  249. PINCTRL_PIN(193, "UART2_RTSB"),
  250. PINCTRL_PIN(194, "UART2_CTSB"),
  251. /* GPP_F */
  252. PINCTRL_PIN(195, "CNV_BRI_DT"),
  253. PINCTRL_PIN(196, "CNV_BRI_RSP"),
  254. PINCTRL_PIN(197, "CNV_RGI_DT"),
  255. PINCTRL_PIN(198, "CNV_RGI_RSP"),
  256. PINCTRL_PIN(199, "CNV_RF_RESET_B"),
  257. PINCTRL_PIN(200, "GPPC_F_5"),
  258. PINCTRL_PIN(201, "CNV_PA_BLANKING"),
  259. PINCTRL_PIN(202, "GPPC_F_7"),
  260. PINCTRL_PIN(203, "I2S_MCLK2_INOUT"),
  261. PINCTRL_PIN(204, "BOOTMPC"),
  262. PINCTRL_PIN(205, "GPPC_F_10"),
  263. PINCTRL_PIN(206, "GPPC_F_11"),
  264. PINCTRL_PIN(207, "GSXDOUT"),
  265. PINCTRL_PIN(208, "GSXSLOAD"),
  266. PINCTRL_PIN(209, "GSXDIN"),
  267. PINCTRL_PIN(210, "GSXSRESETB"),
  268. PINCTRL_PIN(211, "GSXCLK"),
  269. PINCTRL_PIN(212, "GMII_MDC"),
  270. PINCTRL_PIN(213, "GMII_MDIO"),
  271. PINCTRL_PIN(214, "SRCCLKREQB_6"),
  272. PINCTRL_PIN(215, "EXT_PWR_GATEB"),
  273. PINCTRL_PIN(216, "EXT_PWR_GATE2B"),
  274. PINCTRL_PIN(217, "VNN_CTRL"),
  275. PINCTRL_PIN(218, "V1P05_CTRL"),
  276. PINCTRL_PIN(219, "GPPF_CLK_LOOPBACK"),
  277. /* HVCMOS */
  278. PINCTRL_PIN(220, "L_BKLTEN"),
  279. PINCTRL_PIN(221, "L_BKLTCTL"),
  280. PINCTRL_PIN(222, "L_VDDEN"),
  281. PINCTRL_PIN(223, "SYS_PWROK"),
  282. PINCTRL_PIN(224, "SYS_RESETB"),
  283. PINCTRL_PIN(225, "MLK_RSTB"),
  284. /* GPP_E */
  285. PINCTRL_PIN(226, "SATAXPCIE_0"),
  286. PINCTRL_PIN(227, "SPI1_IO_2"),
  287. PINCTRL_PIN(228, "SPI1_IO_3"),
  288. PINCTRL_PIN(229, "CPU_GP_0"),
  289. PINCTRL_PIN(230, "SATA_DEVSLP_0"),
  290. PINCTRL_PIN(231, "SATA_DEVSLP_1"),
  291. PINCTRL_PIN(232, "GPPC_E_6"),
  292. PINCTRL_PIN(233, "CPU_GP_1"),
  293. PINCTRL_PIN(234, "SPI1_CS1B"),
  294. PINCTRL_PIN(235, "USB2_OCB_0"),
  295. PINCTRL_PIN(236, "SPI1_CSB"),
  296. PINCTRL_PIN(237, "SPI1_CLK"),
  297. PINCTRL_PIN(238, "SPI1_MISO_IO_1"),
  298. PINCTRL_PIN(239, "SPI1_MOSI_IO_0"),
  299. PINCTRL_PIN(240, "DDSP_HPD_A"),
  300. PINCTRL_PIN(241, "ISH_GP_6"),
  301. PINCTRL_PIN(242, "ISH_GP_7"),
  302. PINCTRL_PIN(243, "GPPC_E_17"),
  303. PINCTRL_PIN(244, "DDP1_CTRLCLK"),
  304. PINCTRL_PIN(245, "DDP1_CTRLDATA"),
  305. PINCTRL_PIN(246, "DDP2_CTRLCLK"),
  306. PINCTRL_PIN(247, "DDP2_CTRLDATA"),
  307. PINCTRL_PIN(248, "DDPA_CTRLCLK"),
  308. PINCTRL_PIN(249, "DDPA_CTRLDATA"),
  309. PINCTRL_PIN(250, "SPI1_CLK_LOOPBK"),
  310. /* JTAG */
  311. PINCTRL_PIN(251, "JTAG_TDO"),
  312. PINCTRL_PIN(252, "JTAGX"),
  313. PINCTRL_PIN(253, "PRDYB"),
  314. PINCTRL_PIN(254, "PREQB"),
  315. PINCTRL_PIN(255, "CPU_TRSTB"),
  316. PINCTRL_PIN(256, "JTAG_TDI"),
  317. PINCTRL_PIN(257, "JTAG_TMS"),
  318. PINCTRL_PIN(258, "JTAG_TCK"),
  319. PINCTRL_PIN(259, "DBG_PMODE"),
  320. /* GPP_R */
  321. PINCTRL_PIN(260, "HDA_BCLK"),
  322. PINCTRL_PIN(261, "HDA_SYNC"),
  323. PINCTRL_PIN(262, "HDA_SDO"),
  324. PINCTRL_PIN(263, "HDA_SDI_0"),
  325. PINCTRL_PIN(264, "HDA_RSTB"),
  326. PINCTRL_PIN(265, "HDA_SDI_1"),
  327. PINCTRL_PIN(266, "GPP_R_6"),
  328. PINCTRL_PIN(267, "GPP_R_7"),
  329. /* SPI */
  330. PINCTRL_PIN(268, "SPI0_IO_2"),
  331. PINCTRL_PIN(269, "SPI0_IO_3"),
  332. PINCTRL_PIN(270, "SPI0_MOSI_IO_0"),
  333. PINCTRL_PIN(271, "SPI0_MISO_IO_1"),
  334. PINCTRL_PIN(272, "SPI0_TPM_CSB"),
  335. PINCTRL_PIN(273, "SPI0_FLASH_0_CSB"),
  336. PINCTRL_PIN(274, "SPI0_FLASH_1_CSB"),
  337. PINCTRL_PIN(275, "SPI0_CLK"),
  338. PINCTRL_PIN(276, "SPI0_CLK_LOOPBK"),
  339. };
  340. static const struct intel_padgroup tgllp_community0_gpps[] = {
  341. TGL_GPP(0, 0, 25, 0), /* GPP_B */
  342. TGL_GPP(1, 26, 41, 32), /* GPP_T */
  343. TGL_GPP(2, 42, 66, 64), /* GPP_A */
  344. };
  345. static const struct intel_padgroup tgllp_community1_gpps[] = {
  346. TGL_GPP(0, 67, 74, 96), /* GPP_S */
  347. TGL_GPP(1, 75, 98, 128), /* GPP_H */
  348. TGL_GPP(2, 99, 119, 160), /* GPP_D */
  349. TGL_GPP(3, 120, 143, 192), /* GPP_U */
  350. TGL_GPP(4, 144, 170, 224), /* vGPIO */
  351. };
  352. static const struct intel_padgroup tgllp_community4_gpps[] = {
  353. TGL_GPP(0, 171, 194, 256), /* GPP_C */
  354. TGL_GPP(1, 195, 219, 288), /* GPP_F */
  355. TGL_GPP(2, 220, 225, INTEL_GPIO_BASE_NOMAP), /* HVCMOS */
  356. TGL_GPP(3, 226, 250, 320), /* GPP_E */
  357. TGL_GPP(4, 251, 259, INTEL_GPIO_BASE_NOMAP), /* JTAG */
  358. };
  359. static const struct intel_padgroup tgllp_community5_gpps[] = {
  360. TGL_GPP(0, 260, 267, 352), /* GPP_R */
  361. TGL_GPP(1, 268, 276, INTEL_GPIO_BASE_NOMAP), /* SPI */
  362. };
  363. static const struct intel_community tgllp_communities[] = {
  364. TGL_LP_COMMUNITY(0, 0, 66, tgllp_community0_gpps),
  365. TGL_LP_COMMUNITY(1, 67, 170, tgllp_community1_gpps),
  366. TGL_LP_COMMUNITY(2, 171, 259, tgllp_community4_gpps),
  367. TGL_LP_COMMUNITY(3, 260, 276, tgllp_community5_gpps),
  368. };
  369. static const struct intel_pinctrl_soc_data tgllp_soc_data = {
  370. .pins = tgllp_pins,
  371. .npins = ARRAY_SIZE(tgllp_pins),
  372. .communities = tgllp_communities,
  373. .ncommunities = ARRAY_SIZE(tgllp_communities),
  374. };
  375. /* Tiger Lake-H */
  376. static const struct pinctrl_pin_desc tglh_pins[] = {
  377. /* GPP_A */
  378. PINCTRL_PIN(0, "SPI0_IO_2"),
  379. PINCTRL_PIN(1, "SPI0_IO_3"),
  380. PINCTRL_PIN(2, "SPI0_MOSI_IO_0"),
  381. PINCTRL_PIN(3, "SPI0_MISO_IO_1"),
  382. PINCTRL_PIN(4, "SPI0_TPM_CSB"),
  383. PINCTRL_PIN(5, "SPI0_FLASH_0_CSB"),
  384. PINCTRL_PIN(6, "SPI0_FLASH_1_CSB"),
  385. PINCTRL_PIN(7, "SPI0_CLK"),
  386. PINCTRL_PIN(8, "ESPI_IO_0"),
  387. PINCTRL_PIN(9, "ESPI_IO_1"),
  388. PINCTRL_PIN(10, "ESPI_IO_2"),
  389. PINCTRL_PIN(11, "ESPI_IO_3"),
  390. PINCTRL_PIN(12, "ESPI_CS0B"),
  391. PINCTRL_PIN(13, "ESPI_CLK"),
  392. PINCTRL_PIN(14, "ESPI_RESETB"),
  393. PINCTRL_PIN(15, "ESPI_CS1B"),
  394. PINCTRL_PIN(16, "ESPI_CS2B"),
  395. PINCTRL_PIN(17, "ESPI_CS3B"),
  396. PINCTRL_PIN(18, "ESPI_ALERT0B"),
  397. PINCTRL_PIN(19, "ESPI_ALERT1B"),
  398. PINCTRL_PIN(20, "ESPI_ALERT2B"),
  399. PINCTRL_PIN(21, "ESPI_ALERT3B"),
  400. PINCTRL_PIN(22, "GPPC_A_14"),
  401. PINCTRL_PIN(23, "SPI0_CLK_LOOPBK"),
  402. PINCTRL_PIN(24, "ESPI_CLK_LOOPBK"),
  403. /* GPP_R */
  404. PINCTRL_PIN(25, "HDA_BCLK"),
  405. PINCTRL_PIN(26, "HDA_SYNC"),
  406. PINCTRL_PIN(27, "HDA_SDO"),
  407. PINCTRL_PIN(28, "HDA_SDI_0"),
  408. PINCTRL_PIN(29, "HDA_RSTB"),
  409. PINCTRL_PIN(30, "HDA_SDI_1"),
  410. PINCTRL_PIN(31, "GPP_R_6"),
  411. PINCTRL_PIN(32, "GPP_R_7"),
  412. PINCTRL_PIN(33, "GPP_R_8"),
  413. PINCTRL_PIN(34, "PCIE_LNK_DOWN"),
  414. PINCTRL_PIN(35, "ISH_UART0_RTSB"),
  415. PINCTRL_PIN(36, "SX_EXIT_HOLDOFFB"),
  416. PINCTRL_PIN(37, "CLKOUT_48"),
  417. PINCTRL_PIN(38, "ISH_GP_7"),
  418. PINCTRL_PIN(39, "ISH_GP_0"),
  419. PINCTRL_PIN(40, "ISH_GP_1"),
  420. PINCTRL_PIN(41, "ISH_GP_2"),
  421. PINCTRL_PIN(42, "ISH_GP_3"),
  422. PINCTRL_PIN(43, "ISH_GP_4"),
  423. PINCTRL_PIN(44, "ISH_GP_5"),
  424. /* GPP_B */
  425. PINCTRL_PIN(45, "GSPI0_CS1B"),
  426. PINCTRL_PIN(46, "GSPI1_CS1B"),
  427. PINCTRL_PIN(47, "VRALERTB"),
  428. PINCTRL_PIN(48, "CPU_GP_2"),
  429. PINCTRL_PIN(49, "CPU_GP_3"),
  430. PINCTRL_PIN(50, "SRCCLKREQB_0"),
  431. PINCTRL_PIN(51, "SRCCLKREQB_1"),
  432. PINCTRL_PIN(52, "SRCCLKREQB_2"),
  433. PINCTRL_PIN(53, "SRCCLKREQB_3"),
  434. PINCTRL_PIN(54, "SRCCLKREQB_4"),
  435. PINCTRL_PIN(55, "SRCCLKREQB_5"),
  436. PINCTRL_PIN(56, "I2S_MCLK"),
  437. PINCTRL_PIN(57, "SLP_S0B"),
  438. PINCTRL_PIN(58, "PLTRSTB"),
  439. PINCTRL_PIN(59, "SPKR"),
  440. PINCTRL_PIN(60, "GSPI0_CS0B"),
  441. PINCTRL_PIN(61, "GSPI0_CLK"),
  442. PINCTRL_PIN(62, "GSPI0_MISO"),
  443. PINCTRL_PIN(63, "GSPI0_MOSI"),
  444. PINCTRL_PIN(64, "GSPI1_CS0B"),
  445. PINCTRL_PIN(65, "GSPI1_CLK"),
  446. PINCTRL_PIN(66, "GSPI1_MISO"),
  447. PINCTRL_PIN(67, "GSPI1_MOSI"),
  448. PINCTRL_PIN(68, "SML1ALERTB"),
  449. PINCTRL_PIN(69, "GSPI0_CLK_LOOPBK"),
  450. PINCTRL_PIN(70, "GSPI1_CLK_LOOPBK"),
  451. /* vGPIO_0 */
  452. PINCTRL_PIN(71, "ESPI_USB_OCB_0"),
  453. PINCTRL_PIN(72, "ESPI_USB_OCB_1"),
  454. PINCTRL_PIN(73, "ESPI_USB_OCB_2"),
  455. PINCTRL_PIN(74, "ESPI_USB_OCB_3"),
  456. PINCTRL_PIN(75, "USB_CPU_OCB_0"),
  457. PINCTRL_PIN(76, "USB_CPU_OCB_1"),
  458. PINCTRL_PIN(77, "USB_CPU_OCB_2"),
  459. PINCTRL_PIN(78, "USB_CPU_OCB_3"),
  460. /* GPP_D */
  461. PINCTRL_PIN(79, "SPI1_CSB"),
  462. PINCTRL_PIN(80, "SPI1_CLK"),
  463. PINCTRL_PIN(81, "SPI1_MISO_IO_1"),
  464. PINCTRL_PIN(82, "SPI1_MOSI_IO_0"),
  465. PINCTRL_PIN(83, "SML1CLK"),
  466. PINCTRL_PIN(84, "I2S2_SFRM"),
  467. PINCTRL_PIN(85, "I2S2_TXD"),
  468. PINCTRL_PIN(86, "I2S2_RXD"),
  469. PINCTRL_PIN(87, "I2S2_SCLK"),
  470. PINCTRL_PIN(88, "SML0CLK"),
  471. PINCTRL_PIN(89, "SML0DATA"),
  472. PINCTRL_PIN(90, "GPP_D_11"),
  473. PINCTRL_PIN(91, "ISH_UART0_CTSB"),
  474. PINCTRL_PIN(92, "SPI1_IO_2"),
  475. PINCTRL_PIN(93, "SPI1_IO_3"),
  476. PINCTRL_PIN(94, "SML1DATA"),
  477. PINCTRL_PIN(95, "GSPI3_CS0B"),
  478. PINCTRL_PIN(96, "GSPI3_CLK"),
  479. PINCTRL_PIN(97, "GSPI3_MISO"),
  480. PINCTRL_PIN(98, "GSPI3_MOSI"),
  481. PINCTRL_PIN(99, "UART3_RXD"),
  482. PINCTRL_PIN(100, "UART3_TXD"),
  483. PINCTRL_PIN(101, "UART3_RTSB"),
  484. PINCTRL_PIN(102, "UART3_CTSB"),
  485. PINCTRL_PIN(103, "SPI1_CLK_LOOPBK"),
  486. PINCTRL_PIN(104, "GSPI3_CLK_LOOPBK"),
  487. /* GPP_C */
  488. PINCTRL_PIN(105, "SMBCLK"),
  489. PINCTRL_PIN(106, "SMBDATA"),
  490. PINCTRL_PIN(107, "SMBALERTB"),
  491. PINCTRL_PIN(108, "ISH_UART0_RXD"),
  492. PINCTRL_PIN(109, "ISH_UART0_TXD"),
  493. PINCTRL_PIN(110, "SML0ALERTB"),
  494. PINCTRL_PIN(111, "ISH_I2C2_SDA"),
  495. PINCTRL_PIN(112, "ISH_I2C2_SCL"),
  496. PINCTRL_PIN(113, "UART0_RXD"),
  497. PINCTRL_PIN(114, "UART0_TXD"),
  498. PINCTRL_PIN(115, "UART0_RTSB"),
  499. PINCTRL_PIN(116, "UART0_CTSB"),
  500. PINCTRL_PIN(117, "UART1_RXD"),
  501. PINCTRL_PIN(118, "UART1_TXD"),
  502. PINCTRL_PIN(119, "UART1_RTSB"),
  503. PINCTRL_PIN(120, "UART1_CTSB"),
  504. PINCTRL_PIN(121, "I2C0_SDA"),
  505. PINCTRL_PIN(122, "I2C0_SCL"),
  506. PINCTRL_PIN(123, "I2C1_SDA"),
  507. PINCTRL_PIN(124, "I2C1_SCL"),
  508. PINCTRL_PIN(125, "UART2_RXD"),
  509. PINCTRL_PIN(126, "UART2_TXD"),
  510. PINCTRL_PIN(127, "UART2_RTSB"),
  511. PINCTRL_PIN(128, "UART2_CTSB"),
  512. /* GPP_S */
  513. PINCTRL_PIN(129, "SNDW1_CLK"),
  514. PINCTRL_PIN(130, "SNDW1_DATA"),
  515. PINCTRL_PIN(131, "SNDW2_CLK"),
  516. PINCTRL_PIN(132, "SNDW2_DATA"),
  517. PINCTRL_PIN(133, "SNDW3_CLK"),
  518. PINCTRL_PIN(134, "SNDW3_DATA"),
  519. PINCTRL_PIN(135, "SNDW4_CLK"),
  520. PINCTRL_PIN(136, "SNDW4_DATA"),
  521. /* GPP_G */
  522. PINCTRL_PIN(137, "DDPA_CTRLCLK"),
  523. PINCTRL_PIN(138, "DDPA_CTRLDATA"),
  524. PINCTRL_PIN(139, "DNX_FORCE_RELOAD"),
  525. PINCTRL_PIN(140, "GMII_MDC_0"),
  526. PINCTRL_PIN(141, "GMII_MDIO_0"),
  527. PINCTRL_PIN(142, "SLP_DRAMB"),
  528. PINCTRL_PIN(143, "GPPC_G_6"),
  529. PINCTRL_PIN(144, "GPPC_G_7"),
  530. PINCTRL_PIN(145, "ISH_SPI_CSB"),
  531. PINCTRL_PIN(146, "ISH_SPI_CLK"),
  532. PINCTRL_PIN(147, "ISH_SPI_MISO"),
  533. PINCTRL_PIN(148, "ISH_SPI_MOSI"),
  534. PINCTRL_PIN(149, "DDP1_CTRLCLK"),
  535. PINCTRL_PIN(150, "DDP1_CTRLDATA"),
  536. PINCTRL_PIN(151, "DDP2_CTRLCLK"),
  537. PINCTRL_PIN(152, "DDP2_CTRLDATA"),
  538. PINCTRL_PIN(153, "GSPI2_CLK_LOOPBK"),
  539. /* vGPIO */
  540. PINCTRL_PIN(154, "CNV_BTEN"),
  541. PINCTRL_PIN(155, "CNV_BT_HOST_WAKEB"),
  542. PINCTRL_PIN(156, "CNV_BT_IF_SELECT"),
  543. PINCTRL_PIN(157, "vCNV_BT_UART_TXD"),
  544. PINCTRL_PIN(158, "vCNV_BT_UART_RXD"),
  545. PINCTRL_PIN(159, "vCNV_BT_UART_CTS_B"),
  546. PINCTRL_PIN(160, "vCNV_BT_UART_RTS_B"),
  547. PINCTRL_PIN(161, "vCNV_MFUART1_TXD"),
  548. PINCTRL_PIN(162, "vCNV_MFUART1_RXD"),
  549. PINCTRL_PIN(163, "vCNV_MFUART1_CTS_B"),
  550. PINCTRL_PIN(164, "vCNV_MFUART1_RTS_B"),
  551. PINCTRL_PIN(165, "vUART0_TXD"),
  552. PINCTRL_PIN(166, "vUART0_RXD"),
  553. PINCTRL_PIN(167, "vUART0_CTS_B"),
  554. PINCTRL_PIN(168, "vUART0_RTS_B"),
  555. PINCTRL_PIN(169, "vISH_UART0_TXD"),
  556. PINCTRL_PIN(170, "vISH_UART0_RXD"),
  557. PINCTRL_PIN(171, "vISH_UART0_CTS_B"),
  558. PINCTRL_PIN(172, "vISH_UART0_RTS_B"),
  559. PINCTRL_PIN(173, "vCNV_BT_I2S_BCLK"),
  560. PINCTRL_PIN(174, "vCNV_BT_I2S_WS_SYNC"),
  561. PINCTRL_PIN(175, "vCNV_BT_I2S_SDO"),
  562. PINCTRL_PIN(176, "vCNV_BT_I2S_SDI"),
  563. PINCTRL_PIN(177, "vI2S2_SCLK"),
  564. PINCTRL_PIN(178, "vI2S2_SFRM"),
  565. PINCTRL_PIN(179, "vI2S2_TXD"),
  566. PINCTRL_PIN(180, "vI2S2_RXD"),
  567. /* GPP_E */
  568. PINCTRL_PIN(181, "SATAXPCIE_0"),
  569. PINCTRL_PIN(182, "SATAXPCIE_1"),
  570. PINCTRL_PIN(183, "SATAXPCIE_2"),
  571. PINCTRL_PIN(184, "CPU_GP_0"),
  572. PINCTRL_PIN(185, "SATA_DEVSLP_0"),
  573. PINCTRL_PIN(186, "SATA_DEVSLP_1"),
  574. PINCTRL_PIN(187, "SATA_DEVSLP_2"),
  575. PINCTRL_PIN(188, "CPU_GP_1"),
  576. PINCTRL_PIN(189, "SATA_LEDB"),
  577. PINCTRL_PIN(190, "USB2_OCB_0"),
  578. PINCTRL_PIN(191, "USB2_OCB_1"),
  579. PINCTRL_PIN(192, "USB2_OCB_2"),
  580. PINCTRL_PIN(193, "USB2_OCB_3"),
  581. /* GPP_F */
  582. PINCTRL_PIN(194, "SATAXPCIE_3"),
  583. PINCTRL_PIN(195, "SATAXPCIE_4"),
  584. PINCTRL_PIN(196, "SATAXPCIE_5"),
  585. PINCTRL_PIN(197, "SATAXPCIE_6"),
  586. PINCTRL_PIN(198, "SATAXPCIE_7"),
  587. PINCTRL_PIN(199, "SATA_DEVSLP_3"),
  588. PINCTRL_PIN(200, "SATA_DEVSLP_4"),
  589. PINCTRL_PIN(201, "SATA_DEVSLP_5"),
  590. PINCTRL_PIN(202, "SATA_DEVSLP_6"),
  591. PINCTRL_PIN(203, "SATA_DEVSLP_7"),
  592. PINCTRL_PIN(204, "SATA_SCLOCK"),
  593. PINCTRL_PIN(205, "SATA_SLOAD"),
  594. PINCTRL_PIN(206, "SATA_SDATAOUT1"),
  595. PINCTRL_PIN(207, "SATA_SDATAOUT0"),
  596. PINCTRL_PIN(208, "PS_ONB"),
  597. PINCTRL_PIN(209, "M2_SKT2_CFG_0"),
  598. PINCTRL_PIN(210, "M2_SKT2_CFG_1"),
  599. PINCTRL_PIN(211, "M2_SKT2_CFG_2"),
  600. PINCTRL_PIN(212, "M2_SKT2_CFG_3"),
  601. PINCTRL_PIN(213, "L_VDDEN"),
  602. PINCTRL_PIN(214, "L_BKLTEN"),
  603. PINCTRL_PIN(215, "L_BKLTCTL"),
  604. PINCTRL_PIN(216, "VNN_CTRL"),
  605. PINCTRL_PIN(217, "GPP_F_23"),
  606. /* GPP_H */
  607. PINCTRL_PIN(218, "SRCCLKREQB_6"),
  608. PINCTRL_PIN(219, "SRCCLKREQB_7"),
  609. PINCTRL_PIN(220, "SRCCLKREQB_8"),
  610. PINCTRL_PIN(221, "SRCCLKREQB_9"),
  611. PINCTRL_PIN(222, "SRCCLKREQB_10"),
  612. PINCTRL_PIN(223, "SRCCLKREQB_11"),
  613. PINCTRL_PIN(224, "SRCCLKREQB_12"),
  614. PINCTRL_PIN(225, "SRCCLKREQB_13"),
  615. PINCTRL_PIN(226, "SRCCLKREQB_14"),
  616. PINCTRL_PIN(227, "SRCCLKREQB_15"),
  617. PINCTRL_PIN(228, "SML2CLK"),
  618. PINCTRL_PIN(229, "SML2DATA"),
  619. PINCTRL_PIN(230, "SML2ALERTB"),
  620. PINCTRL_PIN(231, "SML3CLK"),
  621. PINCTRL_PIN(232, "SML3DATA"),
  622. PINCTRL_PIN(233, "SML3ALERTB"),
  623. PINCTRL_PIN(234, "SML4CLK"),
  624. PINCTRL_PIN(235, "SML4DATA"),
  625. PINCTRL_PIN(236, "SML4ALERTB"),
  626. PINCTRL_PIN(237, "ISH_I2C0_SDA"),
  627. PINCTRL_PIN(238, "ISH_I2C0_SCL"),
  628. PINCTRL_PIN(239, "ISH_I2C1_SDA"),
  629. PINCTRL_PIN(240, "ISH_I2C1_SCL"),
  630. PINCTRL_PIN(241, "TIME_SYNC_0"),
  631. /* GPP_J */
  632. PINCTRL_PIN(242, "CNV_PA_BLANKING"),
  633. PINCTRL_PIN(243, "CPU_C10_GATEB"),
  634. PINCTRL_PIN(244, "CNV_BRI_DT"),
  635. PINCTRL_PIN(245, "CNV_BRI_RSP"),
  636. PINCTRL_PIN(246, "CNV_RGI_DT"),
  637. PINCTRL_PIN(247, "CNV_RGI_RSP"),
  638. PINCTRL_PIN(248, "CNV_MFUART2_RXD"),
  639. PINCTRL_PIN(249, "CNV_MFUART2_TXD"),
  640. PINCTRL_PIN(250, "GPP_J_8"),
  641. PINCTRL_PIN(251, "GPP_J_9"),
  642. /* GPP_K */
  643. PINCTRL_PIN(252, "GSXDOUT"),
  644. PINCTRL_PIN(253, "GSXSLOAD"),
  645. PINCTRL_PIN(254, "GSXDIN"),
  646. PINCTRL_PIN(255, "GSXSRESETB"),
  647. PINCTRL_PIN(256, "GSXCLK"),
  648. PINCTRL_PIN(257, "ADR_COMPLETE"),
  649. PINCTRL_PIN(258, "DDSP_HPD_A"),
  650. PINCTRL_PIN(259, "DDSP_HPD_B"),
  651. PINCTRL_PIN(260, "CORE_VID_0"),
  652. PINCTRL_PIN(261, "CORE_VID_1"),
  653. PINCTRL_PIN(262, "DDSP_HPD_C"),
  654. PINCTRL_PIN(263, "GPP_K_11"),
  655. PINCTRL_PIN(264, "SYS_PWROK"),
  656. PINCTRL_PIN(265, "SYS_RESETB"),
  657. PINCTRL_PIN(266, "MLK_RSTB"),
  658. /* GPP_I */
  659. PINCTRL_PIN(267, "PMCALERTB"),
  660. PINCTRL_PIN(268, "DDSP_HPD_1"),
  661. PINCTRL_PIN(269, "DDSP_HPD_2"),
  662. PINCTRL_PIN(270, "DDSP_HPD_3"),
  663. PINCTRL_PIN(271, "DDSP_HPD_4"),
  664. PINCTRL_PIN(272, "DDPB_CTRLCLK"),
  665. PINCTRL_PIN(273, "DDPB_CTRLDATA"),
  666. PINCTRL_PIN(274, "DDPC_CTRLCLK"),
  667. PINCTRL_PIN(275, "DDPC_CTRLDATA"),
  668. PINCTRL_PIN(276, "FUSA_DIAGTEST_EN"),
  669. PINCTRL_PIN(277, "FUSA_DIAGTEST_MODE"),
  670. PINCTRL_PIN(278, "USB2_OCB_4"),
  671. PINCTRL_PIN(279, "USB2_OCB_5"),
  672. PINCTRL_PIN(280, "USB2_OCB_6"),
  673. PINCTRL_PIN(281, "USB2_OCB_7"),
  674. /* JTAG */
  675. PINCTRL_PIN(282, "JTAG_TDO"),
  676. PINCTRL_PIN(283, "JTAGX"),
  677. PINCTRL_PIN(284, "PRDYB"),
  678. PINCTRL_PIN(285, "PREQB"),
  679. PINCTRL_PIN(286, "JTAG_TDI"),
  680. PINCTRL_PIN(287, "JTAG_TMS"),
  681. PINCTRL_PIN(288, "JTAG_TCK"),
  682. PINCTRL_PIN(289, "DBG_PMODE"),
  683. PINCTRL_PIN(290, "CPU_TRSTB"),
  684. };
  685. static const struct intel_padgroup tglh_community0_gpps[] = {
  686. TGL_GPP(0, 0, 24, 0), /* GPP_A */
  687. TGL_GPP(1, 25, 44, 32), /* GPP_R */
  688. TGL_GPP(2, 45, 70, 64), /* GPP_B */
  689. TGL_GPP(3, 71, 78, 96), /* vGPIO_0 */
  690. };
  691. static const struct intel_padgroup tglh_community1_gpps[] = {
  692. TGL_GPP(0, 79, 104, 128), /* GPP_D */
  693. TGL_GPP(1, 105, 128, 160), /* GPP_C */
  694. TGL_GPP(2, 129, 136, 192), /* GPP_S */
  695. TGL_GPP(3, 137, 153, 224), /* GPP_G */
  696. TGL_GPP(4, 154, 180, 256), /* vGPIO */
  697. };
  698. static const struct intel_padgroup tglh_community3_gpps[] = {
  699. TGL_GPP(0, 181, 193, 288), /* GPP_E */
  700. TGL_GPP(1, 194, 217, 320), /* GPP_F */
  701. };
  702. static const struct intel_padgroup tglh_community4_gpps[] = {
  703. TGL_GPP(0, 218, 241, 352), /* GPP_H */
  704. TGL_GPP(1, 242, 251, 384), /* GPP_J */
  705. TGL_GPP(2, 252, 266, 416), /* GPP_K */
  706. };
  707. static const struct intel_padgroup tglh_community5_gpps[] = {
  708. TGL_GPP(0, 267, 281, 448), /* GPP_I */
  709. TGL_GPP(1, 282, 290, INTEL_GPIO_BASE_NOMAP), /* JTAG */
  710. };
  711. static const struct intel_community tglh_communities[] = {
  712. TGL_H_COMMUNITY(0, 0, 78, tglh_community0_gpps),
  713. TGL_H_COMMUNITY(1, 79, 180, tglh_community1_gpps),
  714. TGL_H_COMMUNITY(2, 181, 217, tglh_community3_gpps),
  715. TGL_H_COMMUNITY(3, 218, 266, tglh_community4_gpps),
  716. TGL_H_COMMUNITY(4, 267, 290, tglh_community5_gpps),
  717. };
  718. static const struct intel_pinctrl_soc_data tglh_soc_data = {
  719. .pins = tglh_pins,
  720. .npins = ARRAY_SIZE(tglh_pins),
  721. .communities = tglh_communities,
  722. .ncommunities = ARRAY_SIZE(tglh_communities),
  723. };
  724. static const struct acpi_device_id tgl_pinctrl_acpi_match[] = {
  725. { "INT34C5", (kernel_ulong_t)&tgllp_soc_data },
  726. { "INT34C6", (kernel_ulong_t)&tglh_soc_data },
  727. { "INTC1055", (kernel_ulong_t)&tgllp_soc_data },
  728. { }
  729. };
  730. MODULE_DEVICE_TABLE(acpi, tgl_pinctrl_acpi_match);
  731. static INTEL_PINCTRL_PM_OPS(tgl_pinctrl_pm_ops);
  732. static struct platform_driver tgl_pinctrl_driver = {
  733. .probe = intel_pinctrl_probe_by_hid,
  734. .driver = {
  735. .name = "tigerlake-pinctrl",
  736. .acpi_match_table = tgl_pinctrl_acpi_match,
  737. .pm = &tgl_pinctrl_pm_ops,
  738. },
  739. };
  740. module_platform_driver(tgl_pinctrl_driver);
  741. MODULE_AUTHOR("Andy Shevchenko <[email protected]>");
  742. MODULE_AUTHOR("Mika Westerberg <[email protected]>");
  743. MODULE_DESCRIPTION("Intel Tiger Lake PCH pinctrl/GPIO driver");
  744. MODULE_LICENSE("GPL v2");