162306a36Sopenharmony_ci/* 262306a36Sopenharmony_ci * Copyright 2017 - Alexandre Torgue <alexandre.torgue@st.com> 362306a36Sopenharmony_ci * 462306a36Sopenharmony_ci * This file is dual-licensed: you can use it either under the terms 562306a36Sopenharmony_ci * of the GPL or the X11 license, at your option. Note that this dual 662306a36Sopenharmony_ci * licensing only applies to this file, and not this project as a 762306a36Sopenharmony_ci * whole. 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * a) This file is free software; you can redistribute it and/or 1062306a36Sopenharmony_ci * modify it under the terms of the GNU General Public License as 1162306a36Sopenharmony_ci * published by the Free Software Foundation; either version 2 of the 1262306a36Sopenharmony_ci * License, or (at your option) any later version. 1362306a36Sopenharmony_ci * 1462306a36Sopenharmony_ci * This file is distributed in the hope that it will be useful, 1562306a36Sopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 1662306a36Sopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1762306a36Sopenharmony_ci * GNU General Public License for more details. 1862306a36Sopenharmony_ci * 1962306a36Sopenharmony_ci * Or, alternatively, 2062306a36Sopenharmony_ci * 2162306a36Sopenharmony_ci * b) Permission is hereby granted, free of charge, to any person 2262306a36Sopenharmony_ci * obtaining a copy of this software and associated documentation 2362306a36Sopenharmony_ci * files (the "Software"), to deal in the Software without 2462306a36Sopenharmony_ci * restriction, including without limitation the rights to use, 2562306a36Sopenharmony_ci * copy, modify, merge, publish, distribute, sublicense, and/or 2662306a36Sopenharmony_ci * sell copies of the Software, and to permit persons to whom the 2762306a36Sopenharmony_ci * Software is furnished to do so, subject to the following 2862306a36Sopenharmony_ci * conditions: 2962306a36Sopenharmony_ci * 3062306a36Sopenharmony_ci * The above copyright notice and this permission notice shall be 3162306a36Sopenharmony_ci * included in all copies or substantial portions of the Software. 3262306a36Sopenharmony_ci * 3362306a36Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 3462306a36Sopenharmony_ci * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 3562306a36Sopenharmony_ci * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 3662306a36Sopenharmony_ci * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 3762306a36Sopenharmony_ci * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 3862306a36Sopenharmony_ci * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 3962306a36Sopenharmony_ci * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 4062306a36Sopenharmony_ci * OTHER DEALINGS IN THE SOFTWARE. 4162306a36Sopenharmony_ci */ 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci#include <dt-bindings/pinctrl/stm32-pinfunc.h> 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci&pinctrl { 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci i2c1_pins_a: i2c1-0 { 4862306a36Sopenharmony_ci pins { 4962306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 6, AF4)>, /* I2C1_SCL */ 5062306a36Sopenharmony_ci <STM32_PINMUX('B', 7, AF4)>; /* I2C1_SDA */ 5162306a36Sopenharmony_ci bias-disable; 5262306a36Sopenharmony_ci drive-open-drain; 5362306a36Sopenharmony_ci slew-rate = <0>; 5462306a36Sopenharmony_ci }; 5562306a36Sopenharmony_ci }; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci ethernet_rmii: rmii-0 { 5862306a36Sopenharmony_ci pins { 5962306a36Sopenharmony_ci pinmux = <STM32_PINMUX('G', 11, AF11)>, 6062306a36Sopenharmony_ci <STM32_PINMUX('G', 13, AF11)>, 6162306a36Sopenharmony_ci <STM32_PINMUX('G', 12, AF11)>, 6262306a36Sopenharmony_ci <STM32_PINMUX('C', 4, AF11)>, 6362306a36Sopenharmony_ci <STM32_PINMUX('C', 5, AF11)>, 6462306a36Sopenharmony_ci <STM32_PINMUX('A', 7, AF11)>, 6562306a36Sopenharmony_ci <STM32_PINMUX('C', 1, AF11)>, 6662306a36Sopenharmony_ci <STM32_PINMUX('A', 2, AF11)>, 6762306a36Sopenharmony_ci <STM32_PINMUX('A', 1, AF11)>; 6862306a36Sopenharmony_ci slew-rate = <2>; 6962306a36Sopenharmony_ci }; 7062306a36Sopenharmony_ci }; 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_ci sdmmc1_b4_pins_a: sdmmc1-b4-0 { 7362306a36Sopenharmony_ci pins { 7462306a36Sopenharmony_ci pinmux = <STM32_PINMUX('C', 8, AF12)>, /* SDMMC1_D0 */ 7562306a36Sopenharmony_ci <STM32_PINMUX('C', 9, AF12)>, /* SDMMC1_D1 */ 7662306a36Sopenharmony_ci <STM32_PINMUX('C', 10, AF12)>, /* SDMMC1_D2 */ 7762306a36Sopenharmony_ci <STM32_PINMUX('C', 11, AF12)>, /* SDMMC1_D3 */ 7862306a36Sopenharmony_ci <STM32_PINMUX('C', 12, AF12)>, /* SDMMC1_CK */ 7962306a36Sopenharmony_ci <STM32_PINMUX('D', 2, AF12)>; /* SDMMC1_CMD */ 8062306a36Sopenharmony_ci slew-rate = <3>; 8162306a36Sopenharmony_ci drive-push-pull; 8262306a36Sopenharmony_ci bias-disable; 8362306a36Sopenharmony_ci }; 8462306a36Sopenharmony_ci }; 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci sdmmc1_b4_od_pins_a: sdmmc1-b4-od-0 { 8762306a36Sopenharmony_ci pins1 { 8862306a36Sopenharmony_ci pinmux = <STM32_PINMUX('C', 8, AF12)>, /* SDMMC1_D0 */ 8962306a36Sopenharmony_ci <STM32_PINMUX('C', 9, AF12)>, /* SDMMC1_D1 */ 9062306a36Sopenharmony_ci <STM32_PINMUX('C', 10, AF12)>, /* SDMMC1_D2 */ 9162306a36Sopenharmony_ci <STM32_PINMUX('C', 11, AF12)>, /* SDMMC1_D3 */ 9262306a36Sopenharmony_ci <STM32_PINMUX('C', 12, AF12)>; /* SDMMC1_CK */ 9362306a36Sopenharmony_ci slew-rate = <3>; 9462306a36Sopenharmony_ci drive-push-pull; 9562306a36Sopenharmony_ci bias-disable; 9662306a36Sopenharmony_ci }; 9762306a36Sopenharmony_ci pins2 { 9862306a36Sopenharmony_ci pinmux = <STM32_PINMUX('D', 2, AF12)>; /* SDMMC1_CMD */ 9962306a36Sopenharmony_ci slew-rate = <3>; 10062306a36Sopenharmony_ci drive-open-drain; 10162306a36Sopenharmony_ci bias-disable; 10262306a36Sopenharmony_ci }; 10362306a36Sopenharmony_ci }; 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci sdmmc1_b4_sleep_pins_a: sdmmc1-b4-sleep-0 { 10662306a36Sopenharmony_ci pins { 10762306a36Sopenharmony_ci pinmux = <STM32_PINMUX('C', 8, ANALOG)>, /* SDMMC1_D0 */ 10862306a36Sopenharmony_ci <STM32_PINMUX('C', 9, ANALOG)>, /* SDMMC1_D1 */ 10962306a36Sopenharmony_ci <STM32_PINMUX('C', 10, ANALOG)>, /* SDMMC1_D2 */ 11062306a36Sopenharmony_ci <STM32_PINMUX('C', 11, ANALOG)>, /* SDMMC1_D3 */ 11162306a36Sopenharmony_ci <STM32_PINMUX('C', 12, ANALOG)>, /* SDMMC1_CK */ 11262306a36Sopenharmony_ci <STM32_PINMUX('D', 2, ANALOG)>; /* SDMMC1_CMD */ 11362306a36Sopenharmony_ci }; 11462306a36Sopenharmony_ci }; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_ci sdmmc1_dir_pins_a: sdmmc1-dir-0 { 11762306a36Sopenharmony_ci pins1 { 11862306a36Sopenharmony_ci pinmux = <STM32_PINMUX('C', 6, AF8)>, /* SDMMC1_D0DIR */ 11962306a36Sopenharmony_ci <STM32_PINMUX('C', 7, AF8)>, /* SDMMC1_D123DIR */ 12062306a36Sopenharmony_ci <STM32_PINMUX('B', 9, AF7)>; /* SDMMC1_CDIR */ 12162306a36Sopenharmony_ci slew-rate = <3>; 12262306a36Sopenharmony_ci drive-push-pull; 12362306a36Sopenharmony_ci bias-pull-up; 12462306a36Sopenharmony_ci }; 12562306a36Sopenharmony_ci pins2 { 12662306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 8, AF7)>; /* SDMMC1_CKIN */ 12762306a36Sopenharmony_ci bias-pull-up; 12862306a36Sopenharmony_ci }; 12962306a36Sopenharmony_ci }; 13062306a36Sopenharmony_ci 13162306a36Sopenharmony_ci sdmmc1_dir_sleep_pins_a: sdmmc1-dir-sleep-0 { 13262306a36Sopenharmony_ci pins { 13362306a36Sopenharmony_ci pinmux = <STM32_PINMUX('C', 6, ANALOG)>, /* SDMMC1_D0DIR */ 13462306a36Sopenharmony_ci <STM32_PINMUX('C', 7, ANALOG)>, /* SDMMC1_D123DIR */ 13562306a36Sopenharmony_ci <STM32_PINMUX('B', 9, ANALOG)>, /* SDMMC1_CDIR */ 13662306a36Sopenharmony_ci <STM32_PINMUX('B', 8, ANALOG)>; /* SDMMC1_CKIN */ 13762306a36Sopenharmony_ci }; 13862306a36Sopenharmony_ci }; 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci sdmmc2_b4_pins_a: sdmmc2-b4-0 { 14162306a36Sopenharmony_ci pins { 14262306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 14, AF9)>, /* SDMMC1_D0 */ 14362306a36Sopenharmony_ci <STM32_PINMUX('B', 15, AF9)>, /* SDMMC1_D1 */ 14462306a36Sopenharmony_ci <STM32_PINMUX('B', 3, AF9)>, /* SDMMC1_D2 */ 14562306a36Sopenharmony_ci <STM32_PINMUX('B', 4, AF9)>, /* SDMMC1_D3 */ 14662306a36Sopenharmony_ci <STM32_PINMUX('D', 6, AF11)>, /* SDMMC1_CK */ 14762306a36Sopenharmony_ci <STM32_PINMUX('D', 7, AF11)>; /* SDMMC1_CMD */ 14862306a36Sopenharmony_ci slew-rate = <3>; 14962306a36Sopenharmony_ci drive-push-pull; 15062306a36Sopenharmony_ci bias-disable; 15162306a36Sopenharmony_ci }; 15262306a36Sopenharmony_ci }; 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci sdmmc2_b4_od_pins_a: sdmmc2-b4-od-0 { 15562306a36Sopenharmony_ci pins1 { 15662306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 14, AF9)>, /* SDMMC2_D0 */ 15762306a36Sopenharmony_ci <STM32_PINMUX('B', 15, AF9)>, /* SDMMC1_D1 */ 15862306a36Sopenharmony_ci <STM32_PINMUX('B', 3, AF9)>, /* SDMMC1_D2 */ 15962306a36Sopenharmony_ci <STM32_PINMUX('B', 4, AF9)>, /* SDMMC1_D3 */ 16062306a36Sopenharmony_ci <STM32_PINMUX('D', 6, AF11)>; /* SDMMC1_CK */ 16162306a36Sopenharmony_ci slew-rate = <3>; 16262306a36Sopenharmony_ci drive-push-pull; 16362306a36Sopenharmony_ci bias-disable; 16462306a36Sopenharmony_ci }; 16562306a36Sopenharmony_ci pins2 { 16662306a36Sopenharmony_ci pinmux = <STM32_PINMUX('D', 7, AF11)>; /* SDMMC1_CMD */ 16762306a36Sopenharmony_ci slew-rate = <3>; 16862306a36Sopenharmony_ci drive-open-drain; 16962306a36Sopenharmony_ci bias-disable; 17062306a36Sopenharmony_ci }; 17162306a36Sopenharmony_ci }; 17262306a36Sopenharmony_ci 17362306a36Sopenharmony_ci sdmmc2_b4_sleep_pins_a: sdmmc2-b4-sleep-0 { 17462306a36Sopenharmony_ci pins { 17562306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 14, ANALOG)>, /* SDMMC1_D0 */ 17662306a36Sopenharmony_ci <STM32_PINMUX('B', 15, ANALOG)>, /* SDMMC1_D1 */ 17762306a36Sopenharmony_ci <STM32_PINMUX('B', 3, ANALOG)>, /* SDMMC1_D2 */ 17862306a36Sopenharmony_ci <STM32_PINMUX('B', 4, ANALOG)>, /* SDMMC1_D3 */ 17962306a36Sopenharmony_ci <STM32_PINMUX('D', 6, ANALOG)>, /* SDMMC1_CK */ 18062306a36Sopenharmony_ci <STM32_PINMUX('D', 7, ANALOG)>; /* SDMMC1_CMD */ 18162306a36Sopenharmony_ci }; 18262306a36Sopenharmony_ci }; 18362306a36Sopenharmony_ci 18462306a36Sopenharmony_ci spi1_pins: spi1-0 { 18562306a36Sopenharmony_ci pins1 { 18662306a36Sopenharmony_ci pinmux = <STM32_PINMUX('A', 5, AF5)>, 18762306a36Sopenharmony_ci /* SPI1_CLK */ 18862306a36Sopenharmony_ci <STM32_PINMUX('B', 5, AF5)>; 18962306a36Sopenharmony_ci /* SPI1_MOSI */ 19062306a36Sopenharmony_ci bias-disable; 19162306a36Sopenharmony_ci drive-push-pull; 19262306a36Sopenharmony_ci slew-rate = <2>; 19362306a36Sopenharmony_ci }; 19462306a36Sopenharmony_ci pins2 { 19562306a36Sopenharmony_ci pinmux = <STM32_PINMUX('G', 9, AF5)>; 19662306a36Sopenharmony_ci /* SPI1_MISO */ 19762306a36Sopenharmony_ci bias-disable; 19862306a36Sopenharmony_ci }; 19962306a36Sopenharmony_ci }; 20062306a36Sopenharmony_ci 20162306a36Sopenharmony_ci uart4_pins: uart4-0 { 20262306a36Sopenharmony_ci pins1 { 20362306a36Sopenharmony_ci pinmux = <STM32_PINMUX('A', 0, AF8)>; /* UART4_TX */ 20462306a36Sopenharmony_ci bias-disable; 20562306a36Sopenharmony_ci drive-push-pull; 20662306a36Sopenharmony_ci slew-rate = <0>; 20762306a36Sopenharmony_ci }; 20862306a36Sopenharmony_ci pins2 { 20962306a36Sopenharmony_ci pinmux = <STM32_PINMUX('I', 9, AF8)>; /* UART4_RX */ 21062306a36Sopenharmony_ci bias-disable; 21162306a36Sopenharmony_ci }; 21262306a36Sopenharmony_ci }; 21362306a36Sopenharmony_ci 21462306a36Sopenharmony_ci usart1_pins: usart1-0 { 21562306a36Sopenharmony_ci pins1 { 21662306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 14, AF4)>; /* USART1_TX */ 21762306a36Sopenharmony_ci bias-disable; 21862306a36Sopenharmony_ci drive-push-pull; 21962306a36Sopenharmony_ci slew-rate = <0>; 22062306a36Sopenharmony_ci }; 22162306a36Sopenharmony_ci pins2 { 22262306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 15, AF4)>; /* USART1_RX */ 22362306a36Sopenharmony_ci bias-disable; 22462306a36Sopenharmony_ci }; 22562306a36Sopenharmony_ci }; 22662306a36Sopenharmony_ci 22762306a36Sopenharmony_ci usart2_pins: usart2-0 { 22862306a36Sopenharmony_ci pins1 { 22962306a36Sopenharmony_ci pinmux = <STM32_PINMUX('D', 5, AF7)>; /* USART2_TX */ 23062306a36Sopenharmony_ci bias-disable; 23162306a36Sopenharmony_ci drive-push-pull; 23262306a36Sopenharmony_ci slew-rate = <0>; 23362306a36Sopenharmony_ci }; 23462306a36Sopenharmony_ci pins2 { 23562306a36Sopenharmony_ci pinmux = <STM32_PINMUX('D', 6, AF7)>; /* USART2_RX */ 23662306a36Sopenharmony_ci bias-disable; 23762306a36Sopenharmony_ci }; 23862306a36Sopenharmony_ci }; 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_ci usart3_pins: usart3-0 { 24162306a36Sopenharmony_ci pins1 { 24262306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 10, AF7)>, /* USART3_TX */ 24362306a36Sopenharmony_ci <STM32_PINMUX('D', 12, AF7)>; /* USART3_RTS_DE */ 24462306a36Sopenharmony_ci bias-disable; 24562306a36Sopenharmony_ci drive-push-pull; 24662306a36Sopenharmony_ci slew-rate = <0>; 24762306a36Sopenharmony_ci }; 24862306a36Sopenharmony_ci pins2 { 24962306a36Sopenharmony_ci pinmux = <STM32_PINMUX('B', 11, AF7)>, /* USART3_RX */ 25062306a36Sopenharmony_ci <STM32_PINMUX('D', 11, AF7)>; /* USART3_CTS_NSS */ 25162306a36Sopenharmony_ci bias-disable; 25262306a36Sopenharmony_ci }; 25362306a36Sopenharmony_ci }; 25462306a36Sopenharmony_ci 25562306a36Sopenharmony_ci usbotg_hs_pins_a: usbotg-hs-0 { 25662306a36Sopenharmony_ci pins { 25762306a36Sopenharmony_ci pinmux = <STM32_PINMUX('H', 4, AF10)>, /* ULPI_NXT */ 25862306a36Sopenharmony_ci <STM32_PINMUX('I', 11, AF10)>, /* ULPI_DIR> */ 25962306a36Sopenharmony_ci <STM32_PINMUX('C', 0, AF10)>, /* ULPI_STP> */ 26062306a36Sopenharmony_ci <STM32_PINMUX('A', 5, AF10)>, /* ULPI_CK> */ 26162306a36Sopenharmony_ci <STM32_PINMUX('A', 3, AF10)>, /* ULPI_D0> */ 26262306a36Sopenharmony_ci <STM32_PINMUX('B', 0, AF10)>, /* ULPI_D1> */ 26362306a36Sopenharmony_ci <STM32_PINMUX('B', 1, AF10)>, /* ULPI_D2> */ 26462306a36Sopenharmony_ci <STM32_PINMUX('B', 10, AF10)>, /* ULPI_D3> */ 26562306a36Sopenharmony_ci <STM32_PINMUX('B', 11, AF10)>, /* ULPI_D4> */ 26662306a36Sopenharmony_ci <STM32_PINMUX('B', 12, AF10)>, /* ULPI_D5> */ 26762306a36Sopenharmony_ci <STM32_PINMUX('B', 13, AF10)>, /* ULPI_D6> */ 26862306a36Sopenharmony_ci <STM32_PINMUX('B', 5, AF10)>; /* ULPI_D7> */ 26962306a36Sopenharmony_ci bias-disable; 27062306a36Sopenharmony_ci drive-push-pull; 27162306a36Sopenharmony_ci slew-rate = <2>; 27262306a36Sopenharmony_ci }; 27362306a36Sopenharmony_ci }; 27462306a36Sopenharmony_ci}; 27562306a36Sopenharmony_ci 276