102 #define VREF2H GPIO_38
103 #define VREF2L GPIO_39
104 #define VREF1H GPIO_40
105 #define VREF1L GPIO_41
114 #define MSEO0 GPIO_59
115 #define MSEO1 GPIO_60
123 #define _V(x,n,i) uint32_t x##_##i : n;
125 _V(x,n,00) _V(x,n,01) _V(x,n,02) _V(x,n,03) _V(x,n,04) _V(x,n,05) _V(x,n,06) _V(x,n,07) \
126 _V(x,n,08) _V(x,n,09) _V(x,n,10) _V(x,n,11) _V(x,n,12) _V(x,n,13) _V(x,n,14) _V(x,n,15) \
127 _V(x,n,16) _V(x,n,17) _V(x,n,18) _V(x,n,19) _V(x,n,20) _V(x,n,21) _V(x,n,22) _V(x,n,23) \
128 _V(x,n,24) _V(x,n,25) _V(x,n,26) _V(x,n,27) _V(x,n,28) _V(x,n,29) _V(x,n,30) _V(x,n,31) \
129 _V(x,n,32) _V(x,n,33) _V(x,n,34) _V(x,n,35) _V(x,n,36) _V(x,n,37) _V(x,n,38) _V(x,n,39) \
130 _V(x,n,40) _V(x,n,41) _V(x,n,42) _V(x,n,43) _V(x,n,44) _V(x,n,45) _V(x,n,46) _V(x,n,47) \
131 _V(x,n,48) _V(x,n,49) _V(x,n,50) _V(x,n,51) _V(x,n,52) _V(x,n,53) _V(x,n,54) _V(x,n,55) \
132 _V(x,n,56) _V(x,n,57) _V(x,n,58) _V(x,n,59) _V(x,n,60) _V(x,n,61) _V(x,n,62) _V(x,n,63)
136 union { struct { uint32_t x##0; uint32_t x##1; }; \
137 struct { _REP(x, 1) }; \
138 struct GPIO_##x { _REP(GPIO, 1) } x; };
139 #define _IO_2bit(x) \
140 union { struct { uint32_t x##0; uint32_t x##1; uint32_t x##2; uint32_t x##3; }; \
141 struct { _REP(x, 2) }; \
142 struct GPIO_##x { _REP(GPIO, 2) } x; };
162 #define _V(x,n,i) __NUM_GPIO_GPIO_##i,
166 #define gpio_set(gpio_xx) __gpio_set(gpio_xx)
167 #define __gpio_set(gpio_xx) \
168 ((__NUM_GPIO_##gpio_xx < 32) \
169 ? (GPIO->DATA_SET0 = (1 << (__NUM_GPIO_##gpio_xx - 0))) \
170 : (GPIO->DATA_SET1 = (1 << (__NUM_GPIO_##gpio_xx - 32))))
171 #define gpio_reset(gpio_xx) __gpio_reset(gpio_xx)
172 #define __gpio_reset(gpio_xx) \
173 ((__NUM_GPIO_##gpio_xx < 32) \
174 ? (GPIO->DATA_RESET0 = (1 << (__NUM_GPIO_##gpio_xx - 0))) \
175 : (GPIO->DATA_RESET1 = (1 << (__NUM_GPIO_##gpio_xx - 32))))
180 static volatile struct GPIO_struct *
const GPIO = (
void *) (0x80000000);
184 #ifndef REG_NO_COMPAT
186 #define GPIO_PAD_DIR0 ((volatile uint32_t *) 0x80000000)
187 #define GPIO_PAD_DIR1 ((volatile uint32_t *) 0x80000004)
188 #define GPIO_DATA0 ((volatile uint32_t *) 0x80000008)
189 #define GPIO_DATA1 ((volatile uint32_t *) 0x8000000c)
190 #define GPIO_PAD_PU_EN0 ((volatile uint32_t *) 0x80000010)
191 #define GPIO_PAD_PU_EN1 ((volatile uint32_t *) 0x80000014)
192 #define GPIO_FUNC_SEL0 ((volatile uint32_t *) 0x80000018)
193 #define GPIO_FUNC_SEL1 ((volatile uint32_t *) 0x8000001c)
194 #define GPIO_FUNC_SEL2 ((volatile uint32_t *) 0x80000020)
195 #define GPIO_FUNC_SEL3 ((volatile uint32_t *) 0x80000024)
196 #define GPIO_DATA_SEL0 ((volatile uint32_t *) 0x80000028)
197 #define GPIO_DATA_SEL1 ((volatile uint32_t *) 0x8000002c)
198 #define GPIO_PAD_PU_SEL0 ((volatile uint32_t *) 0x80000030)
199 #define GPIO_PAD_PU_SEL1 ((volatile uint32_t *) 0x80000034)
201 #define GPIO_DATA_SET0 ((volatile uint32_t *) 0x80000048)
202 #define GPIO_DATA_SET1 ((volatile uint32_t *) 0x8000004c)
203 #define GPIO_DATA_RESET0 ((volatile uint32_t *) 0x80000050)
204 #define GPIO_DATA_RESET1 ((volatile uint32_t *) 0x80000054)
205 #define GPIO_PAD_DIR_SET0 ((volatile uint32_t *) 0x80000058)
206 #define GPIO_PAD_DIR_SET1 ((volatile uint32_t *) 0x8000005c)
207 #define GPIO_PAD_DIR_RESET0 ((volatile uint32_t *) 0x80000060)
208 #define GPIO_PAD_DIR_RESET1 ((volatile uint32_t *) 0x80000064)
210 inline void gpio_pad_dir(
volatile uint64_t data);
211 inline void gpio_data(
volatile uint64_t data);
212 inline uint64_t gpio_data_get(
volatile uint64_t bits);
213 inline void gpio_pad_pu_en(
volatile uint64_t data);
214 inline void gpio_data_sel(
volatile uint64_t data);
215 inline void gpio_data_pu_sel(
volatile uint64_t data);
216 inline void gpio_data_set(
volatile uint64_t data);
217 inline void gpio_data_reset(
volatile uint64_t data);
218 inline void gpio_pad_dir_set(
volatile uint64_t data);
219 inline void gpio_pad_dir_reset(
volatile uint64_t data);
222 #define gpio_sel0_pullup(b) (set_bit(*GPIO_PAD_PU_SEL0,b))
223 #define gpio_sel0_pulldown(b) (clear_bit(*GPIO_PAD_PU_SEL0,b))
226 #define gpio_sel1_pullup(b) (set_bit(*GPIO_PAD_PU_SEL1,b-32))
227 #define gpio_sel1_pulldown(b) (clear_bit(*GPIO_PAD_PU_SEL1,b-32))
230 #define gpio_pu0_enable(b) (set_bit(*GPIO_PAD_PU_EN0,b))
231 #define gpio_pu0_disable(b) (clear_bit(*GPIO_PAD_PU_EN0,b))
234 #define gpio_pu1_enable(b) (set_bit(*GPIO_PAD_PU_EN1,b-32))
235 #define gpio_pu1_disable(b) (clear_bit(*GPIO_PAD_PU_EN1,b-32))