2020-09-09 16:12:09 +00:00
|
|
|
/*
|
|
|
|
Flipper devices inc.
|
|
|
|
|
|
|
|
GPIO and HAL implementations
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "main.h"
|
|
|
|
|
2020-09-29 23:18:30 +00:00
|
|
|
typedef enum { GpioModeInput, GpioModeOutput, GpioModeOpenDrain } GpioMode;
|
2020-09-09 16:12:09 +00:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
GPIO_TypeDef* port;
|
|
|
|
uint32_t pin;
|
|
|
|
} GpioPin;
|
|
|
|
|
|
|
|
void app_gpio_init(GpioPin gpio, GpioMode mode);
|
|
|
|
|
2020-10-05 10:01:20 +00:00
|
|
|
static inline void app_gpio_write(GpioPin gpio, bool state) {
|
2020-09-09 16:12:09 +00:00
|
|
|
if(gpio.pin != 0) {
|
|
|
|
if(state) {
|
|
|
|
gpio.port->BSRR = (uint32_t)gpio.pin;
|
|
|
|
} else {
|
|
|
|
gpio.port->BRR = (uint32_t)gpio.pin;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-05 10:01:20 +00:00
|
|
|
static inline bool app_gpio_read(GpioPin gpio) {
|
2020-09-09 16:12:09 +00:00
|
|
|
if(gpio.pin != 0) {
|
|
|
|
return (gpio.port->IDR & gpio.pin) != 0x00u;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2020-10-23 09:39:11 +00:00
|
|
|
void delay_us_init_DWT(void);
|
|
|
|
void delay_us(float time);
|
2020-09-09 16:12:09 +00:00
|
|
|
|
|
|
|
void pwm_set(float value, float freq, TIM_HandleTypeDef* tim, uint32_t channel);
|
2020-10-23 09:39:11 +00:00
|
|
|
void pwm_stop(TIM_HandleTypeDef* tim, uint32_t channel);
|
2020-09-09 16:12:09 +00:00
|
|
|
|
|
|
|
extern TIM_HandleTypeDef htim8;
|
|
|
|
|
2020-10-05 10:01:20 +00:00
|
|
|
static inline void app_tim_ic_init(bool both) {
|
2020-09-09 16:12:09 +00:00
|
|
|
HAL_TIM_OC_Stop(&htim8, TIM_CHANNEL_2);
|
|
|
|
|
|
|
|
TIM_IC_InitTypeDef sConfigIC = {0};
|
2020-09-29 23:18:30 +00:00
|
|
|
sConfigIC.ICPolarity = both ? TIM_INPUTCHANNELPOLARITY_BOTHEDGE :
|
|
|
|
TIM_INPUTCHANNELPOLARITY_FALLING;
|
2020-09-09 16:12:09 +00:00
|
|
|
sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
|
|
|
|
sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
|
|
|
|
sConfigIC.ICFilter = 0;
|
|
|
|
HAL_TIM_IC_ConfigChannel(&htim8, &sConfigIC, TIM_CHANNEL_2);
|
|
|
|
|
|
|
|
HAL_TIM_IC_Start_IT(&htim8, TIM_CHANNEL_2);
|
|
|
|
}
|
|
|
|
|
2020-10-05 10:01:20 +00:00
|
|
|
static inline void app_tim_pulse(uint32_t width) {
|
2020-09-09 16:12:09 +00:00
|
|
|
htim8.State = HAL_TIM_STATE_BUSY;
|
|
|
|
|
|
|
|
__HAL_TIM_DISABLE(&htim8);
|
|
|
|
|
|
|
|
__HAL_TIM_SET_COUNTER(&htim8, 0);
|
|
|
|
|
|
|
|
TIM_OC_InitTypeDef sConfigOC;
|
|
|
|
sConfigOC.OCMode = TIM_OCMODE_INACTIVE;
|
|
|
|
sConfigOC.Pulse = (uint16_t)(width);
|
|
|
|
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
|
|
|
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
|
|
|
// HAL_TIM_OC_ConfigChannel(&htim8, &sConfigOC, TIM_CHANNEL_2);
|
|
|
|
|
|
|
|
htim8.Lock = HAL_LOCKED;
|
|
|
|
|
|
|
|
/* Configure the TIM Channel 2 in Output Compare */
|
|
|
|
TIM_OC2_SetConfig(htim8.Instance, &sConfigOC);
|
|
|
|
|
|
|
|
htim8.Lock = HAL_UNLOCKED;
|
|
|
|
|
|
|
|
// TIM_CCxChannelCmd(htim8.Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE);
|
|
|
|
|
|
|
|
/* Reset the CCxE Bit */
|
|
|
|
htim8.Instance->CCER &= ~(TIM_CCER_CC1E << (TIM_CHANNEL_2 & 0x1FU));
|
|
|
|
|
|
|
|
/* Set or reset the CCxE Bit */
|
|
|
|
htim8.Instance->CCER |= (uint32_t)(TIM_CCx_ENABLE << (TIM_CHANNEL_2 & 0x1FU));
|
|
|
|
|
|
|
|
__HAL_TIM_MOE_ENABLE(&htim8);
|
|
|
|
__HAL_TIM_ENABLE(&htim8);
|
|
|
|
|
|
|
|
htim8.State = HAL_TIM_STATE_READY;
|
|
|
|
}
|
|
|
|
|
2020-10-05 10:01:20 +00:00
|
|
|
static inline void app_tim_stop() {
|
2020-09-09 16:12:09 +00:00
|
|
|
HAL_TIM_OC_Stop(&htim8, TIM_CHANNEL_2);
|
|
|
|
HAL_TIM_IC_Stop(&htim8, TIM_CHANNEL_2);
|
|
|
|
}
|