pinctrl-msm8960.c 37 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282
  1. /*
  2. * Copyright (c) 2014, Sony Mobile Communications AB.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 and
  6. * only version 2 as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <linux/module.h>
  14. #include <linux/of.h>
  15. #include <linux/platform_device.h>
  16. #include <linux/pinctrl/pinctrl.h>
  17. #include <linux/pinctrl/pinmux.h>
  18. #include "pinctrl-msm.h"
  19. static const struct pinctrl_pin_desc msm8960_pins[] = {
  20. PINCTRL_PIN(0, "GPIO_0"),
  21. PINCTRL_PIN(1, "GPIO_1"),
  22. PINCTRL_PIN(2, "GPIO_2"),
  23. PINCTRL_PIN(3, "GPIO_3"),
  24. PINCTRL_PIN(4, "GPIO_4"),
  25. PINCTRL_PIN(5, "GPIO_5"),
  26. PINCTRL_PIN(6, "GPIO_6"),
  27. PINCTRL_PIN(7, "GPIO_7"),
  28. PINCTRL_PIN(8, "GPIO_8"),
  29. PINCTRL_PIN(9, "GPIO_9"),
  30. PINCTRL_PIN(10, "GPIO_10"),
  31. PINCTRL_PIN(11, "GPIO_11"),
  32. PINCTRL_PIN(12, "GPIO_12"),
  33. PINCTRL_PIN(13, "GPIO_13"),
  34. PINCTRL_PIN(14, "GPIO_14"),
  35. PINCTRL_PIN(15, "GPIO_15"),
  36. PINCTRL_PIN(16, "GPIO_16"),
  37. PINCTRL_PIN(17, "GPIO_17"),
  38. PINCTRL_PIN(18, "GPIO_18"),
  39. PINCTRL_PIN(19, "GPIO_19"),
  40. PINCTRL_PIN(20, "GPIO_20"),
  41. PINCTRL_PIN(21, "GPIO_21"),
  42. PINCTRL_PIN(22, "GPIO_22"),
  43. PINCTRL_PIN(23, "GPIO_23"),
  44. PINCTRL_PIN(24, "GPIO_24"),
  45. PINCTRL_PIN(25, "GPIO_25"),
  46. PINCTRL_PIN(26, "GPIO_26"),
  47. PINCTRL_PIN(27, "GPIO_27"),
  48. PINCTRL_PIN(28, "GPIO_28"),
  49. PINCTRL_PIN(29, "GPIO_29"),
  50. PINCTRL_PIN(30, "GPIO_30"),
  51. PINCTRL_PIN(31, "GPIO_31"),
  52. PINCTRL_PIN(32, "GPIO_32"),
  53. PINCTRL_PIN(33, "GPIO_33"),
  54. PINCTRL_PIN(34, "GPIO_34"),
  55. PINCTRL_PIN(35, "GPIO_35"),
  56. PINCTRL_PIN(36, "GPIO_36"),
  57. PINCTRL_PIN(37, "GPIO_37"),
  58. PINCTRL_PIN(38, "GPIO_38"),
  59. PINCTRL_PIN(39, "GPIO_39"),
  60. PINCTRL_PIN(40, "GPIO_40"),
  61. PINCTRL_PIN(41, "GPIO_41"),
  62. PINCTRL_PIN(42, "GPIO_42"),
  63. PINCTRL_PIN(43, "GPIO_43"),
  64. PINCTRL_PIN(44, "GPIO_44"),
  65. PINCTRL_PIN(45, "GPIO_45"),
  66. PINCTRL_PIN(46, "GPIO_46"),
  67. PINCTRL_PIN(47, "GPIO_47"),
  68. PINCTRL_PIN(48, "GPIO_48"),
  69. PINCTRL_PIN(49, "GPIO_49"),
  70. PINCTRL_PIN(50, "GPIO_50"),
  71. PINCTRL_PIN(51, "GPIO_51"),
  72. PINCTRL_PIN(52, "GPIO_52"),
  73. PINCTRL_PIN(53, "GPIO_53"),
  74. PINCTRL_PIN(54, "GPIO_54"),
  75. PINCTRL_PIN(55, "GPIO_55"),
  76. PINCTRL_PIN(56, "GPIO_56"),
  77. PINCTRL_PIN(57, "GPIO_57"),
  78. PINCTRL_PIN(58, "GPIO_58"),
  79. PINCTRL_PIN(59, "GPIO_59"),
  80. PINCTRL_PIN(60, "GPIO_60"),
  81. PINCTRL_PIN(61, "GPIO_61"),
  82. PINCTRL_PIN(62, "GPIO_62"),
  83. PINCTRL_PIN(63, "GPIO_63"),
  84. PINCTRL_PIN(64, "GPIO_64"),
  85. PINCTRL_PIN(65, "GPIO_65"),
  86. PINCTRL_PIN(66, "GPIO_66"),
  87. PINCTRL_PIN(67, "GPIO_67"),
  88. PINCTRL_PIN(68, "GPIO_68"),
  89. PINCTRL_PIN(69, "GPIO_69"),
  90. PINCTRL_PIN(70, "GPIO_70"),
  91. PINCTRL_PIN(71, "GPIO_71"),
  92. PINCTRL_PIN(72, "GPIO_72"),
  93. PINCTRL_PIN(73, "GPIO_73"),
  94. PINCTRL_PIN(74, "GPIO_74"),
  95. PINCTRL_PIN(75, "GPIO_75"),
  96. PINCTRL_PIN(76, "GPIO_76"),
  97. PINCTRL_PIN(77, "GPIO_77"),
  98. PINCTRL_PIN(78, "GPIO_78"),
  99. PINCTRL_PIN(79, "GPIO_79"),
  100. PINCTRL_PIN(80, "GPIO_80"),
  101. PINCTRL_PIN(81, "GPIO_81"),
  102. PINCTRL_PIN(82, "GPIO_82"),
  103. PINCTRL_PIN(83, "GPIO_83"),
  104. PINCTRL_PIN(84, "GPIO_84"),
  105. PINCTRL_PIN(85, "GPIO_85"),
  106. PINCTRL_PIN(86, "GPIO_86"),
  107. PINCTRL_PIN(87, "GPIO_87"),
  108. PINCTRL_PIN(88, "GPIO_88"),
  109. PINCTRL_PIN(89, "GPIO_89"),
  110. PINCTRL_PIN(90, "GPIO_90"),
  111. PINCTRL_PIN(91, "GPIO_91"),
  112. PINCTRL_PIN(92, "GPIO_92"),
  113. PINCTRL_PIN(93, "GPIO_93"),
  114. PINCTRL_PIN(94, "GPIO_94"),
  115. PINCTRL_PIN(95, "GPIO_95"),
  116. PINCTRL_PIN(96, "GPIO_96"),
  117. PINCTRL_PIN(97, "GPIO_97"),
  118. PINCTRL_PIN(98, "GPIO_98"),
  119. PINCTRL_PIN(99, "GPIO_99"),
  120. PINCTRL_PIN(100, "GPIO_100"),
  121. PINCTRL_PIN(101, "GPIO_101"),
  122. PINCTRL_PIN(102, "GPIO_102"),
  123. PINCTRL_PIN(103, "GPIO_103"),
  124. PINCTRL_PIN(104, "GPIO_104"),
  125. PINCTRL_PIN(105, "GPIO_105"),
  126. PINCTRL_PIN(106, "GPIO_106"),
  127. PINCTRL_PIN(107, "GPIO_107"),
  128. PINCTRL_PIN(108, "GPIO_108"),
  129. PINCTRL_PIN(109, "GPIO_109"),
  130. PINCTRL_PIN(110, "GPIO_110"),
  131. PINCTRL_PIN(111, "GPIO_111"),
  132. PINCTRL_PIN(112, "GPIO_112"),
  133. PINCTRL_PIN(113, "GPIO_113"),
  134. PINCTRL_PIN(114, "GPIO_114"),
  135. PINCTRL_PIN(115, "GPIO_115"),
  136. PINCTRL_PIN(116, "GPIO_116"),
  137. PINCTRL_PIN(117, "GPIO_117"),
  138. PINCTRL_PIN(118, "GPIO_118"),
  139. PINCTRL_PIN(119, "GPIO_119"),
  140. PINCTRL_PIN(120, "GPIO_120"),
  141. PINCTRL_PIN(121, "GPIO_121"),
  142. PINCTRL_PIN(122, "GPIO_122"),
  143. PINCTRL_PIN(123, "GPIO_123"),
  144. PINCTRL_PIN(124, "GPIO_124"),
  145. PINCTRL_PIN(125, "GPIO_125"),
  146. PINCTRL_PIN(126, "GPIO_126"),
  147. PINCTRL_PIN(127, "GPIO_127"),
  148. PINCTRL_PIN(128, "GPIO_128"),
  149. PINCTRL_PIN(129, "GPIO_129"),
  150. PINCTRL_PIN(130, "GPIO_130"),
  151. PINCTRL_PIN(131, "GPIO_131"),
  152. PINCTRL_PIN(132, "GPIO_132"),
  153. PINCTRL_PIN(133, "GPIO_133"),
  154. PINCTRL_PIN(134, "GPIO_134"),
  155. PINCTRL_PIN(135, "GPIO_135"),
  156. PINCTRL_PIN(136, "GPIO_136"),
  157. PINCTRL_PIN(137, "GPIO_137"),
  158. PINCTRL_PIN(138, "GPIO_138"),
  159. PINCTRL_PIN(139, "GPIO_139"),
  160. PINCTRL_PIN(140, "GPIO_140"),
  161. PINCTRL_PIN(141, "GPIO_141"),
  162. PINCTRL_PIN(142, "GPIO_142"),
  163. PINCTRL_PIN(143, "GPIO_143"),
  164. PINCTRL_PIN(144, "GPIO_144"),
  165. PINCTRL_PIN(145, "GPIO_145"),
  166. PINCTRL_PIN(146, "GPIO_146"),
  167. PINCTRL_PIN(147, "GPIO_147"),
  168. PINCTRL_PIN(148, "GPIO_148"),
  169. PINCTRL_PIN(149, "GPIO_149"),
  170. PINCTRL_PIN(150, "GPIO_150"),
  171. PINCTRL_PIN(151, "GPIO_151"),
  172. PINCTRL_PIN(152, "SDC1_CLK"),
  173. PINCTRL_PIN(153, "SDC1_CMD"),
  174. PINCTRL_PIN(154, "SDC1_DATA"),
  175. PINCTRL_PIN(155, "SDC3_CLK"),
  176. PINCTRL_PIN(156, "SDC3_CMD"),
  177. PINCTRL_PIN(157, "SDC3_DATA"),
  178. };
  179. #define DECLARE_MSM_GPIO_PINS(pin) static const unsigned int gpio##pin##_pins[] = { pin }
  180. DECLARE_MSM_GPIO_PINS(0);
  181. DECLARE_MSM_GPIO_PINS(1);
  182. DECLARE_MSM_GPIO_PINS(2);
  183. DECLARE_MSM_GPIO_PINS(3);
  184. DECLARE_MSM_GPIO_PINS(4);
  185. DECLARE_MSM_GPIO_PINS(5);
  186. DECLARE_MSM_GPIO_PINS(6);
  187. DECLARE_MSM_GPIO_PINS(7);
  188. DECLARE_MSM_GPIO_PINS(8);
  189. DECLARE_MSM_GPIO_PINS(9);
  190. DECLARE_MSM_GPIO_PINS(10);
  191. DECLARE_MSM_GPIO_PINS(11);
  192. DECLARE_MSM_GPIO_PINS(12);
  193. DECLARE_MSM_GPIO_PINS(13);
  194. DECLARE_MSM_GPIO_PINS(14);
  195. DECLARE_MSM_GPIO_PINS(15);
  196. DECLARE_MSM_GPIO_PINS(16);
  197. DECLARE_MSM_GPIO_PINS(17);
  198. DECLARE_MSM_GPIO_PINS(18);
  199. DECLARE_MSM_GPIO_PINS(19);
  200. DECLARE_MSM_GPIO_PINS(20);
  201. DECLARE_MSM_GPIO_PINS(21);
  202. DECLARE_MSM_GPIO_PINS(22);
  203. DECLARE_MSM_GPIO_PINS(23);
  204. DECLARE_MSM_GPIO_PINS(24);
  205. DECLARE_MSM_GPIO_PINS(25);
  206. DECLARE_MSM_GPIO_PINS(26);
  207. DECLARE_MSM_GPIO_PINS(27);
  208. DECLARE_MSM_GPIO_PINS(28);
  209. DECLARE_MSM_GPIO_PINS(29);
  210. DECLARE_MSM_GPIO_PINS(30);
  211. DECLARE_MSM_GPIO_PINS(31);
  212. DECLARE_MSM_GPIO_PINS(32);
  213. DECLARE_MSM_GPIO_PINS(33);
  214. DECLARE_MSM_GPIO_PINS(34);
  215. DECLARE_MSM_GPIO_PINS(35);
  216. DECLARE_MSM_GPIO_PINS(36);
  217. DECLARE_MSM_GPIO_PINS(37);
  218. DECLARE_MSM_GPIO_PINS(38);
  219. DECLARE_MSM_GPIO_PINS(39);
  220. DECLARE_MSM_GPIO_PINS(40);
  221. DECLARE_MSM_GPIO_PINS(41);
  222. DECLARE_MSM_GPIO_PINS(42);
  223. DECLARE_MSM_GPIO_PINS(43);
  224. DECLARE_MSM_GPIO_PINS(44);
  225. DECLARE_MSM_GPIO_PINS(45);
  226. DECLARE_MSM_GPIO_PINS(46);
  227. DECLARE_MSM_GPIO_PINS(47);
  228. DECLARE_MSM_GPIO_PINS(48);
  229. DECLARE_MSM_GPIO_PINS(49);
  230. DECLARE_MSM_GPIO_PINS(50);
  231. DECLARE_MSM_GPIO_PINS(51);
  232. DECLARE_MSM_GPIO_PINS(52);
  233. DECLARE_MSM_GPIO_PINS(53);
  234. DECLARE_MSM_GPIO_PINS(54);
  235. DECLARE_MSM_GPIO_PINS(55);
  236. DECLARE_MSM_GPIO_PINS(56);
  237. DECLARE_MSM_GPIO_PINS(57);
  238. DECLARE_MSM_GPIO_PINS(58);
  239. DECLARE_MSM_GPIO_PINS(59);
  240. DECLARE_MSM_GPIO_PINS(60);
  241. DECLARE_MSM_GPIO_PINS(61);
  242. DECLARE_MSM_GPIO_PINS(62);
  243. DECLARE_MSM_GPIO_PINS(63);
  244. DECLARE_MSM_GPIO_PINS(64);
  245. DECLARE_MSM_GPIO_PINS(65);
  246. DECLARE_MSM_GPIO_PINS(66);
  247. DECLARE_MSM_GPIO_PINS(67);
  248. DECLARE_MSM_GPIO_PINS(68);
  249. DECLARE_MSM_GPIO_PINS(69);
  250. DECLARE_MSM_GPIO_PINS(70);
  251. DECLARE_MSM_GPIO_PINS(71);
  252. DECLARE_MSM_GPIO_PINS(72);
  253. DECLARE_MSM_GPIO_PINS(73);
  254. DECLARE_MSM_GPIO_PINS(74);
  255. DECLARE_MSM_GPIO_PINS(75);
  256. DECLARE_MSM_GPIO_PINS(76);
  257. DECLARE_MSM_GPIO_PINS(77);
  258. DECLARE_MSM_GPIO_PINS(78);
  259. DECLARE_MSM_GPIO_PINS(79);
  260. DECLARE_MSM_GPIO_PINS(80);
  261. DECLARE_MSM_GPIO_PINS(81);
  262. DECLARE_MSM_GPIO_PINS(82);
  263. DECLARE_MSM_GPIO_PINS(83);
  264. DECLARE_MSM_GPIO_PINS(84);
  265. DECLARE_MSM_GPIO_PINS(85);
  266. DECLARE_MSM_GPIO_PINS(86);
  267. DECLARE_MSM_GPIO_PINS(87);
  268. DECLARE_MSM_GPIO_PINS(88);
  269. DECLARE_MSM_GPIO_PINS(89);
  270. DECLARE_MSM_GPIO_PINS(90);
  271. DECLARE_MSM_GPIO_PINS(91);
  272. DECLARE_MSM_GPIO_PINS(92);
  273. DECLARE_MSM_GPIO_PINS(93);
  274. DECLARE_MSM_GPIO_PINS(94);
  275. DECLARE_MSM_GPIO_PINS(95);
  276. DECLARE_MSM_GPIO_PINS(96);
  277. DECLARE_MSM_GPIO_PINS(97);
  278. DECLARE_MSM_GPIO_PINS(98);
  279. DECLARE_MSM_GPIO_PINS(99);
  280. DECLARE_MSM_GPIO_PINS(100);
  281. DECLARE_MSM_GPIO_PINS(101);
  282. DECLARE_MSM_GPIO_PINS(102);
  283. DECLARE_MSM_GPIO_PINS(103);
  284. DECLARE_MSM_GPIO_PINS(104);
  285. DECLARE_MSM_GPIO_PINS(105);
  286. DECLARE_MSM_GPIO_PINS(106);
  287. DECLARE_MSM_GPIO_PINS(107);
  288. DECLARE_MSM_GPIO_PINS(108);
  289. DECLARE_MSM_GPIO_PINS(109);
  290. DECLARE_MSM_GPIO_PINS(110);
  291. DECLARE_MSM_GPIO_PINS(111);
  292. DECLARE_MSM_GPIO_PINS(112);
  293. DECLARE_MSM_GPIO_PINS(113);
  294. DECLARE_MSM_GPIO_PINS(114);
  295. DECLARE_MSM_GPIO_PINS(115);
  296. DECLARE_MSM_GPIO_PINS(116);
  297. DECLARE_MSM_GPIO_PINS(117);
  298. DECLARE_MSM_GPIO_PINS(118);
  299. DECLARE_MSM_GPIO_PINS(119);
  300. DECLARE_MSM_GPIO_PINS(120);
  301. DECLARE_MSM_GPIO_PINS(121);
  302. DECLARE_MSM_GPIO_PINS(122);
  303. DECLARE_MSM_GPIO_PINS(123);
  304. DECLARE_MSM_GPIO_PINS(124);
  305. DECLARE_MSM_GPIO_PINS(125);
  306. DECLARE_MSM_GPIO_PINS(126);
  307. DECLARE_MSM_GPIO_PINS(127);
  308. DECLARE_MSM_GPIO_PINS(128);
  309. DECLARE_MSM_GPIO_PINS(129);
  310. DECLARE_MSM_GPIO_PINS(130);
  311. DECLARE_MSM_GPIO_PINS(131);
  312. DECLARE_MSM_GPIO_PINS(132);
  313. DECLARE_MSM_GPIO_PINS(133);
  314. DECLARE_MSM_GPIO_PINS(134);
  315. DECLARE_MSM_GPIO_PINS(135);
  316. DECLARE_MSM_GPIO_PINS(136);
  317. DECLARE_MSM_GPIO_PINS(137);
  318. DECLARE_MSM_GPIO_PINS(138);
  319. DECLARE_MSM_GPIO_PINS(139);
  320. DECLARE_MSM_GPIO_PINS(140);
  321. DECLARE_MSM_GPIO_PINS(141);
  322. DECLARE_MSM_GPIO_PINS(142);
  323. DECLARE_MSM_GPIO_PINS(143);
  324. DECLARE_MSM_GPIO_PINS(144);
  325. DECLARE_MSM_GPIO_PINS(145);
  326. DECLARE_MSM_GPIO_PINS(146);
  327. DECLARE_MSM_GPIO_PINS(147);
  328. DECLARE_MSM_GPIO_PINS(148);
  329. DECLARE_MSM_GPIO_PINS(149);
  330. DECLARE_MSM_GPIO_PINS(150);
  331. DECLARE_MSM_GPIO_PINS(151);
  332. static const unsigned int sdc1_clk_pins[] = { 152 };
  333. static const unsigned int sdc1_cmd_pins[] = { 153 };
  334. static const unsigned int sdc1_data_pins[] = { 154 };
  335. static const unsigned int sdc3_clk_pins[] = { 155 };
  336. static const unsigned int sdc3_cmd_pins[] = { 156 };
  337. static const unsigned int sdc3_data_pins[] = { 157 };
  338. #define FUNCTION(fname) \
  339. [MSM_MUX_##fname] = { \
  340. .name = #fname, \
  341. .groups = fname##_groups, \
  342. .ngroups = ARRAY_SIZE(fname##_groups), \
  343. }
  344. #define PINGROUP(id, f1, f2, f3, f4, f5, f6, f7, f8, f9, f10, f11) \
  345. { \
  346. .name = "gpio" #id, \
  347. .pins = gpio##id##_pins, \
  348. .npins = ARRAY_SIZE(gpio##id##_pins), \
  349. .funcs = (int[]){ \
  350. MSM_MUX_gpio, \
  351. MSM_MUX_##f1, \
  352. MSM_MUX_##f2, \
  353. MSM_MUX_##f3, \
  354. MSM_MUX_##f4, \
  355. MSM_MUX_##f5, \
  356. MSM_MUX_##f6, \
  357. MSM_MUX_##f7, \
  358. MSM_MUX_##f8, \
  359. MSM_MUX_##f9, \
  360. MSM_MUX_##f10, \
  361. MSM_MUX_##f11 \
  362. }, \
  363. .nfuncs = 12, \
  364. .ctl_reg = 0x1000 + 0x10 * id, \
  365. .io_reg = 0x1004 + 0x10 * id, \
  366. .intr_cfg_reg = 0x1008 + 0x10 * id, \
  367. .intr_status_reg = 0x100c + 0x10 * id, \
  368. .intr_target_reg = 0x400 + 0x4 * id, \
  369. .mux_bit = 2, \
  370. .pull_bit = 0, \
  371. .drv_bit = 6, \
  372. .oe_bit = 9, \
  373. .in_bit = 0, \
  374. .out_bit = 1, \
  375. .intr_enable_bit = 0, \
  376. .intr_status_bit = 0, \
  377. .intr_ack_high = 1, \
  378. .intr_target_bit = 0, \
  379. .intr_raw_status_bit = 3, \
  380. .intr_polarity_bit = 1, \
  381. .intr_detection_bit = 2, \
  382. .intr_detection_width = 1, \
  383. }
  384. #define SDC_PINGROUP(pg_name, ctl, pull, drv) \
  385. { \
  386. .name = #pg_name, \
  387. .pins = pg_name##_pins, \
  388. .npins = ARRAY_SIZE(pg_name##_pins), \
  389. .ctl_reg = ctl, \
  390. .io_reg = 0, \
  391. .intr_cfg_reg = 0, \
  392. .intr_status_reg = 0, \
  393. .intr_target_reg = 0, \
  394. .mux_bit = -1, \
  395. .pull_bit = pull, \
  396. .drv_bit = drv, \
  397. .oe_bit = -1, \
  398. .in_bit = -1, \
  399. .out_bit = -1, \
  400. .intr_enable_bit = -1, \
  401. .intr_status_bit = -1, \
  402. .intr_target_bit = -1, \
  403. .intr_raw_status_bit = -1, \
  404. .intr_polarity_bit = -1, \
  405. .intr_detection_bit = -1, \
  406. .intr_detection_width = -1, \
  407. }
  408. enum msm8960_functions {
  409. MSM_MUX_audio_pcm,
  410. MSM_MUX_bt,
  411. MSM_MUX_cam_mclk0,
  412. MSM_MUX_cam_mclk1,
  413. MSM_MUX_cam_mclk2,
  414. MSM_MUX_codec_mic_i2s,
  415. MSM_MUX_codec_spkr_i2s,
  416. MSM_MUX_ext_gps,
  417. MSM_MUX_fm,
  418. MSM_MUX_gps_blanking,
  419. MSM_MUX_gps_pps_in,
  420. MSM_MUX_gps_pps_out,
  421. MSM_MUX_gp_clk_0a,
  422. MSM_MUX_gp_clk_0b,
  423. MSM_MUX_gp_clk_1a,
  424. MSM_MUX_gp_clk_1b,
  425. MSM_MUX_gp_clk_2a,
  426. MSM_MUX_gp_clk_2b,
  427. MSM_MUX_gp_mn,
  428. MSM_MUX_gp_pdm_0a,
  429. MSM_MUX_gp_pdm_0b,
  430. MSM_MUX_gp_pdm_1a,
  431. MSM_MUX_gp_pdm_1b,
  432. MSM_MUX_gp_pdm_2a,
  433. MSM_MUX_gp_pdm_2b,
  434. MSM_MUX_gpio,
  435. MSM_MUX_gsbi1,
  436. MSM_MUX_gsbi1_spi_cs1_n,
  437. MSM_MUX_gsbi1_spi_cs2a_n,
  438. MSM_MUX_gsbi1_spi_cs2b_n,
  439. MSM_MUX_gsbi1_spi_cs3_n,
  440. MSM_MUX_gsbi2,
  441. MSM_MUX_gsbi2_spi_cs1_n,
  442. MSM_MUX_gsbi2_spi_cs2_n,
  443. MSM_MUX_gsbi2_spi_cs3_n,
  444. MSM_MUX_gsbi3,
  445. MSM_MUX_gsbi4,
  446. MSM_MUX_gsbi4_3d_cam_i2c_l,
  447. MSM_MUX_gsbi4_3d_cam_i2c_r,
  448. MSM_MUX_gsbi5,
  449. MSM_MUX_gsbi5_3d_cam_i2c_l,
  450. MSM_MUX_gsbi5_3d_cam_i2c_r,
  451. MSM_MUX_gsbi6,
  452. MSM_MUX_gsbi7,
  453. MSM_MUX_gsbi8,
  454. MSM_MUX_gsbi9,
  455. MSM_MUX_gsbi10,
  456. MSM_MUX_gsbi11,
  457. MSM_MUX_gsbi11_spi_cs1a_n,
  458. MSM_MUX_gsbi11_spi_cs1b_n,
  459. MSM_MUX_gsbi11_spi_cs2a_n,
  460. MSM_MUX_gsbi11_spi_cs2b_n,
  461. MSM_MUX_gsbi11_spi_cs3_n,
  462. MSM_MUX_gsbi12,
  463. MSM_MUX_hdmi_cec,
  464. MSM_MUX_hdmi_ddc_clock,
  465. MSM_MUX_hdmi_ddc_data,
  466. MSM_MUX_hdmi_hot_plug_detect,
  467. MSM_MUX_hsic,
  468. MSM_MUX_mdp_vsync,
  469. MSM_MUX_mi2s,
  470. MSM_MUX_mic_i2s,
  471. MSM_MUX_pmb_clk,
  472. MSM_MUX_pmb_ext_ctrl,
  473. MSM_MUX_ps_hold,
  474. MSM_MUX_rpm_wdog,
  475. MSM_MUX_sdc2,
  476. MSM_MUX_sdc4,
  477. MSM_MUX_sdc5,
  478. MSM_MUX_slimbus1,
  479. MSM_MUX_slimbus2,
  480. MSM_MUX_spkr_i2s,
  481. MSM_MUX_ssbi1,
  482. MSM_MUX_ssbi2,
  483. MSM_MUX_ssbi_ext_gps,
  484. MSM_MUX_ssbi_pmic2,
  485. MSM_MUX_ssbi_qpa1,
  486. MSM_MUX_ssbi_ts,
  487. MSM_MUX_tsif1,
  488. MSM_MUX_tsif2,
  489. MSM_MUX_ts_eoc,
  490. MSM_MUX_usb_fs1,
  491. MSM_MUX_usb_fs1_oe,
  492. MSM_MUX_usb_fs1_oe_n,
  493. MSM_MUX_usb_fs2,
  494. MSM_MUX_usb_fs2_oe,
  495. MSM_MUX_usb_fs2_oe_n,
  496. MSM_MUX_vfe_camif_timer1_a,
  497. MSM_MUX_vfe_camif_timer1_b,
  498. MSM_MUX_vfe_camif_timer2,
  499. MSM_MUX_vfe_camif_timer3_a,
  500. MSM_MUX_vfe_camif_timer3_b,
  501. MSM_MUX_vfe_camif_timer4_a,
  502. MSM_MUX_vfe_camif_timer4_b,
  503. MSM_MUX_vfe_camif_timer4_c,
  504. MSM_MUX_vfe_camif_timer5_a,
  505. MSM_MUX_vfe_camif_timer5_b,
  506. MSM_MUX_vfe_camif_timer6_a,
  507. MSM_MUX_vfe_camif_timer6_b,
  508. MSM_MUX_vfe_camif_timer6_c,
  509. MSM_MUX_vfe_camif_timer7_a,
  510. MSM_MUX_vfe_camif_timer7_b,
  511. MSM_MUX_vfe_camif_timer7_c,
  512. MSM_MUX_wlan,
  513. MSM_MUX_NA,
  514. };
  515. static const char * const audio_pcm_groups[] = {
  516. "gpio63", "gpio64", "gpio65", "gpio66"
  517. };
  518. static const char * const bt_groups[] = {
  519. "gpio28", "gpio29", "gpio83"
  520. };
  521. static const char * const cam_mclk0_groups[] = {
  522. "gpio5"
  523. };
  524. static const char * const cam_mclk1_groups[] = {
  525. "gpio4"
  526. };
  527. static const char * const cam_mclk2_groups[] = {
  528. "gpio2"
  529. };
  530. static const char * const codec_mic_i2s_groups[] = {
  531. "gpio54", "gpio55", "gpio56", "gpio57", "gpio58"
  532. };
  533. static const char * const codec_spkr_i2s_groups[] = {
  534. "gpio59", "gpio60", "gpio61", "gpio62"
  535. };
  536. static const char * const ext_gps_groups[] = {
  537. "gpio22", "gpio23", "gpio24", "gpio25"
  538. };
  539. static const char * const fm_groups[] = {
  540. "gpio26", "gpio27"
  541. };
  542. static const char * const gps_blanking_groups[] = {
  543. "gpio137"
  544. };
  545. static const char * const gps_pps_in_groups[] = {
  546. "gpio37"
  547. };
  548. static const char * const gps_pps_out_groups[] = {
  549. "gpio37"
  550. };
  551. static const char * const gp_clk_0a_groups[] = {
  552. "gpio3"
  553. };
  554. static const char * const gp_clk_0b_groups[] = {
  555. "gpio54"
  556. };
  557. static const char * const gp_clk_1a_groups[] = {
  558. "gpio4"
  559. };
  560. static const char * const gp_clk_1b_groups[] = {
  561. "gpio70"
  562. };
  563. static const char * const gp_clk_2a_groups[] = {
  564. "gpio52"
  565. };
  566. static const char * const gp_clk_2b_groups[] = {
  567. "gpio37"
  568. };
  569. static const char * const gp_mn_groups[] = {
  570. "gpio2"
  571. };
  572. static const char * const gp_pdm_0a_groups[] = {
  573. "gpio58"
  574. };
  575. static const char * const gp_pdm_0b_groups[] = {
  576. "gpio39"
  577. };
  578. static const char * const gp_pdm_1a_groups[] = {
  579. "gpio94"
  580. };
  581. static const char * const gp_pdm_1b_groups[] = {
  582. "gpio64"
  583. };
  584. static const char * const gp_pdm_2a_groups[] = {
  585. "gpio69"
  586. };
  587. static const char * const gp_pdm_2b_groups[] = {
  588. "gpio53"
  589. };
  590. static const char * const gpio_groups[] = {
  591. "gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7",
  592. "gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14",
  593. "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
  594. "gpio22", "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28",
  595. "gpio29", "gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35",
  596. "gpio36", "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42",
  597. "gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49",
  598. "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55", "gpio56",
  599. "gpio57", "gpio58", "gpio59", "gpio60", "gpio61", "gpio62", "gpio63",
  600. "gpio64", "gpio65", "gpio66", "gpio67", "gpio68", "gpio69", "gpio70",
  601. "gpio71", "gpio72", "gpio73", "gpio74", "gpio75", "gpio76", "gpio77",
  602. "gpio78", "gpio79", "gpio80", "gpio81", "gpio82", "gpio83", "gpio84",
  603. "gpio85", "gpio86", "gpio87", "gpio88", "gpio89", "gpio90", "gpio91",
  604. "gpio92", "gpio93", "gpio94", "gpio95", "gpio96", "gpio97", "gpio98",
  605. "gpio99", "gpio100", "gpio101", "gpio102", "gpio103", "gpio104",
  606. "gpio105", "gpio106", "gpio107", "gpio108", "gpio109", "gpio110",
  607. "gpio111", "gpio112", "gpio113", "gpio114", "gpio115", "gpio116",
  608. "gpio117", "gpio118", "gpio119", "gpio120", "gpio121", "gpio122",
  609. "gpio123", "gpio124", "gpio125", "gpio126", "gpio127", "gpio128",
  610. "gpio129", "gpio130", "gpio131", "gpio132", "gpio133", "gpio134",
  611. "gpio135", "gpio136", "gpio137", "gpio138", "gpio139", "gpio140",
  612. "gpio141", "gpio142", "gpio143", "gpio144", "gpio145", "gpio146",
  613. "gpio147", "gpio148", "gpio149", "gpio150", "gpio151"
  614. };
  615. static const char * const gsbi1_groups[] = {
  616. "gpio6", "gpio7", "gpio8", "gpio9"
  617. };
  618. static const char * const gsbi1_spi_cs1_n_groups[] = {
  619. "gpio14"
  620. };
  621. static const char * const gsbi1_spi_cs2a_n_groups[] = {
  622. "gpio15"
  623. };
  624. static const char * const gsbi1_spi_cs2b_n_groups[] = {
  625. "gpio17"
  626. };
  627. static const char * const gsbi1_spi_cs3_n_groups[] = {
  628. "gpio16"
  629. };
  630. static const char * const gsbi2_groups[] = {
  631. "gpio10", "gpio11", "gpio12", "gpio13"
  632. };
  633. static const char * const gsbi2_spi_cs1_n_groups[] = {
  634. "gpio52"
  635. };
  636. static const char * const gsbi2_spi_cs2_n_groups[] = {
  637. "gpio68"
  638. };
  639. static const char * const gsbi2_spi_cs3_n_groups[] = {
  640. "gpio56"
  641. };
  642. static const char * const gsbi3_groups[] = {
  643. "gpio14", "gpio15", "gpio16", "gpio17"
  644. };
  645. static const char * const gsbi4_groups[] = {
  646. "gpio18", "gpio19", "gpio20", "gpio21"
  647. };
  648. static const char * const gsbi4_3d_cam_i2c_l_groups[] = {
  649. "gpio18", "gpio19"
  650. };
  651. static const char * const gsbi4_3d_cam_i2c_r_groups[] = {
  652. "gpio20", "gpio21"
  653. };
  654. static const char * const gsbi5_groups[] = {
  655. "gpio22", "gpio23", "gpio24", "gpio25"
  656. };
  657. static const char * const gsbi5_3d_cam_i2c_l_groups[] = {
  658. "gpio22", "gpio23"
  659. };
  660. static const char * const gsbi5_3d_cam_i2c_r_groups[] = {
  661. "gpio24", "gpio25"
  662. };
  663. static const char * const gsbi6_groups[] = {
  664. "gpio26", "gpio27", "gpio28", "gpio29"
  665. };
  666. static const char * const gsbi7_groups[] = {
  667. "gpio30", "gpio31", "gpio32", "gpio33"
  668. };
  669. static const char * const gsbi8_groups[] = {
  670. "gpio34", "gpio35", "gpio36", "gpio37"
  671. };
  672. static const char * const gsbi9_groups[] = {
  673. "gpio93", "gpio94", "gpio95", "gpio96"
  674. };
  675. static const char * const gsbi10_groups[] = {
  676. "gpio71", "gpio72", "gpio73", "gpio74"
  677. };
  678. static const char * const gsbi11_groups[] = {
  679. "gpio38", "gpio39", "gpio40", "gpio41"
  680. };
  681. static const char * const gsbi11_spi_cs1a_n_groups[] = {
  682. "gpio36"
  683. };
  684. static const char * const gsbi11_spi_cs1b_n_groups[] = {
  685. "gpio18"
  686. };
  687. static const char * const gsbi11_spi_cs2a_n_groups[] = {
  688. "gpio37"
  689. };
  690. static const char * const gsbi11_spi_cs2b_n_groups[] = {
  691. "gpio19"
  692. };
  693. static const char * const gsbi11_spi_cs3_n_groups[] = {
  694. "gpio76"
  695. };
  696. static const char * const gsbi12_groups[] = {
  697. "gpio42", "gpio43", "gpio44", "gpio45"
  698. };
  699. static const char * const hdmi_cec_groups[] = {
  700. "gpio99"
  701. };
  702. static const char * const hdmi_ddc_clock_groups[] = {
  703. "gpio100"
  704. };
  705. static const char * const hdmi_ddc_data_groups[] = {
  706. "gpio101"
  707. };
  708. static const char * const hdmi_hot_plug_detect_groups[] = {
  709. "gpio102"
  710. };
  711. static const char * const hsic_groups[] = {
  712. "gpio150", "gpio151"
  713. };
  714. static const char * const mdp_vsync_groups[] = {
  715. "gpio0", "gpio1", "gpio19"
  716. };
  717. static const char * const mi2s_groups[] = {
  718. "gpio47", "gpio48", "gpio49", "gpio50", "gpio51", "gpio52", "gpio53"
  719. };
  720. static const char * const mic_i2s_groups[] = {
  721. "gpio71", "gpio72", "gpio73", "gpio74"
  722. };
  723. static const char * const pmb_clk_groups[] = {
  724. "gpio21", "gpio86", "gpio112"
  725. };
  726. static const char * const pmb_ext_ctrl_groups[] = {
  727. "gpio4", "gpio5"
  728. };
  729. static const char * const ps_hold_groups[] = {
  730. "gpio108"
  731. };
  732. static const char * const rpm_wdog_groups[] = {
  733. "gpio12"
  734. };
  735. static const char * const sdc2_groups[] = {
  736. "gpio89", "gpio90", "gpio91", "gpio92", "gpio93", "gpio94", "gpio95",
  737. "gpio96", "gpio97", "gpio98"
  738. };
  739. static const char * const sdc4_groups[] = {
  740. "gpio83", "gpio84", "gpio85", "gpio86", "gpio87", "gpio88"
  741. };
  742. static const char * const sdc5_groups[] = {
  743. "gpio77", "gpio78", "gpio79", "gpio80", "gpio81", "gpio82"
  744. };
  745. static const char * const slimbus1_groups[] = {
  746. "gpio50", "gpio51", "gpio60", "gpio61"
  747. };
  748. static const char * const slimbus2_groups[] = {
  749. "gpio42", "gpio43"
  750. };
  751. static const char * const spkr_i2s_groups[] = {
  752. "gpio67", "gpio68", "gpio69", "gpio70"
  753. };
  754. static const char * const ssbi1_groups[] = {
  755. "gpio141", "gpio143"
  756. };
  757. static const char * const ssbi2_groups[] = {
  758. "gpio140", "gpio142"
  759. };
  760. static const char * const ssbi_ext_gps_groups[] = {
  761. "gpio23"
  762. };
  763. static const char * const ssbi_pmic2_groups[] = {
  764. "gpio149"
  765. };
  766. static const char * const ssbi_qpa1_groups[] = {
  767. "gpio131"
  768. };
  769. static const char * const ssbi_ts_groups[] = {
  770. "gpio10"
  771. };
  772. static const char * const tsif1_groups[] = {
  773. "gpio75", "gpio76", "gpio77", "gpio82"
  774. };
  775. static const char * const tsif2_groups[] = {
  776. "gpio78", "gpio79", "gpio80", "gpio81"
  777. };
  778. static const char * const ts_eoc_groups[] = {
  779. "gpio11"
  780. };
  781. static const char * const usb_fs1_groups[] = {
  782. "gpio32", "gpio33"
  783. };
  784. static const char * const usb_fs1_oe_groups[] = {
  785. "gpio31"
  786. };
  787. static const char * const usb_fs1_oe_n_groups[] = {
  788. "gpio31"
  789. };
  790. static const char * const usb_fs2_groups[] = {
  791. "gpio34", "gpio35"
  792. };
  793. static const char * const usb_fs2_oe_groups[] = {
  794. "gpio36"
  795. };
  796. static const char * const usb_fs2_oe_n_groups[] = {
  797. "gpio36"
  798. };
  799. static const char * const vfe_camif_timer1_a_groups[] = {
  800. "gpio2"
  801. };
  802. static const char * const vfe_camif_timer1_b_groups[] = {
  803. "gpio38"
  804. };
  805. static const char * const vfe_camif_timer2_groups[] = {
  806. "gpio3"
  807. };
  808. static const char * const vfe_camif_timer3_a_groups[] = {
  809. "gpio4"
  810. };
  811. static const char * const vfe_camif_timer3_b_groups[] = {
  812. "gpio151"
  813. };
  814. static const char * const vfe_camif_timer4_a_groups[] = {
  815. "gpio65"
  816. };
  817. static const char * const vfe_camif_timer4_b_groups[] = {
  818. "gpio150"
  819. };
  820. static const char * const vfe_camif_timer4_c_groups[] = {
  821. "gpio10"
  822. };
  823. static const char * const vfe_camif_timer5_a_groups[] = {
  824. "gpio66"
  825. };
  826. static const char * const vfe_camif_timer5_b_groups[] = {
  827. "gpio39"
  828. };
  829. static const char * const vfe_camif_timer6_a_groups[] = {
  830. "gpio71"
  831. };
  832. static const char * const vfe_camif_timer6_b_groups[] = {
  833. "gpio0"
  834. };
  835. static const char * const vfe_camif_timer6_c_groups[] = {
  836. "gpio18"
  837. };
  838. static const char * const vfe_camif_timer7_a_groups[] = {
  839. "gpio67"
  840. };
  841. static const char * const vfe_camif_timer7_b_groups[] = {
  842. "gpio1"
  843. };
  844. static const char * const vfe_camif_timer7_c_groups[] = {
  845. "gpio19"
  846. };
  847. static const char * const wlan_groups[] = {
  848. "gpio84", "gpio85", "gpio86", "gpio87", "gpio88"
  849. };
  850. static const struct msm_function msm8960_functions[] = {
  851. FUNCTION(audio_pcm),
  852. FUNCTION(bt),
  853. FUNCTION(cam_mclk0),
  854. FUNCTION(cam_mclk1),
  855. FUNCTION(cam_mclk2),
  856. FUNCTION(codec_mic_i2s),
  857. FUNCTION(codec_spkr_i2s),
  858. FUNCTION(ext_gps),
  859. FUNCTION(fm),
  860. FUNCTION(gps_blanking),
  861. FUNCTION(gps_pps_in),
  862. FUNCTION(gps_pps_out),
  863. FUNCTION(gp_clk_0a),
  864. FUNCTION(gp_clk_0b),
  865. FUNCTION(gp_clk_1a),
  866. FUNCTION(gp_clk_1b),
  867. FUNCTION(gp_clk_2a),
  868. FUNCTION(gp_clk_2b),
  869. FUNCTION(gp_mn),
  870. FUNCTION(gp_pdm_0a),
  871. FUNCTION(gp_pdm_0b),
  872. FUNCTION(gp_pdm_1a),
  873. FUNCTION(gp_pdm_1b),
  874. FUNCTION(gp_pdm_2a),
  875. FUNCTION(gp_pdm_2b),
  876. FUNCTION(gpio),
  877. FUNCTION(gsbi1),
  878. FUNCTION(gsbi1_spi_cs1_n),
  879. FUNCTION(gsbi1_spi_cs2a_n),
  880. FUNCTION(gsbi1_spi_cs2b_n),
  881. FUNCTION(gsbi1_spi_cs3_n),
  882. FUNCTION(gsbi2),
  883. FUNCTION(gsbi2_spi_cs1_n),
  884. FUNCTION(gsbi2_spi_cs2_n),
  885. FUNCTION(gsbi2_spi_cs3_n),
  886. FUNCTION(gsbi3),
  887. FUNCTION(gsbi4),
  888. FUNCTION(gsbi4_3d_cam_i2c_l),
  889. FUNCTION(gsbi4_3d_cam_i2c_r),
  890. FUNCTION(gsbi5),
  891. FUNCTION(gsbi5_3d_cam_i2c_l),
  892. FUNCTION(gsbi5_3d_cam_i2c_r),
  893. FUNCTION(gsbi6),
  894. FUNCTION(gsbi7),
  895. FUNCTION(gsbi8),
  896. FUNCTION(gsbi9),
  897. FUNCTION(gsbi10),
  898. FUNCTION(gsbi11),
  899. FUNCTION(gsbi11_spi_cs1a_n),
  900. FUNCTION(gsbi11_spi_cs1b_n),
  901. FUNCTION(gsbi11_spi_cs2a_n),
  902. FUNCTION(gsbi11_spi_cs2b_n),
  903. FUNCTION(gsbi11_spi_cs3_n),
  904. FUNCTION(gsbi12),
  905. FUNCTION(hdmi_cec),
  906. FUNCTION(hdmi_ddc_clock),
  907. FUNCTION(hdmi_ddc_data),
  908. FUNCTION(hdmi_hot_plug_detect),
  909. FUNCTION(hsic),
  910. FUNCTION(mdp_vsync),
  911. FUNCTION(mi2s),
  912. FUNCTION(mic_i2s),
  913. FUNCTION(pmb_clk),
  914. FUNCTION(pmb_ext_ctrl),
  915. FUNCTION(ps_hold),
  916. FUNCTION(rpm_wdog),
  917. FUNCTION(sdc2),
  918. FUNCTION(sdc4),
  919. FUNCTION(sdc5),
  920. FUNCTION(slimbus1),
  921. FUNCTION(slimbus2),
  922. FUNCTION(spkr_i2s),
  923. FUNCTION(ssbi1),
  924. FUNCTION(ssbi2),
  925. FUNCTION(ssbi_ext_gps),
  926. FUNCTION(ssbi_pmic2),
  927. FUNCTION(ssbi_qpa1),
  928. FUNCTION(ssbi_ts),
  929. FUNCTION(tsif1),
  930. FUNCTION(tsif2),
  931. FUNCTION(ts_eoc),
  932. FUNCTION(usb_fs1),
  933. FUNCTION(usb_fs1_oe),
  934. FUNCTION(usb_fs1_oe_n),
  935. FUNCTION(usb_fs2),
  936. FUNCTION(usb_fs2_oe),
  937. FUNCTION(usb_fs2_oe_n),
  938. FUNCTION(vfe_camif_timer1_a),
  939. FUNCTION(vfe_camif_timer1_b),
  940. FUNCTION(vfe_camif_timer2),
  941. FUNCTION(vfe_camif_timer3_a),
  942. FUNCTION(vfe_camif_timer3_b),
  943. FUNCTION(vfe_camif_timer4_a),
  944. FUNCTION(vfe_camif_timer4_b),
  945. FUNCTION(vfe_camif_timer4_c),
  946. FUNCTION(vfe_camif_timer5_a),
  947. FUNCTION(vfe_camif_timer5_b),
  948. FUNCTION(vfe_camif_timer6_a),
  949. FUNCTION(vfe_camif_timer6_b),
  950. FUNCTION(vfe_camif_timer6_c),
  951. FUNCTION(vfe_camif_timer7_a),
  952. FUNCTION(vfe_camif_timer7_b),
  953. FUNCTION(vfe_camif_timer7_c),
  954. FUNCTION(wlan),
  955. };
  956. static const struct msm_pingroup msm8960_groups[] = {
  957. PINGROUP(0, mdp_vsync, vfe_camif_timer6_b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  958. PINGROUP(1, mdp_vsync, vfe_camif_timer7_b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  959. PINGROUP(2, vfe_camif_timer1_a, gp_mn, NA, cam_mclk2, NA, NA, NA, NA, NA, NA, NA),
  960. PINGROUP(3, vfe_camif_timer2, gp_clk_0a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  961. PINGROUP(4, vfe_camif_timer3_a, cam_mclk1, gp_clk_1a, pmb_ext_ctrl, NA, NA, NA, NA, NA, NA, NA),
  962. PINGROUP(5, cam_mclk0, pmb_ext_ctrl, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  963. PINGROUP(6, gsbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  964. PINGROUP(7, gsbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  965. PINGROUP(8, gsbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  966. PINGROUP(9, gsbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  967. PINGROUP(10, gsbi2, ssbi_ts, NA, vfe_camif_timer4_c, NA, NA, NA, NA, NA, NA, NA),
  968. PINGROUP(11, gsbi2, ts_eoc, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  969. PINGROUP(12, gsbi2, rpm_wdog, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  970. PINGROUP(13, gsbi2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  971. PINGROUP(14, gsbi3, gsbi1_spi_cs1_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  972. PINGROUP(15, gsbi3, gsbi1_spi_cs2a_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  973. PINGROUP(16, gsbi3, gsbi1_spi_cs3_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  974. PINGROUP(17, gsbi3, gsbi1_spi_cs2b_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  975. PINGROUP(18, gsbi4, gsbi11_spi_cs1b_n, NA, NA, gsbi4_3d_cam_i2c_l, vfe_camif_timer6_c, NA, NA, NA, NA, NA),
  976. PINGROUP(19, gsbi4, gsbi11_spi_cs2b_n, NA, mdp_vsync, NA, gsbi4_3d_cam_i2c_l, vfe_camif_timer7_c, NA, NA, NA, NA),
  977. PINGROUP(20, gsbi4, gsbi4_3d_cam_i2c_r, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  978. PINGROUP(21, gsbi4, pmb_clk, gsbi4_3d_cam_i2c_r, NA, NA, NA, NA, NA, NA, NA, NA),
  979. PINGROUP(22, gsbi5, ext_gps, NA, NA, NA, NA, NA, NA, NA, gsbi5_3d_cam_i2c_l, NA),
  980. PINGROUP(23, gsbi5, ssbi_ext_gps, NA, NA, NA, NA, NA, NA, NA, gsbi5_3d_cam_i2c_l, NA),
  981. PINGROUP(24, gsbi5, ext_gps, NA, NA, NA, NA, NA, NA, NA, gsbi5_3d_cam_i2c_r, NA),
  982. PINGROUP(25, gsbi5, ext_gps, NA, NA, NA, NA, NA, NA, NA, gsbi5_3d_cam_i2c_r, NA),
  983. PINGROUP(26, fm, gsbi6, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  984. PINGROUP(27, fm, gsbi6, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  985. PINGROUP(28, bt, gsbi6, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  986. PINGROUP(29, bt, gsbi6, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  987. PINGROUP(30, gsbi7, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  988. PINGROUP(31, gsbi7, usb_fs1_oe, usb_fs1_oe_n, NA, NA, NA, NA, NA, NA, NA, NA),
  989. PINGROUP(32, gsbi7, usb_fs1, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  990. PINGROUP(33, gsbi7, usb_fs1, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  991. PINGROUP(34, gsbi8, usb_fs2, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  992. PINGROUP(35, gsbi8, usb_fs2, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  993. PINGROUP(36, gsbi8, usb_fs2_oe, usb_fs2_oe_n, gsbi11_spi_cs1a_n, NA, NA, NA, NA, NA, NA, NA),
  994. PINGROUP(37, gsbi8, gps_pps_out, gps_pps_in, gsbi11_spi_cs2a_n, gp_clk_2b, NA, NA, NA, NA, NA, NA),
  995. PINGROUP(38, gsbi11, NA, NA, NA, NA, NA, NA, NA, NA, vfe_camif_timer1_b, NA),
  996. PINGROUP(39, gsbi11, gp_pdm_0b, NA, NA, NA, NA, NA, NA, NA, NA, vfe_camif_timer5_b),
  997. PINGROUP(40, gsbi11, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  998. PINGROUP(41, gsbi11, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  999. PINGROUP(42, gsbi12, slimbus2, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1000. PINGROUP(43, gsbi12, slimbus2, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1001. PINGROUP(44, gsbi12, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1002. PINGROUP(45, gsbi12, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1003. PINGROUP(46, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1004. PINGROUP(47, mi2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1005. PINGROUP(48, mi2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1006. PINGROUP(49, mi2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1007. PINGROUP(50, mi2s, slimbus1, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1008. PINGROUP(51, mi2s, slimbus1, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1009. PINGROUP(52, mi2s, gp_clk_2a, gsbi2_spi_cs1_n, NA, NA, NA, NA, NA, NA, NA, NA),
  1010. PINGROUP(53, mi2s, gp_pdm_2b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1011. PINGROUP(54, codec_mic_i2s, gp_clk_0b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1012. PINGROUP(55, codec_mic_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1013. PINGROUP(56, codec_mic_i2s, gsbi2_spi_cs3_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1014. PINGROUP(57, codec_mic_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1015. PINGROUP(58, codec_mic_i2s, gp_pdm_0a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1016. PINGROUP(59, codec_spkr_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1017. PINGROUP(60, slimbus1, codec_spkr_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1018. PINGROUP(61, slimbus1, codec_spkr_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1019. PINGROUP(62, codec_spkr_i2s, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1020. PINGROUP(63, audio_pcm, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1021. PINGROUP(64, audio_pcm, gp_pdm_1b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1022. PINGROUP(65, audio_pcm, vfe_camif_timer4_a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1023. PINGROUP(66, audio_pcm, vfe_camif_timer5_a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1024. PINGROUP(67, spkr_i2s, vfe_camif_timer7_a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1025. PINGROUP(68, spkr_i2s, gsbi2_spi_cs2_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1026. PINGROUP(69, spkr_i2s, gp_pdm_2a, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1027. PINGROUP(70, spkr_i2s, gp_clk_1b, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1028. PINGROUP(71, mic_i2s, gsbi10, vfe_camif_timer6_a, NA, NA, NA, NA, NA, NA, NA, NA),
  1029. PINGROUP(72, mic_i2s, gsbi10, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1030. PINGROUP(73, mic_i2s, gsbi10, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1031. PINGROUP(74, mic_i2s, gsbi10, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1032. PINGROUP(75, tsif1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1033. PINGROUP(76, tsif1, gsbi11_spi_cs3_n, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1034. PINGROUP(77, tsif1, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1035. PINGROUP(78, tsif2, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1036. PINGROUP(79, tsif2, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1037. PINGROUP(80, tsif2, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1038. PINGROUP(81, tsif2, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1039. PINGROUP(82, tsif1, sdc5, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1040. PINGROUP(83, bt, sdc4, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1041. PINGROUP(84, wlan, sdc4, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1042. PINGROUP(85, wlan, sdc4, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1043. PINGROUP(86, wlan, sdc4, pmb_clk, NA, NA, NA, NA, NA, NA, NA, NA),
  1044. PINGROUP(87, wlan, sdc4, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1045. PINGROUP(88, wlan, sdc4, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1046. PINGROUP(89, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1047. PINGROUP(90, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1048. PINGROUP(91, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1049. PINGROUP(92, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1050. PINGROUP(93, sdc2, gsbi9, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1051. PINGROUP(94, sdc2, gsbi9, gp_pdm_1a, NA, NA, NA, NA, NA, NA, NA, NA),
  1052. PINGROUP(95, sdc2, gsbi9, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1053. PINGROUP(96, sdc2, gsbi9, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1054. PINGROUP(97, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1055. PINGROUP(98, sdc2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1056. PINGROUP(99, hdmi_cec, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1057. PINGROUP(100, hdmi_ddc_clock, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1058. PINGROUP(101, hdmi_ddc_data, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1059. PINGROUP(102, hdmi_hot_plug_detect, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1060. PINGROUP(103, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1061. PINGROUP(104, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1062. PINGROUP(105, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1063. PINGROUP(106, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1064. PINGROUP(107, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1065. PINGROUP(108, ps_hold, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1066. PINGROUP(109, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1067. PINGROUP(110, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1068. PINGROUP(111, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1069. PINGROUP(112, NA, pmb_clk, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1070. PINGROUP(113, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1071. PINGROUP(114, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1072. PINGROUP(115, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1073. PINGROUP(116, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1074. PINGROUP(117, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1075. PINGROUP(118, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1076. PINGROUP(119, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1077. PINGROUP(120, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1078. PINGROUP(121, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1079. PINGROUP(122, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1080. PINGROUP(123, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1081. PINGROUP(124, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1082. PINGROUP(125, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1083. PINGROUP(126, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1084. PINGROUP(127, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1085. PINGROUP(128, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1086. PINGROUP(129, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1087. PINGROUP(130, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1088. PINGROUP(131, NA, ssbi_qpa1, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1089. PINGROUP(132, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1090. PINGROUP(133, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1091. PINGROUP(134, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1092. PINGROUP(135, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1093. PINGROUP(136, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1094. PINGROUP(137, gps_blanking, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1095. PINGROUP(138, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1096. PINGROUP(139, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1097. PINGROUP(140, ssbi2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1098. PINGROUP(141, ssbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1099. PINGROUP(142, ssbi2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1100. PINGROUP(143, ssbi1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1101. PINGROUP(144, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1102. PINGROUP(145, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1103. PINGROUP(146, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1104. PINGROUP(147, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1105. PINGROUP(148, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1106. PINGROUP(149, ssbi_pmic2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
  1107. PINGROUP(150, hsic, NA, vfe_camif_timer4_b, NA, NA, NA, NA, NA, NA, NA, NA),
  1108. PINGROUP(151, hsic, NA, vfe_camif_timer3_b, NA, NA, NA, NA, NA, NA, NA, NA),
  1109. SDC_PINGROUP(sdc1_clk, 0x20a0, 13, 6),
  1110. SDC_PINGROUP(sdc1_cmd, 0x20a0, 11, 3),
  1111. SDC_PINGROUP(sdc1_data, 0x20a0, 9, 0),
  1112. SDC_PINGROUP(sdc3_clk, 0x20a4, 14, 6),
  1113. SDC_PINGROUP(sdc3_cmd, 0x20a4, 11, 3),
  1114. SDC_PINGROUP(sdc3_data, 0x20a4, 9, 0),
  1115. };
  1116. #define NUM_GPIO_PINGROUPS 152
  1117. static const struct msm_pinctrl_soc_data msm8960_pinctrl = {
  1118. .pins = msm8960_pins,
  1119. .npins = ARRAY_SIZE(msm8960_pins),
  1120. .functions = msm8960_functions,
  1121. .nfunctions = ARRAY_SIZE(msm8960_functions),
  1122. .groups = msm8960_groups,
  1123. .ngroups = ARRAY_SIZE(msm8960_groups),
  1124. .ngpios = NUM_GPIO_PINGROUPS,
  1125. };
  1126. static int msm8960_pinctrl_probe(struct platform_device *pdev)
  1127. {
  1128. return msm_pinctrl_probe(pdev, &msm8960_pinctrl);
  1129. }
  1130. static const struct of_device_id msm8960_pinctrl_of_match[] = {
  1131. { .compatible = "qcom,msm8960-pinctrl", },
  1132. { },
  1133. };
  1134. static struct platform_driver msm8960_pinctrl_driver = {
  1135. .driver = {
  1136. .name = "msm8960-pinctrl",
  1137. .owner = THIS_MODULE,
  1138. .of_match_table = msm8960_pinctrl_of_match,
  1139. },
  1140. .probe = msm8960_pinctrl_probe,
  1141. .remove = msm_pinctrl_remove,
  1142. };
  1143. static int __init msm8960_pinctrl_init(void)
  1144. {
  1145. return platform_driver_register(&msm8960_pinctrl_driver);
  1146. }
  1147. arch_initcall(msm8960_pinctrl_init);
  1148. static void __exit msm8960_pinctrl_exit(void)
  1149. {
  1150. platform_driver_unregister(&msm8960_pinctrl_driver);
  1151. }
  1152. module_exit(msm8960_pinctrl_exit);
  1153. MODULE_AUTHOR("Bjorn Andersson <bjorn.andersson@sonymobile.com>");
  1154. MODULE_DESCRIPTION("Qualcomm MSM8960 pinctrl driver");
  1155. MODULE_LICENSE("GPL v2");
  1156. MODULE_DEVICE_TABLE(of, msm8960_pinctrl_of_match);