-
Notifications
You must be signed in to change notification settings - Fork 78
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
96 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
#include "gpio.h" | ||
|
||
static void _gpio_enable_port(GPIO_TypeDef *port) { | ||
int portnum = (((uint32_t)port - GPIOA_BASE) / (GPIOB_BASE - GPIOA_BASE)); | ||
RCC->APB2ENR |= RCC_APB2ENR_IOPAEN << portnum; | ||
} | ||
|
||
void gpio_pin_init(const gpio_pin_config_t *pincfg) { | ||
volatile uint32_t *crx = &pincfg->port->CRL + (pincfg->pin >> 3); | ||
uint8_t crx_offset = (pincfg->pin & 0x07) << 2; | ||
uint32_t modecfg = 0; | ||
_gpio_enable_port(pincfg->port); | ||
if (pincfg->dir == gpio_dir_input) { | ||
if (pincfg->pull == gpio_pull_floating) { | ||
modecfg |= GPIO_CRL_CNF0_0; | ||
} else { | ||
modecfg |= GPIO_CRL_CNF0_1; | ||
pincfg->port->BSRR = ((pincfg->pull == gpio_pull_up) ? GPIO_BSRR_BS0 : GPIO_BSRR_BR0) << pincfg->pin; | ||
} | ||
} else { | ||
switch (pincfg->speed) { | ||
case gpio_speed_low: | ||
modecfg |= GPIO_CRL_MODE0_1; | ||
break; | ||
case gpio_speed_medium: | ||
modecfg |= GPIO_CRL_MODE0_0; | ||
break; | ||
case gpio_speed_high: | ||
modecfg |= GPIO_CRL_MODE0; | ||
break; | ||
} | ||
if (pincfg->output == gpio_output_od) { | ||
modecfg |= GPIO_CRL_CNF0_0; | ||
} | ||
if (pincfg->func == gpio_func_alternate) { | ||
modecfg |= GPIO_CRL_CNF0_1; | ||
} | ||
} | ||
*crx &= ~((GPIO_CRL_CNF0 | GPIO_CRL_MODE0) << crx_offset); | ||
*crx |= (modecfg << crx_offset); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
#ifndef GPIO_H | ||
#define GPIO_H | ||
|
||
#include <stdint.h> | ||
#include <stm32f1xx.h> | ||
|
||
typedef enum { | ||
gpio_dir_input, | ||
gpio_dir_output, | ||
} __attribute__ ((packed)) gpio_dir_t; | ||
|
||
typedef enum { | ||
gpio_func_general, | ||
gpio_func_alternate, | ||
} __attribute__ ((packed)) gpio_func_t; | ||
|
||
typedef enum { | ||
gpio_output_pp, | ||
gpio_output_od, | ||
} __attribute__ ((packed)) gpio_output_t; | ||
|
||
typedef enum { | ||
gpio_pull_floating, | ||
gpio_pull_up, | ||
gpio_pull_down, | ||
} __attribute__ ((packed)) gpio_pull_t; | ||
|
||
typedef enum { | ||
gpio_polarity_high, | ||
gpio_polarity_low | ||
} __attribute__ ((packed)) gpio_polarity_t; | ||
|
||
typedef enum { | ||
gpio_speed_low, | ||
gpio_speed_medium, | ||
gpio_speed_high, | ||
} __attribute__ ((packed)) gpio_speed_t; | ||
|
||
typedef struct { | ||
GPIO_TypeDef* port; | ||
uint8_t pin; | ||
gpio_dir_t dir; | ||
gpio_func_t func; | ||
gpio_output_t output; | ||
gpio_pull_t pull; | ||
gpio_polarity_t polarity; | ||
gpio_speed_t speed; | ||
} __attribute__ ((packed)) gpio_pin_config_t; | ||
|
||
void gpio_pin_init(const gpio_pin_config_t *pincfg); | ||
|
||
#endif /* GPIO_G */ |