stih407-pinctrl.dtsi 31 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2014 STMicroelectronics Limited.
  4. * Author: Giuseppe Cavallaro <[email protected]>
  5. */
  6. #include "st-pincfg.h"
  7. #include <dt-bindings/interrupt-controller/arm-gic.h>
  8. / {
  9. aliases {
  10. /* 0-5: PIO_SBC */
  11. gpio0 = &pio0;
  12. gpio1 = &pio1;
  13. gpio2 = &pio2;
  14. gpio3 = &pio3;
  15. gpio4 = &pio4;
  16. gpio5 = &pio5;
  17. /* 10-19: PIO_FRONT0 */
  18. gpio6 = &pio10;
  19. gpio7 = &pio11;
  20. gpio8 = &pio12;
  21. gpio9 = &pio13;
  22. gpio10 = &pio14;
  23. gpio11 = &pio15;
  24. gpio12 = &pio16;
  25. gpio13 = &pio17;
  26. gpio14 = &pio18;
  27. gpio15 = &pio19;
  28. /* 20: PIO_FRONT1 */
  29. gpio16 = &pio20;
  30. /* 30-35: PIO_REAR */
  31. gpio17 = &pio30;
  32. gpio18 = &pio31;
  33. gpio19 = &pio32;
  34. gpio20 = &pio33;
  35. gpio21 = &pio34;
  36. gpio22 = &pio35;
  37. /* 40-42: PIO_FLASH */
  38. gpio23 = &pio40;
  39. gpio24 = &pio41;
  40. gpio25 = &pio42;
  41. };
  42. soc {
  43. pin-controller-sbc@961f080 {
  44. #address-cells = <1>;
  45. #size-cells = <1>;
  46. compatible = "st,stih407-sbc-pinctrl";
  47. st,syscfg = <&syscfg_sbc>;
  48. reg = <0x0961f080 0x4>;
  49. reg-names = "irqmux";
  50. interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>;
  51. interrupt-names = "irqmux";
  52. ranges = <0 0x09610000 0x6000>;
  53. pio0: gpio@9610000 {
  54. gpio-controller;
  55. #gpio-cells = <2>;
  56. interrupt-controller;
  57. #interrupt-cells = <2>;
  58. reg = <0x0 0x100>;
  59. st,bank-name = "PIO0";
  60. };
  61. pio1: gpio@9611000 {
  62. gpio-controller;
  63. #gpio-cells = <2>;
  64. interrupt-controller;
  65. #interrupt-cells = <2>;
  66. reg = <0x1000 0x100>;
  67. st,bank-name = "PIO1";
  68. };
  69. pio2: gpio@9612000 {
  70. gpio-controller;
  71. #gpio-cells = <2>;
  72. interrupt-controller;
  73. #interrupt-cells = <2>;
  74. reg = <0x2000 0x100>;
  75. st,bank-name = "PIO2";
  76. };
  77. pio3: gpio@9613000 {
  78. gpio-controller;
  79. #gpio-cells = <2>;
  80. interrupt-controller;
  81. #interrupt-cells = <2>;
  82. reg = <0x3000 0x100>;
  83. st,bank-name = "PIO3";
  84. };
  85. pio4: gpio@9614000 {
  86. gpio-controller;
  87. #gpio-cells = <2>;
  88. interrupt-controller;
  89. #interrupt-cells = <2>;
  90. reg = <0x4000 0x100>;
  91. st,bank-name = "PIO4";
  92. };
  93. pio5: gpio@9615000 {
  94. gpio-controller;
  95. #gpio-cells = <2>;
  96. interrupt-controller;
  97. #interrupt-cells = <2>;
  98. reg = <0x5000 0x100>;
  99. st,bank-name = "PIO5";
  100. st,retime-pin-mask = <0x3f>;
  101. };
  102. cec0 {
  103. pinctrl_cec0_default: cec0-default {
  104. st,pins {
  105. hdmi_cec = <&pio2 4 ALT1 BIDIR>;
  106. };
  107. };
  108. };
  109. rc {
  110. pinctrl_ir: ir0 {
  111. st,pins {
  112. ir = <&pio4 0 ALT2 IN>;
  113. };
  114. };
  115. pinctrl_uhf: uhf0 {
  116. st,pins {
  117. ir = <&pio4 1 ALT2 IN>;
  118. };
  119. };
  120. pinctrl_tx: tx0 {
  121. st,pins {
  122. tx = <&pio4 2 ALT2 OUT>;
  123. };
  124. };
  125. pinctrl_tx_od: tx_od0 {
  126. st,pins {
  127. tx_od = <&pio4 3 ALT2 OUT>;
  128. };
  129. };
  130. };
  131. /* SBC_ASC0 - UART10 */
  132. sbc_serial0 {
  133. pinctrl_sbc_serial0: sbc_serial0-0 {
  134. st,pins {
  135. tx = <&pio3 4 ALT1 OUT>;
  136. rx = <&pio3 5 ALT1 IN>;
  137. };
  138. };
  139. };
  140. /* SBC_ASC1 - UART11 */
  141. sbc_serial1 {
  142. pinctrl_sbc_serial1: sbc_serial1-0 {
  143. st,pins {
  144. tx = <&pio2 6 ALT3 OUT>;
  145. rx = <&pio2 7 ALT3 IN>;
  146. };
  147. };
  148. };
  149. i2c10 {
  150. pinctrl_i2c10_default: i2c10-default {
  151. st,pins {
  152. sda = <&pio4 6 ALT1 BIDIR>;
  153. scl = <&pio4 5 ALT1 BIDIR>;
  154. };
  155. };
  156. };
  157. i2c11 {
  158. pinctrl_i2c11_default: i2c11-default {
  159. st,pins {
  160. sda = <&pio5 1 ALT1 BIDIR>;
  161. scl = <&pio5 0 ALT1 BIDIR>;
  162. };
  163. };
  164. };
  165. keyscan {
  166. pinctrl_keyscan: keyscan {
  167. st,pins {
  168. keyin0 = <&pio4 0 ALT6 IN>;
  169. keyin1 = <&pio4 5 ALT4 IN>;
  170. keyin2 = <&pio0 4 ALT2 IN>;
  171. keyin3 = <&pio2 6 ALT2 IN>;
  172. keyout0 = <&pio4 6 ALT4 OUT>;
  173. keyout1 = <&pio1 7 ALT2 OUT>;
  174. keyout2 = <&pio0 6 ALT2 OUT>;
  175. keyout3 = <&pio2 7 ALT2 OUT>;
  176. };
  177. };
  178. };
  179. gmac1 {
  180. /*
  181. * Almost all the boards based on STiH407 SoC have an embedded
  182. * switch where the mdio/mdc have been used for managing the SMI
  183. * iface via I2C. For this reason these lines can be allocated
  184. * by using dedicated configuration (in case of there will be a
  185. * standard PHY transceiver on-board).
  186. */
  187. pinctrl_rgmii1: rgmii1-0 {
  188. st,pins {
  189. txd0 = <&pio0 0 ALT1 OUT DE_IO 0 CLK_A>;
  190. txd1 = <&pio0 1 ALT1 OUT DE_IO 0 CLK_A>;
  191. txd2 = <&pio0 2 ALT1 OUT DE_IO 0 CLK_A>;
  192. txd3 = <&pio0 3 ALT1 OUT DE_IO 0 CLK_A>;
  193. txen = <&pio0 5 ALT1 OUT DE_IO 0 CLK_A>;
  194. txclk = <&pio0 6 ALT1 IN NICLK 0 CLK_A>;
  195. rxd0 = <&pio1 4 ALT1 IN DE_IO 0 CLK_A>;
  196. rxd1 = <&pio1 5 ALT1 IN DE_IO 0 CLK_A>;
  197. rxd2 = <&pio1 6 ALT1 IN DE_IO 0 CLK_A>;
  198. rxd3 = <&pio1 7 ALT1 IN DE_IO 0 CLK_A>;
  199. rxdv = <&pio2 0 ALT1 IN DE_IO 0 CLK_A>;
  200. rxclk = <&pio2 2 ALT1 IN NICLK 0 CLK_A>;
  201. clk125 = <&pio3 7 ALT4 IN NICLK 0 CLK_A>;
  202. phyclk = <&pio2 3 ALT4 OUT NICLK 1250 CLK_B>;
  203. };
  204. };
  205. pinctrl_rgmii1_mdio: rgmii1-mdio {
  206. st,pins {
  207. mdio = <&pio1 0 ALT1 OUT BYPASS 0>;
  208. mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
  209. mdint = <&pio1 3 ALT1 IN BYPASS 0>;
  210. };
  211. };
  212. pinctrl_rgmii1_mdio_1: rgmii1-mdio-1 {
  213. st,pins {
  214. mdio = <&pio1 0 ALT1 OUT BYPASS 0>;
  215. mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
  216. };
  217. };
  218. pinctrl_mii1: mii1 {
  219. st,pins {
  220. txd0 = <&pio0 0 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  221. txd1 = <&pio0 1 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  222. txd2 = <&pio0 2 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  223. txd3 = <&pio0 3 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  224. txer = <&pio0 4 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  225. txen = <&pio0 5 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  226. txclk = <&pio0 6 ALT1 IN NICLK 0 CLK_A>;
  227. col = <&pio0 7 ALT1 IN BYPASS 1000>;
  228. mdio = <&pio1 0 ALT1 OUT BYPASS 1500>;
  229. mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
  230. crs = <&pio1 2 ALT1 IN BYPASS 1000>;
  231. mdint = <&pio1 3 ALT1 IN BYPASS 0>;
  232. rxd0 = <&pio1 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  233. rxd1 = <&pio1 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  234. rxd2 = <&pio1 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  235. rxd3 = <&pio1 7 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  236. rxdv = <&pio2 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  237. rx_er = <&pio2 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  238. rxclk = <&pio2 2 ALT1 IN NICLK 0 CLK_A>;
  239. phyclk = <&pio2 3 ALT1 OUT NICLK 0 CLK_A>;
  240. };
  241. };
  242. pinctrl_rmii1: rmii1-0 {
  243. st,pins {
  244. txd0 = <&pio0 0 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  245. txd1 = <&pio0 1 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  246. txen = <&pio0 5 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  247. mdio = <&pio1 0 ALT1 OUT BYPASS 0>;
  248. mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
  249. mdint = <&pio1 3 ALT1 IN BYPASS 0>;
  250. rxd0 = <&pio1 4 ALT1 IN SE_NICLK_IO 0 CLK_B>;
  251. rxd1 = <&pio1 5 ALT1 IN SE_NICLK_IO 0 CLK_B>;
  252. rxdv = <&pio2 0 ALT1 IN SE_NICLK_IO 0 CLK_B>;
  253. rx_er = <&pio2 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  254. };
  255. };
  256. pinctrl_rmii1_phyclk: rmii1_phyclk {
  257. st,pins {
  258. phyclk = <&pio2 3 ALT1 OUT NICLK 0 CLK_A>;
  259. };
  260. };
  261. pinctrl_rmii1_phyclk_ext: rmii1_phyclk_ext {
  262. st,pins {
  263. phyclk = <&pio2 3 ALT2 IN NICLK 0 CLK_A>;
  264. };
  265. };
  266. };
  267. pwm1 {
  268. pinctrl_pwm1_chan0_default: pwm1-0-default {
  269. st,pins {
  270. pwm-out = <&pio3 0 ALT1 OUT>;
  271. pwm-capturein = <&pio3 2 ALT1 IN>;
  272. };
  273. };
  274. pinctrl_pwm1_chan1_default: pwm1-1-default {
  275. st,pins {
  276. pwm-capturein = <&pio4 3 ALT1 IN>;
  277. pwm-out = <&pio4 4 ALT1 OUT>;
  278. };
  279. };
  280. pinctrl_pwm1_chan2_default: pwm1-2-default {
  281. st,pins {
  282. pwm-out = <&pio4 6 ALT3 OUT>;
  283. };
  284. };
  285. pinctrl_pwm1_chan3_default: pwm1-3-default {
  286. st,pins {
  287. pwm-out = <&pio4 7 ALT3 OUT>;
  288. };
  289. };
  290. };
  291. spi10 {
  292. pinctrl_spi10_default: spi10-4w-alt1-0 {
  293. st,pins {
  294. mtsr = <&pio4 6 ALT1 OUT>;
  295. mrst = <&pio4 7 ALT1 IN>;
  296. scl = <&pio4 5 ALT1 OUT>;
  297. };
  298. };
  299. pinctrl_spi10_3w_alt1_0: spi10-3w-alt1-0 {
  300. st,pins {
  301. mtsr = <&pio4 6 ALT1 BIDIR_PU>;
  302. scl = <&pio4 5 ALT1 OUT>;
  303. };
  304. };
  305. };
  306. spi11 {
  307. pinctrl_spi11_default: spi11-4w-alt2-0 {
  308. st,pins {
  309. mtsr = <&pio3 1 ALT2 OUT>;
  310. mrst = <&pio3 0 ALT2 IN>;
  311. scl = <&pio3 2 ALT2 OUT>;
  312. };
  313. };
  314. pinctrl_spi11_3w_alt2_0: spi11-3w-alt2-0 {
  315. st,pins {
  316. mtsr = <&pio3 1 ALT2 BIDIR_PU>;
  317. scl = <&pio3 2 ALT2 OUT>;
  318. };
  319. };
  320. };
  321. spi12 {
  322. pinctrl_spi12_default: spi12-4w-alt2-0 {
  323. st,pins {
  324. mtsr = <&pio3 6 ALT2 OUT>;
  325. mrst = <&pio3 4 ALT2 IN>;
  326. scl = <&pio3 7 ALT2 OUT>;
  327. };
  328. };
  329. pinctrl_spi12_3w_alt2_0: spi12-3w-alt2-0 {
  330. st,pins {
  331. mtsr = <&pio3 6 ALT2 BIDIR_PU>;
  332. scl = <&pio3 7 ALT2 OUT>;
  333. };
  334. };
  335. };
  336. };
  337. pin-controller-front0@920f080 {
  338. #address-cells = <1>;
  339. #size-cells = <1>;
  340. compatible = "st,stih407-front-pinctrl";
  341. st,syscfg = <&syscfg_front>;
  342. reg = <0x0920f080 0x4>;
  343. reg-names = "irqmux";
  344. interrupts = <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>;
  345. interrupt-names = "irqmux";
  346. ranges = <0 0x09200000 0x10000>;
  347. pio10: pio@9200000 {
  348. gpio-controller;
  349. #gpio-cells = <2>;
  350. interrupt-controller;
  351. #interrupt-cells = <2>;
  352. reg = <0x0 0x100>;
  353. st,bank-name = "PIO10";
  354. };
  355. pio11: pio@9201000 {
  356. gpio-controller;
  357. #gpio-cells = <2>;
  358. interrupt-controller;
  359. #interrupt-cells = <2>;
  360. reg = <0x1000 0x100>;
  361. st,bank-name = "PIO11";
  362. };
  363. pio12: pio@9202000 {
  364. gpio-controller;
  365. #gpio-cells = <2>;
  366. interrupt-controller;
  367. #interrupt-cells = <2>;
  368. reg = <0x2000 0x100>;
  369. st,bank-name = "PIO12";
  370. };
  371. pio13: pio@9203000 {
  372. gpio-controller;
  373. #gpio-cells = <2>;
  374. interrupt-controller;
  375. #interrupt-cells = <2>;
  376. reg = <0x3000 0x100>;
  377. st,bank-name = "PIO13";
  378. };
  379. pio14: pio@9204000 {
  380. gpio-controller;
  381. #gpio-cells = <2>;
  382. interrupt-controller;
  383. #interrupt-cells = <2>;
  384. reg = <0x4000 0x100>;
  385. st,bank-name = "PIO14";
  386. };
  387. pio15: pio@9205000 {
  388. gpio-controller;
  389. #gpio-cells = <2>;
  390. interrupt-controller;
  391. #interrupt-cells = <2>;
  392. reg = <0x5000 0x100>;
  393. st,bank-name = "PIO15";
  394. };
  395. pio16: pio@9206000 {
  396. gpio-controller;
  397. #gpio-cells = <2>;
  398. interrupt-controller;
  399. #interrupt-cells = <2>;
  400. reg = <0x6000 0x100>;
  401. st,bank-name = "PIO16";
  402. };
  403. pio17: pio@9207000 {
  404. gpio-controller;
  405. #gpio-cells = <2>;
  406. interrupt-controller;
  407. #interrupt-cells = <2>;
  408. reg = <0x7000 0x100>;
  409. st,bank-name = "PIO17";
  410. };
  411. pio18: pio@9208000 {
  412. gpio-controller;
  413. #gpio-cells = <2>;
  414. interrupt-controller;
  415. #interrupt-cells = <2>;
  416. reg = <0x8000 0x100>;
  417. st,bank-name = "PIO18";
  418. };
  419. pio19: pio@9209000 {
  420. gpio-controller;
  421. #gpio-cells = <2>;
  422. interrupt-controller;
  423. #interrupt-cells = <2>;
  424. reg = <0x9000 0x100>;
  425. st,bank-name = "PIO19";
  426. };
  427. /* Comms */
  428. serial0 {
  429. pinctrl_serial0: serial0-0 {
  430. st,pins {
  431. tx = <&pio17 0 ALT1 OUT>;
  432. rx = <&pio17 1 ALT1 IN>;
  433. };
  434. };
  435. pinctrl_serial0_hw_flowctrl: serial0-0_hw_flowctrl {
  436. st,pins {
  437. tx = <&pio17 0 ALT1 OUT>;
  438. rx = <&pio17 1 ALT1 IN>;
  439. cts = <&pio17 2 ALT1 IN>;
  440. rts = <&pio17 3 ALT1 OUT>;
  441. };
  442. };
  443. };
  444. serial1 {
  445. pinctrl_serial1: serial1-0 {
  446. st,pins {
  447. tx = <&pio16 0 ALT1 OUT>;
  448. rx = <&pio16 1 ALT1 IN>;
  449. };
  450. };
  451. };
  452. serial2 {
  453. pinctrl_serial2: serial2-0 {
  454. st,pins {
  455. tx = <&pio15 0 ALT1 OUT>;
  456. rx = <&pio15 1 ALT1 IN>;
  457. };
  458. };
  459. };
  460. mmc1 {
  461. pinctrl_sd1: sd1-0 {
  462. st,pins {
  463. sd_clk = <&pio19 3 ALT5 BIDIR NICLK 0 CLK_B>;
  464. sd_cmd = <&pio19 2 ALT5 BIDIR_PU BYPASS 0>;
  465. sd_dat0 = <&pio19 4 ALT5 BIDIR_PU BYPASS 0>;
  466. sd_dat1 = <&pio19 5 ALT5 BIDIR_PU BYPASS 0>;
  467. sd_dat2 = <&pio19 6 ALT5 BIDIR_PU BYPASS 0>;
  468. sd_dat3 = <&pio19 7 ALT5 BIDIR_PU BYPASS 0>;
  469. sd_led = <&pio16 6 ALT6 OUT>;
  470. sd_pwren = <&pio16 7 ALT6 OUT>;
  471. sd_cd = <&pio19 0 ALT6 IN>;
  472. sd_wp = <&pio19 1 ALT6 IN>;
  473. };
  474. };
  475. };
  476. i2c0 {
  477. pinctrl_i2c0_default: i2c0-default {
  478. st,pins {
  479. sda = <&pio10 6 ALT2 BIDIR>;
  480. scl = <&pio10 5 ALT2 BIDIR>;
  481. };
  482. };
  483. };
  484. i2c1 {
  485. pinctrl_i2c1_default: i2c1-default {
  486. st,pins {
  487. sda = <&pio11 1 ALT2 BIDIR>;
  488. scl = <&pio11 0 ALT2 BIDIR>;
  489. };
  490. };
  491. };
  492. i2c2 {
  493. pinctrl_i2c2_default: i2c2-default {
  494. st,pins {
  495. sda = <&pio15 6 ALT2 BIDIR>;
  496. scl = <&pio15 5 ALT2 BIDIR>;
  497. };
  498. };
  499. pinctrl_i2c2_alt2_1: i2c2-alt2-1 {
  500. st,pins {
  501. sda = <&pio12 6 ALT2 BIDIR>;
  502. scl = <&pio12 5 ALT2 BIDIR>;
  503. };
  504. };
  505. };
  506. i2c3 {
  507. pinctrl_i2c3_default: i2c3-alt1-0 {
  508. st,pins {
  509. sda = <&pio18 6 ALT1 BIDIR>;
  510. scl = <&pio18 5 ALT1 BIDIR>;
  511. };
  512. };
  513. pinctrl_i2c3_alt1_1: i2c3-alt1-1 {
  514. st,pins {
  515. sda = <&pio17 7 ALT1 BIDIR>;
  516. scl = <&pio17 6 ALT1 BIDIR>;
  517. };
  518. };
  519. pinctrl_i2c3_alt3_0: i2c3-alt3-0 {
  520. st,pins {
  521. sda = <&pio13 6 ALT3 BIDIR>;
  522. scl = <&pio13 5 ALT3 BIDIR>;
  523. };
  524. };
  525. };
  526. spi0 {
  527. pinctrl_spi0_default: spi0-4w-alt2-0 {
  528. st,pins {
  529. mtsr = <&pio10 6 ALT2 OUT>;
  530. mrst = <&pio10 7 ALT2 IN>;
  531. scl = <&pio10 5 ALT2 OUT>;
  532. };
  533. };
  534. pinctrl_spi0_3w_alt2_0: spi0-3w-alt2-0 {
  535. st,pins {
  536. mtsr = <&pio10 6 ALT2 BIDIR_PU>;
  537. scl = <&pio10 5 ALT2 OUT>;
  538. };
  539. };
  540. pinctrl_spi0_4w_alt1_0: spi0-4w-alt1-0 {
  541. st,pins {
  542. mtsr = <&pio19 7 ALT1 OUT>;
  543. mrst = <&pio19 5 ALT1 IN>;
  544. scl = <&pio19 6 ALT1 OUT>;
  545. };
  546. };
  547. pinctrl_spi0_3w_alt1_0: spi0-3w-alt1-0 {
  548. st,pins {
  549. mtsr = <&pio19 7 ALT1 BIDIR_PU>;
  550. scl = <&pio19 6 ALT1 OUT>;
  551. };
  552. };
  553. };
  554. spi1 {
  555. pinctrl_spi1_default: spi1-4w-alt2-0 {
  556. st,pins {
  557. mtsr = <&pio11 1 ALT2 OUT>;
  558. mrst = <&pio11 2 ALT2 IN>;
  559. scl = <&pio11 0 ALT2 OUT>;
  560. };
  561. };
  562. pinctrl_spi1_3w_alt2_0: spi1-3w-alt2-0 {
  563. st,pins {
  564. mtsr = <&pio11 1 ALT2 BIDIR_PU>;
  565. scl = <&pio11 0 ALT2 OUT>;
  566. };
  567. };
  568. pinctrl_spi1_4w_alt1_0: spi1-4w-alt1-0 {
  569. st,pins {
  570. mtsr = <&pio14 3 ALT1 OUT>;
  571. mrst = <&pio14 4 ALT1 IN>;
  572. scl = <&pio14 2 ALT1 OUT>;
  573. };
  574. };
  575. pinctrl_spi1_3w_alt1_0: spi1-3w-alt1-0 {
  576. st,pins {
  577. mtsr = <&pio14 3 ALT1 BIDIR_PU>;
  578. scl = <&pio14 2 ALT1 OUT>;
  579. };
  580. };
  581. };
  582. spi2 {
  583. pinctrl_spi2_default: spi2-4w-alt2-0 {
  584. st,pins {
  585. mtsr = <&pio12 6 ALT2 OUT>;
  586. mrst = <&pio12 7 ALT2 IN>;
  587. scl = <&pio12 5 ALT2 OUT>;
  588. };
  589. };
  590. pinctrl_spi2_3w_alt2_0: spi2-3w-alt2-0 {
  591. st,pins {
  592. mtsr = <&pio12 6 ALT2 BIDIR_PU>;
  593. scl = <&pio12 5 ALT2 OUT>;
  594. };
  595. };
  596. pinctrl_spi2_4w_alt1_0: spi2-4w-alt1-0 {
  597. st,pins {
  598. mtsr = <&pio14 6 ALT1 OUT>;
  599. mrst = <&pio14 7 ALT1 IN>;
  600. scl = <&pio14 5 ALT1 OUT>;
  601. };
  602. };
  603. pinctrl_spi2_3w_alt1_0: spi2-3w-alt1-0 {
  604. st,pins {
  605. mtsr = <&pio14 6 ALT1 BIDIR_PU>;
  606. scl = <&pio14 5 ALT1 OUT>;
  607. };
  608. };
  609. pinctrl_spi2_4w_alt2_1: spi2-4w-alt2-1 {
  610. st,pins {
  611. mtsr = <&pio15 6 ALT2 OUT>;
  612. mrst = <&pio15 7 ALT2 IN>;
  613. scl = <&pio15 5 ALT2 OUT>;
  614. };
  615. };
  616. pinctrl_spi2_3w_alt2_1: spi2-3w-alt2-1 {
  617. st,pins {
  618. mtsr = <&pio15 6 ALT2 BIDIR_PU>;
  619. scl = <&pio15 5 ALT2 OUT>;
  620. };
  621. };
  622. };
  623. spi3 {
  624. pinctrl_spi3_default: spi3-4w-alt3-0 {
  625. st,pins {
  626. mtsr = <&pio13 6 ALT3 OUT>;
  627. mrst = <&pio13 7 ALT3 IN>;
  628. scl = <&pio13 5 ALT3 OUT>;
  629. };
  630. };
  631. pinctrl_spi3_3w_alt3_0: spi3-3w-alt3-0 {
  632. st,pins {
  633. mtsr = <&pio13 6 ALT3 BIDIR_PU>;
  634. scl = <&pio13 5 ALT3 OUT>;
  635. };
  636. };
  637. pinctrl_spi3_4w_alt1_0: spi3-4w-alt1-0 {
  638. st,pins {
  639. mtsr = <&pio17 7 ALT1 OUT>;
  640. mrst = <&pio17 5 ALT1 IN>;
  641. scl = <&pio17 6 ALT1 OUT>;
  642. };
  643. };
  644. pinctrl_spi3_3w_alt1_0: spi3-3w-alt1-0 {
  645. st,pins {
  646. mtsr = <&pio17 7 ALT1 BIDIR_PU>;
  647. scl = <&pio17 6 ALT1 OUT>;
  648. };
  649. };
  650. pinctrl_spi3_4w_alt1_1: spi3-4w-alt1-1 {
  651. st,pins {
  652. mtsr = <&pio18 6 ALT1 OUT>;
  653. mrst = <&pio18 7 ALT1 IN>;
  654. scl = <&pio18 5 ALT1 OUT>;
  655. };
  656. };
  657. pinctrl_spi3_3w_alt1_1: spi3-3w-alt1-1 {
  658. st,pins {
  659. mtsr = <&pio18 6 ALT1 BIDIR_PU>;
  660. scl = <&pio18 5 ALT1 OUT>;
  661. };
  662. };
  663. };
  664. tsin0 {
  665. pinctrl_tsin0_parallel: tsin0_parallel {
  666. st,pins {
  667. DATA7 = <&pio10 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  668. DATA6 = <&pio10 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  669. DATA5 = <&pio10 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  670. DATA4 = <&pio10 7 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  671. DATA3 = <&pio11 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  672. DATA2 = <&pio11 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  673. DATA1 = <&pio11 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  674. DATA0 = <&pio11 3 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  675. CLKIN = <&pio10 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  676. VALID = <&pio10 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  677. ERROR = <&pio10 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  678. PKCLK = <&pio10 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  679. };
  680. };
  681. pinctrl_tsin0_serial: tsin0_serial {
  682. st,pins {
  683. DATA7 = <&pio10 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  684. CLKIN = <&pio10 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  685. VALID = <&pio10 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  686. ERROR = <&pio10 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  687. PKCLK = <&pio10 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  688. };
  689. };
  690. };
  691. tsin1 {
  692. pinctrl_tsin1_parallel: tsin1_parallel {
  693. st,pins {
  694. DATA7 = <&pio12 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  695. DATA6 = <&pio12 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  696. DATA5 = <&pio12 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  697. DATA4 = <&pio12 3 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  698. DATA3 = <&pio12 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  699. DATA2 = <&pio12 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  700. DATA1 = <&pio12 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  701. DATA0 = <&pio12 7 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  702. CLKIN = <&pio11 7 ALT1 IN CLKNOTDATA 0 CLK_A>;
  703. VALID = <&pio11 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  704. ERROR = <&pio11 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  705. PKCLK = <&pio11 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  706. };
  707. };
  708. pinctrl_tsin1_serial: tsin1_serial {
  709. st,pins {
  710. DATA7 = <&pio12 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  711. CLKIN = <&pio11 7 ALT1 IN CLKNOTDATA 0 CLK_A>;
  712. VALID = <&pio11 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  713. ERROR = <&pio11 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  714. PKCLK = <&pio11 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  715. };
  716. };
  717. };
  718. tsin2 {
  719. pinctrl_tsin2_parallel: tsin2_parallel {
  720. st,pins {
  721. DATA7 = <&pio13 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  722. DATA6 = <&pio13 5 ALT2 IN SE_NICLK_IO 0 CLK_B>;
  723. DATA5 = <&pio13 6 ALT2 IN SE_NICLK_IO 0 CLK_B>;
  724. DATA4 = <&pio13 7 ALT2 IN SE_NICLK_IO 0 CLK_B>;
  725. DATA3 = <&pio14 0 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  726. DATA2 = <&pio14 1 ALT2 IN SE_NICLK_IO 0 CLK_B>;
  727. DATA1 = <&pio14 2 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  728. DATA0 = <&pio14 3 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  729. CLKIN = <&pio13 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  730. VALID = <&pio13 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  731. ERROR = <&pio13 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  732. PKCLK = <&pio13 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  733. };
  734. };
  735. pinctrl_tsin2_serial: tsin2_serial {
  736. st,pins {
  737. DATA7 = <&pio13 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  738. CLKIN = <&pio13 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  739. VALID = <&pio13 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  740. ERROR = <&pio13 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  741. PKCLK = <&pio13 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  742. };
  743. };
  744. };
  745. tsin3 {
  746. pinctrl_tsin3_serial: tsin3_serial {
  747. st,pins {
  748. DATA7 = <&pio14 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  749. CLKIN = <&pio14 0 ALT1 IN CLKNOTDATA 0 CLK_A>;
  750. VALID = <&pio13 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  751. ERROR = <&pio13 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  752. PKCLK = <&pio13 7 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  753. };
  754. };
  755. };
  756. tsin4 {
  757. pinctrl_tsin4_serial_alt3: tsin4_serial_alt3 {
  758. st,pins {
  759. DATA7 = <&pio14 6 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  760. CLKIN = <&pio14 5 ALT3 IN CLKNOTDATA 0 CLK_A>;
  761. VALID = <&pio14 3 ALT3 IN SE_NICLK_IO 0 CLK_B>;
  762. ERROR = <&pio14 2 ALT3 IN SE_NICLK_IO 0 CLK_B>;
  763. PKCLK = <&pio14 4 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  764. };
  765. };
  766. };
  767. tsin5 {
  768. pinctrl_tsin5_serial_alt1: tsin5_serial_alt1 {
  769. st,pins {
  770. DATA7 = <&pio18 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  771. CLKIN = <&pio18 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  772. VALID = <&pio18 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  773. ERROR = <&pio18 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  774. PKCLK = <&pio18 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  775. };
  776. };
  777. pinctrl_tsin5_serial_alt2: tsin5_serial_alt2 {
  778. st,pins {
  779. DATA7 = <&pio19 4 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  780. CLKIN = <&pio19 3 ALT2 IN CLKNOTDATA 0 CLK_A>;
  781. VALID = <&pio19 1 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  782. ERROR = <&pio19 0 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  783. PKCLK = <&pio19 2 ALT2 IN SE_NICLK_IO 0 CLK_A>;
  784. };
  785. };
  786. };
  787. tsout0 {
  788. pinctrl_tsout0_parallel: tsout0_parallel {
  789. st,pins {
  790. DATA7 = <&pio12 0 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  791. DATA6 = <&pio12 1 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  792. DATA5 = <&pio12 2 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  793. DATA4 = <&pio12 3 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  794. DATA3 = <&pio12 4 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  795. DATA2 = <&pio12 5 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  796. DATA1 = <&pio12 6 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  797. DATA0 = <&pio12 7 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  798. CLKIN = <&pio11 7 ALT3 OUT NICLK 0 CLK_A>;
  799. VALID = <&pio11 5 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  800. ERROR = <&pio11 4 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  801. PKCLK = <&pio11 6 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  802. };
  803. };
  804. pinctrl_tsout0_serial: tsout0_serial {
  805. st,pins {
  806. DATA7 = <&pio12 0 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  807. CLKIN = <&pio11 7 ALT3 OUT NICLK 0 CLK_A>;
  808. VALID = <&pio11 5 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  809. ERROR = <&pio11 4 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  810. PKCLK = <&pio11 6 ALT3 OUT SE_NICLK_IO 0 CLK_A>;
  811. };
  812. };
  813. };
  814. tsout1 {
  815. pinctrl_tsout1_serial: tsout1_serial {
  816. st,pins {
  817. DATA7 = <&pio19 4 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  818. CLKIN = <&pio19 3 ALT1 OUT NICLK 0 CLK_A>;
  819. VALID = <&pio19 1 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  820. ERROR = <&pio19 0 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  821. PKCLK = <&pio19 2 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
  822. };
  823. };
  824. };
  825. mtsin0 {
  826. pinctrl_mtsin0_parallel: mtsin0_parallel {
  827. st,pins {
  828. DATA7 = <&pio10 4 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  829. DATA6 = <&pio10 5 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  830. DATA5 = <&pio10 6 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  831. DATA4 = <&pio10 7 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  832. DATA3 = <&pio11 0 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  833. DATA2 = <&pio11 1 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  834. DATA1 = <&pio11 2 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  835. DATA0 = <&pio11 3 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  836. CLKIN = <&pio10 3 ALT3 IN CLKNOTDATA 0 CLK_A>;
  837. VALID = <&pio10 1 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  838. ERROR = <&pio10 0 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  839. PKCLK = <&pio10 2 ALT3 IN SE_NICLK_IO 0 CLK_A>;
  840. };
  841. };
  842. };
  843. systrace {
  844. pinctrl_systrace_default: systrace-default {
  845. st,pins {
  846. trc_data0 = <&pio11 3 ALT5 OUT>;
  847. trc_data1 = <&pio11 4 ALT5 OUT>;
  848. trc_data2 = <&pio11 5 ALT5 OUT>;
  849. trc_data3 = <&pio11 6 ALT5 OUT>;
  850. trc_clk = <&pio11 7 ALT5 OUT>;
  851. };
  852. };
  853. };
  854. };
  855. pin-controller-front1@921f080 {
  856. #address-cells = <1>;
  857. #size-cells = <1>;
  858. compatible = "st,stih407-front-pinctrl";
  859. st,syscfg = <&syscfg_front>;
  860. reg = <0x0921f080 0x4>;
  861. reg-names = "irqmux";
  862. interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>;
  863. interrupt-names = "irqmux";
  864. ranges = <0 0x09210000 0x10000>;
  865. pio20: pio@9210000 {
  866. gpio-controller;
  867. #gpio-cells = <2>;
  868. interrupt-controller;
  869. #interrupt-cells = <2>;
  870. reg = <0x0 0x100>;
  871. st,bank-name = "PIO20";
  872. };
  873. tsin4 {
  874. pinctrl_tsin4_serial_alt1: tsin4_serial_alt1 {
  875. st,pins {
  876. DATA7 = <&pio20 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  877. CLKIN = <&pio20 3 ALT1 IN CLKNOTDATA 0 CLK_A>;
  878. VALID = <&pio20 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  879. ERROR = <&pio20 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  880. PKCLK = <&pio20 2 ALT1 IN SE_NICLK_IO 0 CLK_A>;
  881. };
  882. };
  883. };
  884. };
  885. pin-controller-rear@922f080 {
  886. #address-cells = <1>;
  887. #size-cells = <1>;
  888. compatible = "st,stih407-rear-pinctrl";
  889. st,syscfg = <&syscfg_rear>;
  890. reg = <0x0922f080 0x4>;
  891. reg-names = "irqmux";
  892. interrupts = <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>;
  893. interrupt-names = "irqmux";
  894. ranges = <0 0x09220000 0x6000>;
  895. pio30: gpio@9220000 {
  896. gpio-controller;
  897. #gpio-cells = <2>;
  898. interrupt-controller;
  899. #interrupt-cells = <2>;
  900. reg = <0x0 0x100>;
  901. st,bank-name = "PIO30";
  902. };
  903. pio31: gpio@9221000 {
  904. gpio-controller;
  905. #gpio-cells = <2>;
  906. interrupt-controller;
  907. #interrupt-cells = <2>;
  908. reg = <0x1000 0x100>;
  909. st,bank-name = "PIO31";
  910. };
  911. pio32: gpio@9222000 {
  912. gpio-controller;
  913. #gpio-cells = <2>;
  914. interrupt-controller;
  915. #interrupt-cells = <2>;
  916. reg = <0x2000 0x100>;
  917. st,bank-name = "PIO32";
  918. };
  919. pio33: gpio@9223000 {
  920. gpio-controller;
  921. #gpio-cells = <2>;
  922. interrupt-controller;
  923. #interrupt-cells = <2>;
  924. reg = <0x3000 0x100>;
  925. st,bank-name = "PIO33";
  926. };
  927. pio34: gpio@9224000 {
  928. gpio-controller;
  929. #gpio-cells = <2>;
  930. interrupt-controller;
  931. #interrupt-cells = <2>;
  932. reg = <0x4000 0x100>;
  933. st,bank-name = "PIO34";
  934. };
  935. pio35: gpio@9225000 {
  936. gpio-controller;
  937. #gpio-cells = <2>;
  938. interrupt-controller;
  939. #interrupt-cells = <2>;
  940. reg = <0x5000 0x100>;
  941. st,bank-name = "PIO35";
  942. st,retime-pin-mask = <0x7f>;
  943. };
  944. i2c4 {
  945. pinctrl_i2c4_default: i2c4-default {
  946. st,pins {
  947. sda = <&pio30 1 ALT1 BIDIR>;
  948. scl = <&pio30 0 ALT1 BIDIR>;
  949. };
  950. };
  951. };
  952. i2c5 {
  953. pinctrl_i2c5_default: i2c5-default {
  954. st,pins {
  955. sda = <&pio34 4 ALT1 BIDIR>;
  956. scl = <&pio34 3 ALT1 BIDIR>;
  957. };
  958. };
  959. };
  960. usb3 {
  961. pinctrl_usb3: usb3-2 {
  962. st,pins {
  963. usb-oc-detect = <&pio35 4 ALT1 IN>;
  964. usb-pwr-enable = <&pio35 5 ALT1 OUT>;
  965. usb-vbus-valid = <&pio35 6 ALT1 IN>;
  966. };
  967. };
  968. };
  969. pwm0 {
  970. pinctrl_pwm0_chan0_default: pwm0-0-default {
  971. st,pins {
  972. pwm-capturein = <&pio31 0 ALT1 IN>;
  973. pwm-out = <&pio31 1 ALT1 OUT>;
  974. };
  975. };
  976. };
  977. spi4 {
  978. pinctrl_spi4_default: spi4-4w-alt1-0 {
  979. st,pins {
  980. mtsr = <&pio30 1 ALT1 OUT>;
  981. mrst = <&pio30 2 ALT1 IN>;
  982. scl = <&pio30 0 ALT1 OUT>;
  983. };
  984. };
  985. pinctrl_spi4_3w_alt1_0: spi4-3w-alt1-0 {
  986. st,pins {
  987. mtsr = <&pio30 1 ALT1 BIDIR_PU>;
  988. scl = <&pio30 0 ALT1 OUT>;
  989. };
  990. };
  991. pinctrl_spi4_4w_alt3_0: spi4-4w-alt3-0 {
  992. st,pins {
  993. mtsr = <&pio34 1 ALT3 OUT>;
  994. mrst = <&pio34 2 ALT3 IN>;
  995. scl = <&pio34 0 ALT3 OUT>;
  996. };
  997. };
  998. pinctrl_spi4_3w_alt3_0: spi4-3w-alt3-0 {
  999. st,pins {
  1000. mtsr = <&pio34 1 ALT3 BIDIR_PU>;
  1001. scl = <&pio34 0 ALT3 OUT>;
  1002. };
  1003. };
  1004. };
  1005. i2s_out {
  1006. pinctrl_i2s_8ch_out: i2s_8ch_out{
  1007. st,pins {
  1008. mclk = <&pio33 5 ALT1 OUT>;
  1009. lrclk = <&pio33 7 ALT1 OUT>;
  1010. sclk = <&pio33 6 ALT1 OUT>;
  1011. data0 = <&pio33 4 ALT1 OUT>;
  1012. data1 = <&pio34 0 ALT1 OUT>;
  1013. data2 = <&pio34 1 ALT1 OUT>;
  1014. data3 = <&pio34 2 ALT1 OUT>;
  1015. };
  1016. };
  1017. pinctrl_i2s_2ch_out: i2s_2ch_out{
  1018. st,pins {
  1019. mclk = <&pio33 5 ALT1 OUT>;
  1020. lrclk = <&pio33 7 ALT1 OUT>;
  1021. sclk = <&pio33 6 ALT1 OUT>;
  1022. data0 = <&pio33 4 ALT1 OUT>;
  1023. };
  1024. };
  1025. };
  1026. i2s_in {
  1027. pinctrl_i2s_8ch_in: i2s_8ch_in{
  1028. st,pins {
  1029. mclk = <&pio32 5 ALT1 IN>;
  1030. lrclk = <&pio32 7 ALT1 IN>;
  1031. sclk = <&pio32 6 ALT1 IN>;
  1032. data0 = <&pio32 4 ALT1 IN>;
  1033. data1 = <&pio33 0 ALT1 IN>;
  1034. data2 = <&pio33 1 ALT1 IN>;
  1035. data3 = <&pio33 2 ALT1 IN>;
  1036. data4 = <&pio33 3 ALT1 IN>;
  1037. };
  1038. };
  1039. pinctrl_i2s_2ch_in: i2s_2ch_in{
  1040. st,pins {
  1041. mclk = <&pio32 5 ALT1 IN>;
  1042. lrclk = <&pio32 7 ALT1 IN>;
  1043. sclk = <&pio32 6 ALT1 IN>;
  1044. data0 = <&pio32 4 ALT1 IN>;
  1045. };
  1046. };
  1047. };
  1048. spdif_out {
  1049. pinctrl_spdif_out: spdif_out{
  1050. st,pins {
  1051. spdif_out = <&pio34 7 ALT1 OUT>;
  1052. };
  1053. };
  1054. };
  1055. serial3 {
  1056. pinctrl_serial3: serial3-0 {
  1057. st,pins {
  1058. tx = <&pio31 3 ALT1 OUT>;
  1059. rx = <&pio31 4 ALT1 IN>;
  1060. };
  1061. };
  1062. };
  1063. };
  1064. pin-controller-flash@923f080 {
  1065. #address-cells = <1>;
  1066. #size-cells = <1>;
  1067. compatible = "st,stih407-flash-pinctrl";
  1068. st,syscfg = <&syscfg_flash>;
  1069. reg = <0x0923f080 0x4>;
  1070. reg-names = "irqmux";
  1071. interrupts = <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>;
  1072. interrupt-names = "irqmux";
  1073. ranges = <0 0x09230000 0x3000>;
  1074. pio40: gpio@9230000 {
  1075. gpio-controller;
  1076. #gpio-cells = <2>;
  1077. interrupt-controller;
  1078. #interrupt-cells = <2>;
  1079. reg = <0 0x100>;
  1080. st,bank-name = "PIO40";
  1081. };
  1082. pio41: gpio@9231000 {
  1083. gpio-controller;
  1084. #gpio-cells = <2>;
  1085. interrupt-controller;
  1086. #interrupt-cells = <2>;
  1087. reg = <0x1000 0x100>;
  1088. st,bank-name = "PIO41";
  1089. };
  1090. pio42: gpio@9232000 {
  1091. gpio-controller;
  1092. #gpio-cells = <2>;
  1093. interrupt-controller;
  1094. #interrupt-cells = <2>;
  1095. reg = <0x2000 0x100>;
  1096. st,bank-name = "PIO42";
  1097. };
  1098. mmc0 {
  1099. pinctrl_mmc0: mmc0-0 {
  1100. st,pins {
  1101. emmc_clk = <&pio40 6 ALT1 BIDIR>;
  1102. emmc_cmd = <&pio40 7 ALT1 BIDIR_PU>;
  1103. emmc_d0 = <&pio41 0 ALT1 BIDIR_PU>;
  1104. emmc_d1 = <&pio41 1 ALT1 BIDIR_PU>;
  1105. emmc_d2 = <&pio41 2 ALT1 BIDIR_PU>;
  1106. emmc_d3 = <&pio41 3 ALT1 BIDIR_PU>;
  1107. emmc_d4 = <&pio41 4 ALT1 BIDIR_PU>;
  1108. emmc_d5 = <&pio41 5 ALT1 BIDIR_PU>;
  1109. emmc_d6 = <&pio41 6 ALT1 BIDIR_PU>;
  1110. emmc_d7 = <&pio41 7 ALT1 BIDIR_PU>;
  1111. };
  1112. };
  1113. pinctrl_sd0: sd0-0 {
  1114. st,pins {
  1115. sd_clk = <&pio40 6 ALT1 BIDIR>;
  1116. sd_cmd = <&pio40 7 ALT1 BIDIR_PU>;
  1117. sd_dat0 = <&pio41 0 ALT1 BIDIR_PU>;
  1118. sd_dat1 = <&pio41 1 ALT1 BIDIR_PU>;
  1119. sd_dat2 = <&pio41 2 ALT1 BIDIR_PU>;
  1120. sd_dat3 = <&pio41 3 ALT1 BIDIR_PU>;
  1121. sd_led = <&pio42 0 ALT2 OUT>;
  1122. sd_pwren = <&pio42 2 ALT2 OUT>;
  1123. sd_vsel = <&pio42 3 ALT2 OUT>;
  1124. sd_cd = <&pio42 4 ALT2 IN>;
  1125. sd_wp = <&pio42 5 ALT2 IN>;
  1126. };
  1127. };
  1128. };
  1129. fsm {
  1130. pinctrl_fsm: fsm {
  1131. st,pins {
  1132. spi-fsm-clk = <&pio40 1 ALT1 OUT>;
  1133. spi-fsm-cs = <&pio40 0 ALT1 OUT>;
  1134. spi-fsm-mosi = <&pio40 2 ALT1 OUT>;
  1135. spi-fsm-miso = <&pio40 3 ALT1 IN>;
  1136. spi-fsm-hol = <&pio40 5 ALT1 OUT>;
  1137. spi-fsm-wp = <&pio40 4 ALT1 OUT>;
  1138. };
  1139. };
  1140. };
  1141. nand {
  1142. pinctrl_nand: nand {
  1143. st,pins {
  1144. nand_cs1 = <&pio40 6 ALT3 OUT>;
  1145. nand_cs0 = <&pio40 7 ALT3 OUT>;
  1146. nand_d0 = <&pio41 0 ALT3 BIDIR>;
  1147. nand_d1 = <&pio41 1 ALT3 BIDIR>;
  1148. nand_d2 = <&pio41 2 ALT3 BIDIR>;
  1149. nand_d3 = <&pio41 3 ALT3 BIDIR>;
  1150. nand_d4 = <&pio41 4 ALT3 BIDIR>;
  1151. nand_d5 = <&pio41 5 ALT3 BIDIR>;
  1152. nand_d6 = <&pio41 6 ALT3 BIDIR>;
  1153. nand_d7 = <&pio41 7 ALT3 BIDIR>;
  1154. nand_we = <&pio42 0 ALT3 OUT>;
  1155. nand_dqs = <&pio42 1 ALT3 OUT>;
  1156. nand_ale = <&pio42 2 ALT3 OUT>;
  1157. nand_cle = <&pio42 3 ALT3 OUT>;
  1158. nand_rnb = <&pio42 4 ALT3 IN>;
  1159. nand_oe = <&pio42 5 ALT3 OUT>;
  1160. };
  1161. };
  1162. };
  1163. };
  1164. };
  1165. };