dajing/bsp/pwm/bsp_pwm.h

91 lines
2.3 KiB
C
Raw Normal View History

2024-05-26 21:02:35 +08:00
/**
* @file bsp_pwm.h
* @author your name (you@domain.com)
* @brief
* @version 0.1
* @date 2023-02-14
*
* @copyright Copyright (c) 2023
*
*/
#ifndef BSP_PWM_H
#define BSP_PWM_H
#include "tim.h"
#include "stdint.h"
#include "stm32f4xx_hal_rcc.h"
#include "stm32f407xx.h"
#define PWM_DEVICE_CNT 16 // 最大支持的PWM实例数量
/* pwm实例结构体 */
typedef struct pwm_ins_temp
{
TIM_HandleTypeDef *htim; // TIM句柄
uint32_t channel; // 通道
uint32_t tclk; // 时钟频率
float period; // 周期
float dutyratio; // 占空比
void (*callback)(struct pwm_ins_temp *); // DMA传输完成回调函数
void *id; // 实例ID
} PWMInstance;
typedef struct
{
TIM_HandleTypeDef *htim; // TIM句柄
uint32_t channel; // 通道
float period; // 周期
float dutyratio; // 占空比
void (*callback)(PWMInstance*); // DMA传输完成回调函数
void *id; // 实例ID
} PWM_Init_Config_s;
/**
* @brief pwm实例
*
* @param config
* @return PWMInstance*
*/
PWMInstance *PWMRegister(PWM_Init_Config_s *config);
/**
* @brief pwm
*
* @param pwm pwm实例
*/
void PWMStart(PWMInstance *pwm, unsigned int i);
/**
* @brief pwm占空比
*
* @param pwm pwm实例
* @param dutyratio 0~1
*/
void PWMSetDutyRatio(PWMInstance *pwm, float dutyratio);
/**
* @brief pwm
*
* @param pwm pwm实例
*/
void PWMStop(PWMInstance *pwm);
/**
* @brief pwm周期
*
* @param pwm pwm实例
* @param period s
*/
void PWMSetPeriod(PWMInstance *pwm, float period);
/**
* @brief pwm dma传输
*
* @param pwm pwm实例
* @param pData ,CubeMX配置的DMA传输位数()
* @param Size
* @note 使,CubeMX中配置DMA传输位数为对应位数
* :使16,DMA传输位数为16位(half word),
*/
void PWMStartDMA(PWMInstance *pwm, uint32_t *pData, uint32_t Size);
#endif // BSP_PWM_H