aboutsummaryrefslogtreecommitdiff
path: root/stmhal/mphalport.c
diff options
context:
space:
mode:
authorDamien George2016-04-12 13:50:47 +0100
committerDamien George2016-04-12 14:06:54 +0100
commit69a1aaf654442247e01655035a5cfb34568b1b80 (patch)
treee8a9972e522a411188d506b7216b9ed25d8f0dfc /stmhal/mphalport.c
parentd083712224602372c5fd22d0b9e2b32efe6fa26b (diff)
stmhal: Implement basic C-level pin HAL.
Diffstat (limited to 'stmhal/mphalport.c')
-rw-r--r--stmhal/mphalport.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/stmhal/mphalport.c b/stmhal/mphalport.c
index 3fd4395d6..82a345b8a 100644
--- a/stmhal/mphalport.c
+++ b/stmhal/mphalport.c
@@ -119,6 +119,15 @@ void mp_hal_gpio_clock_enable(GPIO_TypeDef *gpio) {
}
}
+void mp_hal_gpio_config(GPIO_TypeDef *gpio, uint32_t pin, uint32_t mode, uint32_t pull, uint32_t alt) {
+ mp_hal_gpio_clock_enable(gpio);
+ gpio->MODER = (gpio->MODER & ~(3 << (2 * pin))) | ((mode & 3) << (2 * pin));
+ gpio->OTYPER = (gpio->OTYPER & ~(1 << pin)) | ((mode >> 2) << pin);
+ gpio->OSPEEDR = (gpio->OSPEEDR & ~(3 << (2 * pin))) | (2 << (2 * pin)); // full speed
+ gpio->PUPDR = (gpio->PUPDR & ~(3 << (2 * pin))) | (pull << (2 * pin));
+ gpio->AFR[pin >> 3] = (gpio->AFR[pin >> 3] & ~(15 << (4 * (pin & 7)))) | (alt << (4 * (pin & 7)));
+}
+
bool mp_hal_gpio_set_af(const pin_obj_t *pin, GPIO_InitTypeDef *init, uint8_t fn, uint8_t unit) {
mp_hal_gpio_clock_enable(pin->gpio);