13#ifndef __PHAL_G4_GPIO_H__
14#define __PHAL_G4_GPIO_H__
16#include "common/phal_G4/phal_G4.h"
22 GPIO_TYPE_INPUT = 0b00,
23 GPIO_TYPE_OUTPUT = 0b01,
25 GPIO_TYPE_ANALOG = 0b11,
32 GPIO_OUTPUT_LOW_SPEED = 0b00,
33 GPIO_OUTPUT_MED_SPEED = 0b01,
34 GPIO_OUTPUT_HIGH_SPEED = 0b10,
35 GPIO_OUTPUT_ULTRA_SPEED = 0b11,
42 GPIO_OUTPUT_PUSH_PULL = 0b0,
43 GPIO_OUTPUT_OPEN_DRAIN = 0b1,
50 GPIO_INPUT_OPEN_DRAIN = 0b00,
51 GPIO_INPUT_PULL_UP = 0b01,
52 GPIO_INPUT_PULL_DOWN = 0b10,
83#define GPIO_INIT_INPUT(gpio_bank, pin_num, input_pull_sel) \
85 .bank = gpio_bank, .pin = pin_num, .type = GPIO_TYPE_INPUT, .config = { \
86 .pull = input_pull_sel \
97#define GPIO_INIT_OUTPUT(gpio_bank, pin_num, ospeed_sel) \
99 .bank = gpio_bank, .pin = pin_num, .type = GPIO_TYPE_OUTPUT, .config = { \
100 .ospeed = ospeed_sel, \
101 .otype = GPIO_OUTPUT_PUSH_PULL \
105#define GPIO_INIT_OUTPUT_OPEN_DRAIN(gpio_bank, pin_num, ospeed_sel) \
107 .bank = gpio_bank, .pin = pin_num, .type = GPIO_TYPE_OUTPUT, .config = { \
108 .ospeed = ospeed_sel, \
109 .otype = GPIO_OUTPUT_OPEN_DRAIN \
118#define GPIO_INIT_ANALOG(gpio_bank, pin_num) \
119 {.bank = gpio_bank, .pin = pin_num, .type = GPIO_TYPE_ANALOG}
131#define GPIO_INIT_AF(gpio_bank, pin_num, alt_func_num, ospeed_sel, otype_sel, input_pull_sel) \
133 .bank = gpio_bank, .pin = pin_num, .type = GPIO_TYPE_AF, .config = { \
134 .af_num = alt_func_num, \
135 .ospeed = ospeed_sel, \
136 .otype = otype_sel, \
137 .pull = input_pull_sel \
166static inline bool PHAL_readGPIO(GPIO_TypeDef *bank, uint8_t pin) {
167 return (bank->IDR >> pin) & 0b1;
170#define GPIO_INIT_USART3TX_PC10 \
171 GPIO_INIT_AF(GPIOC, \
174 GPIO_OUTPUT_ULTRA_SPEED, \
175 GPIO_OUTPUT_PUSH_PULL, \
176 GPIO_INPUT_OPEN_DRAIN)
177#define GPIO_INIT_USART3RX_PC11 \
178 GPIO_INIT_AF(GPIOC, \
181 GPIO_OUTPUT_ULTRA_SPEED, \
182 GPIO_OUTPUT_OPEN_DRAIN, \
183 GPIO_INPUT_OPEN_DRAIN)
185#define GPIO_INIT_USART3TX_PB10 \
186 GPIO_INIT_AF(GPIOB, \
189 GPIO_OUTPUT_ULTRA_SPEED, \
190 GPIO_OUTPUT_PUSH_PULL, \
191 GPIO_INPUT_OPEN_DRAIN)
192#define GPIO_INIT_USART3RX_PB11 \
193 GPIO_INIT_AF(GPIOB, \
196 GPIO_OUTPUT_ULTRA_SPEED, \
197 GPIO_OUTPUT_OPEN_DRAIN, \
198 GPIO_INPUT_OPEN_DRAIN)
200#define GPIO_INIT_USART2TX_PA2 \
201 GPIO_INIT_AF(GPIOA, 2, 7, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
202#define GPIO_INIT_USART2RX_PA3 \
203 GPIO_INIT_AF(GPIOA, \
206 GPIO_OUTPUT_ULTRA_SPEED, \
207 GPIO_OUTPUT_OPEN_DRAIN, \
208 GPIO_INPUT_OPEN_DRAIN)
210#define GPIO_INIT_USART1TX_PA9 \
211 GPIO_INIT_AF(GPIOA, 9, 7, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
212#define GPIO_INIT_USART1RX_PA10 \
213 GPIO_INIT_AF(GPIOA, \
216 GPIO_OUTPUT_ULTRA_SPEED, \
217 GPIO_OUTPUT_OPEN_DRAIN, \
218 GPIO_INPUT_OPEN_DRAIN)
220#define GPIO_INIT_USART2TX_PD5 \
221 GPIO_INIT_AF(GPIOD, 5, 7, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
222#define GPIO_INIT_USART2RX_PD6 \
223 GPIO_INIT_AF(GPIOD, \
226 GPIO_OUTPUT_ULTRA_SPEED, \
227 GPIO_OUTPUT_OPEN_DRAIN, \
228 GPIO_INPUT_OPEN_DRAIN)
230#define GPIO_INIT_UART4TX_PC10 \
231 GPIO_INIT_AF(GPIOC, \
234 GPIO_OUTPUT_ULTRA_SPEED, \
235 GPIO_OUTPUT_PUSH_PULL, \
236 GPIO_INPUT_OPEN_DRAIN)
237#define GPIO_INIT_UART4RX_PC11 \
238 GPIO_INIT_AF(GPIOC, \
241 GPIO_OUTPUT_ULTRA_SPEED, \
242 GPIO_OUTPUT_OPEN_DRAIN, \
243 GPIO_INPUT_OPEN_DRAIN)
245#define GPIO_INIT_LPUART1TX_PC0 \
246 GPIO_INIT_AF(GPIOC, 0, 8, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
247#define GPIO_INIT_LPUART1RX_PC1 \
248 GPIO_INIT_AF(GPIOC, \
251 GPIO_OUTPUT_ULTRA_SPEED, \
252 GPIO_OUTPUT_OPEN_DRAIN, \
253 GPIO_INPUT_OPEN_DRAIN)
258#define GPIO_INIT_SPI1SCK_PA5 \
259 GPIO_INIT_AF(GPIOA, 5, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
261#define GPIO_INIT_SPI1MISO_PA6 \
262 GPIO_INIT_AF(GPIOA, 6, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_PULL_UP)
264#define GPIO_INIT_SPI1MOSI_PA7 \
265 GPIO_INIT_AF(GPIOA, 7, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
267#define GPIO_INIT_SPI1NSS_PA4 \
268 GPIO_INIT_AF(GPIOA, 4, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
270#define GPIO_INIT_SPI1NSS_PA15 \
271 GPIO_INIT_AF(GPIOA, \
274 GPIO_OUTPUT_ULTRA_SPEED, \
275 GPIO_OUTPUT_PUSH_PULL, \
276 GPIO_INPUT_OPEN_DRAIN)
281#define GPIO_INIT_SPI2SCK_RET_PB13 \
282 GPIO_INIT_AF(GPIOB, \
285 GPIO_OUTPUT_ULTRA_SPEED, \
286 GPIO_OUTPUT_PUSH_PULL, \
287 GPIO_INPUT_OPEN_DRAIN)
289#define GPIO_INIT_SPI2MISO_RET_PB14 \
290 GPIO_INIT_AF(GPIOB, 14, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_PULL_UP)
292#define GPIO_INIT_SPI2MOSI_RET_PB15 \
293 GPIO_INIT_AF(GPIOB, \
296 GPIO_OUTPUT_ULTRA_SPEED, \
297 GPIO_OUTPUT_PUSH_PULL, \
298 GPIO_INPUT_OPEN_DRAIN)
300#define GPIO_INIT_SPI2NSS_RET_PB12 \
301 GPIO_INIT_AF(GPIOB, \
304 GPIO_OUTPUT_ULTRA_SPEED, \
305 GPIO_OUTPUT_PUSH_PULL, \
306 GPIO_INPUT_OPEN_DRAIN)
311#define GPIO_INIT_SPI2SCK_CET_PA9 \
312 GPIO_INIT_AF(GPIOA, 9, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
314#define GPIO_INIT_SPI2MISO_CET_PA10 \
315 GPIO_INIT_AF(GPIOA, 10, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_PULL_UP)
317#define GPIO_INIT_SPI2MOSI_CET_PA11 \
318 GPIO_INIT_AF(GPIOA, \
321 GPIO_OUTPUT_ULTRA_SPEED, \
322 GPIO_OUTPUT_PUSH_PULL, \
323 GPIO_INPUT_OPEN_DRAIN)
325#define GPIO_INIT_SPI2NSS_CET_PA8 \
326 GPIO_INIT_AF(GPIOA, 8, 5, GPIO_OUTPUT_ULTRA_SPEED, GPIO_OUTPUT_PUSH_PULL, GPIO_INPUT_OPEN_DRAIN)
335static inline void PHAL_writeGPIO(GPIO_TypeDef *bank, uint8_t pin,
bool value) {
337 1 << ((!value << 4) | pin);
340static inline void PHAL_toggleGPIO(GPIO_TypeDef *bank, uint8_t pin) {
341 PHAL_writeGPIO(bank, pin, !PHAL_readGPIO(bank, pin));
GPIOOutputPull_t
Output drive mode selection.
Definition gpio.h:75
GPIOPinType_t
Configuration type for GPIO Pin.
Definition gpio.h:55
bool PHAL_initGPIO(GPIOInitConfig_t config[], uint8_t config_len)
Initilize the GPIO perpheral given a list of configuration fields for all of the GPIO pins....
Definition gpio.c:3
GPIOInputPull_t
Enable internal pullup/down resistors.
Definition gpio.h:83
GPIOOutputSpeed_t
Slew rate control for output pins.
Definition gpio.h:65
Configuration entry for GPIO initilization.
Definition gpio.h:93