1  /* SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause */
2  /*
3   * GPIO definitions for MStar/SigmaStar MSC313 and later SoCs
4   *
5   * Copyright (C) 2020 Daniel Palmer <daniel@thingy.jp>
6   */
7  
8  #ifndef _DT_BINDINGS_MSC313_GPIO_H
9  #define _DT_BINDINGS_MSC313_GPIO_H
10  
11  #define MSC313_GPIO_FUART	0
12  #define MSC313_GPIO_FUART_RX	(MSC313_GPIO_FUART + 0)
13  #define MSC313_GPIO_FUART_TX	(MSC313_GPIO_FUART + 1)
14  #define MSC313_GPIO_FUART_CTS	(MSC313_GPIO_FUART + 2)
15  #define MSC313_GPIO_FUART_RTS	(MSC313_GPIO_FUART + 3)
16  
17  #define MSC313_GPIO_SR		(MSC313_GPIO_FUART_RTS + 1)
18  #define MSC313_GPIO_SR_IO2	(MSC313_GPIO_SR + 0)
19  #define MSC313_GPIO_SR_IO3	(MSC313_GPIO_SR + 1)
20  #define MSC313_GPIO_SR_IO4	(MSC313_GPIO_SR + 2)
21  #define MSC313_GPIO_SR_IO5	(MSC313_GPIO_SR + 3)
22  #define MSC313_GPIO_SR_IO6	(MSC313_GPIO_SR + 4)
23  #define MSC313_GPIO_SR_IO7	(MSC313_GPIO_SR + 5)
24  #define MSC313_GPIO_SR_IO8	(MSC313_GPIO_SR + 6)
25  #define MSC313_GPIO_SR_IO9	(MSC313_GPIO_SR + 7)
26  #define MSC313_GPIO_SR_IO10	(MSC313_GPIO_SR + 8)
27  #define MSC313_GPIO_SR_IO11	(MSC313_GPIO_SR + 9)
28  #define MSC313_GPIO_SR_IO12	(MSC313_GPIO_SR + 10)
29  #define MSC313_GPIO_SR_IO13	(MSC313_GPIO_SR + 11)
30  #define MSC313_GPIO_SR_IO14	(MSC313_GPIO_SR + 12)
31  #define MSC313_GPIO_SR_IO15	(MSC313_GPIO_SR + 13)
32  #define MSC313_GPIO_SR_IO16	(MSC313_GPIO_SR + 14)
33  #define MSC313_GPIO_SR_IO17	(MSC313_GPIO_SR + 15)
34  
35  #define MSC313_GPIO_SD		(MSC313_GPIO_SR_IO17 + 1)
36  #define MSC313_GPIO_SD_CLK	(MSC313_GPIO_SD + 0)
37  #define MSC313_GPIO_SD_CMD	(MSC313_GPIO_SD + 1)
38  #define MSC313_GPIO_SD_D0	(MSC313_GPIO_SD + 2)
39  #define MSC313_GPIO_SD_D1	(MSC313_GPIO_SD + 3)
40  #define MSC313_GPIO_SD_D2	(MSC313_GPIO_SD + 4)
41  #define MSC313_GPIO_SD_D3	(MSC313_GPIO_SD + 5)
42  
43  #define MSC313_GPIO_I2C1	(MSC313_GPIO_SD_D3 + 1)
44  #define MSC313_GPIO_I2C1_SCL	(MSC313_GPIO_I2C1 + 0)
45  #define MSC313_GPIO_I2C1_SDA	(MSC313_GPIO_I2C1 + 1)
46  
47  #define MSC313_GPIO_SPI0	(MSC313_GPIO_I2C1_SDA + 1)
48  #define MSC313_GPIO_SPI0_CZ	(MSC313_GPIO_SPI0 + 0)
49  #define MSC313_GPIO_SPI0_CK	(MSC313_GPIO_SPI0 + 1)
50  #define MSC313_GPIO_SPI0_DI	(MSC313_GPIO_SPI0 + 2)
51  #define MSC313_GPIO_SPI0_DO	(MSC313_GPIO_SPI0 + 3)
52  
53  /* SSD20x */
54  #define SSD20XD_GPIO_FUART	0
55  #define SSD20XD_GPIO_FUART_RX	(SSD20XD_GPIO_FUART + 0)
56  #define SSD20XD_GPIO_FUART_TX	(SSD20XD_GPIO_FUART + 1)
57  #define SSD20XD_GPIO_FUART_CTS	(SSD20XD_GPIO_FUART + 2)
58  #define SSD20XD_GPIO_FUART_RTS	(SSD20XD_GPIO_FUART + 3)
59  
60  #define SSD20XD_GPIO_SD		(SSD20XD_GPIO_FUART_RTS + 1)
61  #define SSD20XD_GPIO_SD_CLK	(SSD20XD_GPIO_SD + 0)
62  #define SSD20XD_GPIO_SD_CMD	(SSD20XD_GPIO_SD + 1)
63  #define SSD20XD_GPIO_SD_D0	(SSD20XD_GPIO_SD + 2)
64  #define SSD20XD_GPIO_SD_D1	(SSD20XD_GPIO_SD + 3)
65  #define SSD20XD_GPIO_SD_D2	(SSD20XD_GPIO_SD + 4)
66  #define SSD20XD_GPIO_SD_D3	(SSD20XD_GPIO_SD + 5)
67  
68  #define SSD20XD_GPIO_UART0	(SSD20XD_GPIO_SD_D3 + 1)
69  #define SSD20XD_GPIO_UART0_RX	(SSD20XD_GPIO_UART0 + 0)
70  #define SSD20XD_GPIO_UART0_TX	(SSD20XD_GPIO_UART0 + 1)
71  
72  #define SSD20XD_GPIO_UART1	(SSD20XD_GPIO_UART0_TX + 1)
73  #define SSD20XD_GPIO_UART1_RX	(SSD20XD_GPIO_UART1 + 0)
74  #define SSD20XD_GPIO_UART1_TX	(SSD20XD_GPIO_UART1 + 1)
75  
76  #define SSD20XD_GPIO_TTL	(SSD20XD_GPIO_UART1_TX + 1)
77  #define SSD20XD_GPIO_TTL0	(SSD20XD_GPIO_TTL + 0)
78  #define SSD20XD_GPIO_TTL1	(SSD20XD_GPIO_TTL + 1)
79  #define SSD20XD_GPIO_TTL2	(SSD20XD_GPIO_TTL + 2)
80  #define SSD20XD_GPIO_TTL3	(SSD20XD_GPIO_TTL + 3)
81  #define SSD20XD_GPIO_TTL4	(SSD20XD_GPIO_TTL + 4)
82  #define SSD20XD_GPIO_TTL5	(SSD20XD_GPIO_TTL + 5)
83  #define SSD20XD_GPIO_TTL6	(SSD20XD_GPIO_TTL + 6)
84  #define SSD20XD_GPIO_TTL7	(SSD20XD_GPIO_TTL + 7)
85  #define SSD20XD_GPIO_TTL8	(SSD20XD_GPIO_TTL + 8)
86  #define SSD20XD_GPIO_TTL9	(SSD20XD_GPIO_TTL + 9)
87  #define SSD20XD_GPIO_TTL10	(SSD20XD_GPIO_TTL + 10)
88  #define SSD20XD_GPIO_TTL11	(SSD20XD_GPIO_TTL + 11)
89  #define SSD20XD_GPIO_TTL12	(SSD20XD_GPIO_TTL + 12)
90  #define SSD20XD_GPIO_TTL13	(SSD20XD_GPIO_TTL + 13)
91  #define SSD20XD_GPIO_TTL14	(SSD20XD_GPIO_TTL + 14)
92  #define SSD20XD_GPIO_TTL15	(SSD20XD_GPIO_TTL + 15)
93  #define SSD20XD_GPIO_TTL16	(SSD20XD_GPIO_TTL + 16)
94  #define SSD20XD_GPIO_TTL17	(SSD20XD_GPIO_TTL + 17)
95  #define SSD20XD_GPIO_TTL18	(SSD20XD_GPIO_TTL + 18)
96  #define SSD20XD_GPIO_TTL19	(SSD20XD_GPIO_TTL + 19)
97  #define SSD20XD_GPIO_TTL20	(SSD20XD_GPIO_TTL + 20)
98  #define SSD20XD_GPIO_TTL21	(SSD20XD_GPIO_TTL + 21)
99  #define SSD20XD_GPIO_TTL22	(SSD20XD_GPIO_TTL + 22)
100  #define SSD20XD_GPIO_TTL23	(SSD20XD_GPIO_TTL + 23)
101  #define SSD20XD_GPIO_TTL24	(SSD20XD_GPIO_TTL + 24)
102  #define SSD20XD_GPIO_TTL25	(SSD20XD_GPIO_TTL + 25)
103  #define SSD20XD_GPIO_TTL26	(SSD20XD_GPIO_TTL + 26)
104  #define SSD20XD_GPIO_TTL27	(SSD20XD_GPIO_TTL + 27)
105  
106  #define SSD20XD_GPIO_GPIO	(SSD20XD_GPIO_TTL27 + 1)
107  #define SSD20XD_GPIO_GPIO0	(SSD20XD_GPIO_GPIO + 0)
108  #define SSD20XD_GPIO_GPIO1	(SSD20XD_GPIO_GPIO + 1)
109  #define SSD20XD_GPIO_GPIO2	(SSD20XD_GPIO_GPIO + 2)
110  #define SSD20XD_GPIO_GPIO3	(SSD20XD_GPIO_GPIO + 3)
111  #define SSD20XD_GPIO_GPIO4	(SSD20XD_GPIO_GPIO + 4)
112  #define SSD20XD_GPIO_GPIO5	(SSD20XD_GPIO_GPIO + 5)
113  #define SSD20XD_GPIO_GPIO6	(SSD20XD_GPIO_GPIO + 6)
114  #define SSD20XD_GPIO_GPIO7	(SSD20XD_GPIO_GPIO + 7)
115  #define SSD20XD_GPIO_GPIO10	(SSD20XD_GPIO_GPIO + 8)
116  #define SSD20XD_GPIO_GPIO11	(SSD20XD_GPIO_GPIO + 9)
117  #define SSD20XD_GPIO_GPIO12	(SSD20XD_GPIO_GPIO + 10)
118  #define SSD20XD_GPIO_GPIO13	(SSD20XD_GPIO_GPIO + 11)
119  #define SSD20XD_GPIO_GPIO14	(SSD20XD_GPIO_GPIO + 12)
120  #define SSD20XD_GPIO_GPIO85	(SSD20XD_GPIO_GPIO + 13)
121  #define SSD20XD_GPIO_GPIO86	(SSD20XD_GPIO_GPIO + 14)
122  #define SSD20XD_GPIO_GPIO90	(SSD20XD_GPIO_GPIO + 15)
123  
124  #endif /* _DT_BINDINGS_MSC313_GPIO_H */
125