| /* |
| * Copyright (c) 2021, Yonatan Schachter |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| #ifndef __RP2040_PINCTRL_H__ |
| #define __RP2040_PINCTRL_H__ |
| |
| #define RP2_PINCTRL_GPIO_FUNC_XIP 0 |
| #define RP2_PINCTRL_GPIO_FUNC_SPI 1 |
| #define RP2_PINCTRL_GPIO_FUNC_UART 2 |
| #define RP2_PINCTRL_GPIO_FUNC_I2C 3 |
| #define RP2_PINCTRL_GPIO_FUNC_PWM 4 |
| #define RP2_PINCTRL_GPIO_FUNC_SIO 5 |
| #define RP2_PINCTRL_GPIO_FUNC_PIO0 6 |
| #define RP2_PINCTRL_GPIO_FUNC_PIO1 7 |
| #define RP2_PINCTRL_GPIO_FUNC_GPCK 8 |
| #define RP2_PINCTRL_GPIO_FUNC_USB 9 |
| #define RP2_PINCTRL_GPIO_FUNC_NULL 0xf |
| |
| #define RP2_ALT_FUNC_POS 0 |
| #define RP2_ALT_FUNC_MASK 0xf |
| |
| #define RP2_PIN_NUM_POS 4 |
| #define RP2_PIN_NUM_MASK 0x1f |
| |
| #define RP2040_PINMUX(pin_num, alt_func) (pin_num << RP2_PIN_NUM_POS | \ |
| alt_func << RP2_ALT_FUNC_POS) |
| |
| #define UART0_TX_P0 RP2040_PINMUX(0, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RX_P1 RP2040_PINMUX(1, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_CTS_P2 RP2040_PINMUX(2, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RTS_P3 RP2040_PINMUX(3, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_TX_P4 RP2040_PINMUX(4, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RX_P5 RP2040_PINMUX(5, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_CTS_P6 RP2040_PINMUX(6, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RTS_P7 RP2040_PINMUX(7, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_TX_P8 RP2040_PINMUX(8, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RX_P9 RP2040_PINMUX(9, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_CTS_P10 RP2040_PINMUX(10, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RTS_P11 RP2040_PINMUX(11, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_TX_P12 RP2040_PINMUX(12, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RX_P13 RP2040_PINMUX(13, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_CTS_P14 RP2040_PINMUX(14, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RTS_P15 RP2040_PINMUX(15, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_TX_P16 RP2040_PINMUX(16, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RX_P17 RP2040_PINMUX(17, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_CTS_P18 RP2040_PINMUX(18, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RTS_P19 RP2040_PINMUX(19, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_TX_P20 RP2040_PINMUX(20, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RX_P21 RP2040_PINMUX(21, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_CTS_P22 RP2040_PINMUX(22, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RTS_P23 RP2040_PINMUX(23, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_TX_P24 RP2040_PINMUX(24, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RX_P25 RP2040_PINMUX(25, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_CTS_P26 RP2040_PINMUX(26, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART1_RTS_P27 RP2040_PINMUX(27, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_TX_P28 RP2040_PINMUX(28, RP2_PINCTRL_GPIO_FUNC_UART) |
| #define UART0_RX_P29 RP2040_PINMUX(29, RP2_PINCTRL_GPIO_FUNC_UART) |
| |
| #endif /* __RP2040_PINCTRL_H__ */ |