flipper_hal.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. Flipper devices inc.
  3. GPIO and HAL implementations
  4. */
  5. #pragma once
  6. #include <stdbool.h>
  7. #include "main.h"
  8. typedef enum { GpioModeInput, GpioModeOutput, GpioModeOpenDrain } GpioMode;
  9. typedef struct {
  10. GPIO_TypeDef* port;
  11. uint32_t pin;
  12. } GpioPin;
  13. void app_gpio_init(GpioPin gpio, GpioMode mode);
  14. static inline void app_gpio_write(GpioPin gpio, bool state) {
  15. if(gpio.pin != 0) {
  16. if(state) {
  17. gpio.port->BSRR = (uint32_t)gpio.pin;
  18. } else {
  19. gpio.port->BRR = (uint32_t)gpio.pin;
  20. }
  21. }
  22. }
  23. static inline bool app_gpio_read(GpioPin gpio) {
  24. if(gpio.pin != 0) {
  25. return (gpio.port->IDR & gpio.pin) != 0x00u;
  26. }
  27. return false;
  28. }
  29. void delay_us(uint32_t time);
  30. void pwm_set(float value, float freq, TIM_HandleTypeDef* tim, uint32_t channel);
  31. extern TIM_HandleTypeDef htim8;
  32. static inline void app_tim_ic_init(bool both) {
  33. HAL_TIM_OC_Stop(&htim8, TIM_CHANNEL_2);
  34. TIM_IC_InitTypeDef sConfigIC = {0};
  35. sConfigIC.ICPolarity = both ? TIM_INPUTCHANNELPOLARITY_BOTHEDGE :
  36. TIM_INPUTCHANNELPOLARITY_FALLING;
  37. sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  38. sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  39. sConfigIC.ICFilter = 0;
  40. HAL_TIM_IC_ConfigChannel(&htim8, &sConfigIC, TIM_CHANNEL_2);
  41. HAL_TIM_IC_Start_IT(&htim8, TIM_CHANNEL_2);
  42. }
  43. static inline void app_tim_pulse(uint32_t width) {
  44. htim8.State = HAL_TIM_STATE_BUSY;
  45. __HAL_TIM_DISABLE(&htim8);
  46. __HAL_TIM_SET_COUNTER(&htim8, 0);
  47. TIM_OC_InitTypeDef sConfigOC;
  48. sConfigOC.OCMode = TIM_OCMODE_INACTIVE;
  49. sConfigOC.Pulse = (uint16_t)(width);
  50. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  51. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  52. // HAL_TIM_OC_ConfigChannel(&htim8, &sConfigOC, TIM_CHANNEL_2);
  53. htim8.Lock = HAL_LOCKED;
  54. /* Configure the TIM Channel 2 in Output Compare */
  55. TIM_OC2_SetConfig(htim8.Instance, &sConfigOC);
  56. htim8.Lock = HAL_UNLOCKED;
  57. // TIM_CCxChannelCmd(htim8.Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE);
  58. /* Reset the CCxE Bit */
  59. htim8.Instance->CCER &= ~(TIM_CCER_CC1E << (TIM_CHANNEL_2 & 0x1FU));
  60. /* Set or reset the CCxE Bit */
  61. htim8.Instance->CCER |= (uint32_t)(TIM_CCx_ENABLE << (TIM_CHANNEL_2 & 0x1FU));
  62. __HAL_TIM_MOE_ENABLE(&htim8);
  63. __HAL_TIM_ENABLE(&htim8);
  64. htim8.State = HAL_TIM_STATE_READY;
  65. }
  66. static inline void app_tim_stop() {
  67. HAL_TIM_OC_Stop(&htim8, TIM_CHANNEL_2);
  68. HAL_TIM_IC_Stop(&htim8, TIM_CHANNEL_2);
  69. }