Line data Source code
1 0 : /*
2 : * Copyright 2025 Arm Limited and/or its affiliates <open-source-office@arm.com>
3 : *
4 : * SPDX-License-Identifier: Apache-2.0
5 : */
6 :
7 0 : #define MPS4_ALT_FUNC_POS 0
8 0 : #define MPS4_ALT_FUNC_MASK 0x7
9 :
10 0 : #define MPS4_EXP_NUM_POS 3
11 0 : #define MPS4_EXP_NUM_MASK 0x1F8
12 :
13 0 : #define MPS4_PINCTRL_FUNC_UART 0
14 0 : #define MPS4_PINCTRL_FUNC_GPIO 1
15 0 : #define MPS4_PINCTRL_FUNC_I2C 2
16 0 : #define MPS4_PINCTRL_FUNC_SPI 3
17 :
18 0 : #define MPS4_PINMUX(alt_func, exp_num) (exp_num << MPS4_EXP_NUM_POS | \
19 : alt_func << MPS4_ALT_FUNC_POS)
20 :
21 : /* GPIO 0 */
22 0 : #define UART3_RXD_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_UART, 0)
23 0 : #define UART3_TXD_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_UART, 1)
24 0 : #define SPI3_SS_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 10)
25 0 : #define SPI3_MOSI_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 11)
26 0 : #define SPI3_MISO_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 12)
27 0 : #define SPI3_SCK_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 13)
28 0 : #define SBCON2_SDA_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_I2C, 14)
29 0 : #define SBCON2_SCL_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_I2C, 15)
30 :
31 :
32 : /* GPIO 1 */
33 0 : #define UART4_RXD_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_UART, 16)
34 0 : #define UART4_TXD_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_UART, 17)
35 0 : #define SPI4_SS_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 26)
36 0 : #define SPI4_MOSI_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 27)
37 0 : #define SPI4_MISO_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 28)
38 0 : #define SPI4_SCK_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_SPI, 29)
39 0 : #define SBCON3_SDA_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_I2C, 30)
40 0 : #define SBCON3_SCL_EXP MPS4_PINMUX(MPS4_PINCTRL_FUNC_I2C, 31)
|