瑞萨单片机利用定时器输入捕获采集PWM波形
创作时间:
作者:
@小白创作中心
瑞萨单片机利用定时器输入捕获采集PWM波形
引用
CSDN
1.
https://m.blog.csdn.net/qq_44377374/article/details/144416217
本文介绍了一种使用瑞萨R7FA2L1AB3CFP单片机通过定时器输入捕获模式采集PWM波形的频率和占空比的具体实现方法。文章详细描述了需求分析、实现方式选择、硬件可行性判断、定时器配置、中断配置以及具体的代码实现,对于从事嵌入式系统开发的工程师具有较高的参考价值。
1.需求
一台设备通过一引脚持续输出PWM波形,需要用瑞萨单片机采集并计算PWM的频率和占空比。
单片机型号:R7FA2L1AB3CFP
编译器版本:e2 studio 2021-01 (21.1.0) fsp:2.3.0
2.实现方式
思路:
1.利用定时器的PWM输入模式,直接获取PWM频率和占空比。
2.利用定时器的输入捕获模式,获取高电平和低电平的维持时间,进而计算PWM的频率和占空比。
3.利用GPIO捕捉引脚电平切换,在中断中在控制定时器的开始与结束,进而计算高电平和低电平的维持时间,进而计算PWM的频率和占空比。
其实三种思路逻辑大体一致,主要看瑞萨单片机是否支持PWM输入模式,这里选用思路2。
3.判断可行性
查阅手册判断瑞萨R7FA2L1AB芯片是否支持以上功能。
可以看到GTI0CnA(n = 0 to 9)、GTIOCnB(n = 0 to 9)引脚支持输入捕获功能。
硬件原本用于测PWM的引脚是P001,该引脚没有定时器功能
选择修改引脚,这里可以看到瑞萨定时器有16位的和32位的,这里选用16位的GPT6
查询引脚图,选择定时器GTIOC6_A通道,对应引脚P400。
4.定时器输入捕获逻辑
在GTIOC6_A引脚上升沿和下降沿时都设置触发捕获,连续计数两个周期后,就可以得到四个捕获值,下降沿捕获值-上升沿捕获值可以得到PWM高电平维持的时间,连续两次下降沿捕获值相减可以得到PWM的周期时间,高电平维持时间/周期时间得到PWM的占空比。
5.定时器配置
/* 定时器输入捕获配置 */
const timer_cfg_t g_input_capture_cfg =
{
.mode = TIMER_MODE_PERIODIC, //周期型定时器
.period_counts = (uint32_t) 0xBB80, //重装载值:48000
.duty_cycle_counts = 0x5DC0, //占空比计数值:24000
.source_div = (timer_source_div_t) 0, //时钟源不分频,48MHz
.channel = 6, //定时器6
.p_callback = input_capture_user_callback, //中断回调函数
.p_context = NULL,
.p_extend = &g_input_capture_extend, //输入捕获扩展配置
.cycle_end_ipl = (0),
#if defined(VECTOR_NUMBER_GPT6_COUNTER_OVERFLOW)
.cycle_end_irq = VECTOR_NUMBER_GPT6_COUNTER_OVERFLOW, //GPT6计数器溢出中断
#else
.cycle_end_irq = FSP_INVALID_VECTOR,
#endif
};
/* 定时器输入捕获扩展配置 */
const gpt_extended_cfg_t g_input_capture_extend =
{
.gtioca =
{ .output_enabled = false, .stop_level = GPT_PIN_LEVEL_LOW }, //停止时低电平
.gtiocb =
{ .output_enabled = false, .stop_level = GPT_PIN_LEVEL_LOW },
.start_source = (gpt_source_t) (GPT_SOURCE_GTIOCA_RISING_WHILE_GTIOCB_LOW),//上升沿触发
.stop_source = (gpt_source_t) (GPT_SOURCE_NONE),
.clear_source = (gpt_source_t) (GPT_SOURCE_NONE),
.count_up_source = (gpt_source_t) (GPT_SOURCE_NONE),
.count_down_source = (gpt_source_t) (GPT_SOURCE_NONE),
.capture_a_source = (gpt_source_t) ( GPT_SOURCE_GTIOCA_FALLING_WHILE_GTIOCB_LOW |
GPT_SOURCE_GTIOCA_FALLING_WHILE_GTIOCB_HIGH |
GPT_SOURCE_GTIOCA_RISING_WHILE_GTIOCB_LOW |
GPT_SOURCE_GTIOCA_RISING_WHILE_GTIOCB_HIGH ),
//上升沿或下降沿触发
.capture_b_source = (gpt_source_t) (GPT_SOURCE_NONE),
.capture_a_ipl = (0),
.capture_b_ipl = (BSP_IRQ_DISABLED),
#if defined(VECTOR_NUMBER_GPT6_CAPTURE_COMPARE_A)
.capture_a_irq = VECTOR_NUMBER_GPT6_CAPTURE_COMPARE_A, //GPT6捕获中断
#else
.capture_a_irq = FSP_INVALID_VECTOR,
#endif
#if defined(VECTOR_NUMBER_GPT6_CAPTURE_COMPARE_B)
.capture_b_irq = VECTOR_NUMBER_GPT6_CAPTURE_COMPARE_B,
#else
.capture_b_irq = FSP_INVALID_VECTOR,
#endif
.capture_filter_gtioca = GPT_CAPTURE_FILTER_NONE, ///捕获不滤波
.capture_filter_gtiocb = GPT_CAPTURE_FILTER_NONE,
#if 0
.p_pwm_cfg = &g_input_capture_pwm_extend,
#else
.p_pwm_cfg = NULL,
#endif
};
6.中断配置
/* GPT6定时器溢出中断和A通道捕获中断 */
#define VECTOR_NUMBER_GPT6_COUNTER_OVERFLOW ((IRQn_Type) 6) /* GPT6 COUNTER OVERFLOW (Overflow) */
#define VECTOR_NUMBER_GPT6_CAPTURE_COMPARE_A ((IRQn_Type) 8) /* GPT6 CAPTURE COMPARE A (Compare match A) */
/*******************************************************************************************************************//**
* @brief User defined callback
* @param[in] p_args
* @retval None
**********************************************************************************************************************/
void input_capture_user_callback(timer_callback_args_t *p_args)
{
/* Check for the event */
switch(p_args->event)
{
/* A通道捕获中断 */
case TIMER_EVENT_CAPTURE_A :
{
/*读取端口电平状态,如果是低电平则发生的是下降沿,高电平则是上升沿*/
bsp_io_level_t p_port_value_port_400;
R_IOPORT_PinRead(&g_ioport_ctrl_1, BMU_TEST_FANPWM_PIN,
&p_port_value_port_400);
if(p_port_value_port_400 == BSP_IO_LEVEL_LOW)
{
/* 记录上次下降沿捕获数据 */
failing_capture_last = failing_capture;
failing_overflow_last = failing_overflow;
/* 记录本次下降沿捕获数据 */
failing_overflow = g_capture_overflow;
failing_capture = p_args->capture;
/* 计算PWM高电平计数值、1个周期的计数值 */
if(failing_capture >= rising_capture)
{
high_level_width = failing_capture - rising_capture;
cycle_witdh = (failing_overflow - failing_overflow_last) * 48000
+ (failing_capture - failing_capture_last);
}
}
else
{
/* 记录本次上升沿捕获数据 */
rising_capture = p_args->capture;
}
break;
}
/* 定时器周期结束 */
case TIMER_EVENT_CYCLE_END:
{
/* 记录溢出次数 */
g_capture_overflow++;
break;
}
default:
{
break;
}
}
}
本文原文来自CSDN
热门推荐
“可爱到发芽”!喜洋洋、乐融融,背后的故事来了
苏堤清明即事
覆膜的三种工艺探讨和比较
日本首都圈新建公寓1月均价下跌7%,日本公寓价格为何下降?
突然抽搐晕倒的原因及预防措施
海南,何时从广东分出来设省的?
晚上一直咳不停?常見夜咳六大原因
2025年四大银行存款利率深度解析
匡琦或接替初辉执掌北京女排,将带领球队冲击全运会
专业志愿优先是什么意思?志愿优先和平行志愿的区别
怎么优化政府业务流程以提升公共服务质量?
感冒后出现六大信号,警惕心衰找上门
一文读懂计算机视觉4大任务:分类任务、检测任务、目标分割任务、关键点检测任务
50%癌症患者是治死的?确诊后选化疗还是保守治疗?医生揭秘真相
地理面积相似,哈萨克斯坦年产9000万吨石油,新疆产量如何?
Arduino控制舵机详解(含代码)
探寻历史深处的王者典范——千古一帝的标准
孩子情绪化,乱发脾气?这3个方法,解开孩子的情绪“小疙瘩”
奶粉中的乳糖含量怎么看?
女子喷米诺地尔后变成“小毛人” 生发神器使用需谨慎
车辆报废证明需要多长时间
燥热咽痛喝什么汤?青橄榄海底椰炖瘦肉汤的功效与制作方法
IC开发——数字电路设计简介
两个电机的正反转电路,电机正反转控制电路设计
流年大运天刑是什么意思
地砖晶体大理石(水磨石地板砖):定义、分类与应用
如何通过开放协同实现团队高效合作?
一文搞懂IGBT
孩子口唇肌功能训练方法:唇部运动、舌头运动及综合训练全攻略
电脑上怎么电子签名?电子签名的应用方法?