打印

GD32H759IMK6使用定时器0的多模式通道进行输入捕获要怎么配置

[复制链接]
2465|10
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
fz的Kevin|  楼主 | 2025-1-8 11:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 fz的Kevin 于 2025-1-8 15:44 编辑

公司的项目是要使用到GD32H759IMK6中TIMER0的8个通道进行输入捕获100Khz的方波。根据官方例程普通通道CH0、CH1、CH2、CH3能够正常捕获到,但是在使用多模式通道MCH0、MCH1、MCH2、MCH3时无论怎么配置,进入输入捕获中断函数的频率并不是由外部输入决定的,而是随着TIMER0规定的计时周期变化而变化,请教各位大佬有没有相关配置资料,或者思路。目前的配置如下:
void timer0_config(void)
{
        timer_ic_parameter_struct timer_icinitpara;
        timer_parameter_struct timer_initpara;

        rcu_periph_clock_enable(RCU_TIMER0);
        rcu_periph_clock_enable(RCU_SYSCFG);

        timer_deinit(TIMER0);
        /* TIMER0 configuration */
        timer_struct_para_init(&timer_initpara);
        timer_initpara.prescaler         = 299;
        timer_initpara.alignedmode       = TIMER_COUNTER_EDGE;
        timer_initpara.counterdirection  = TIMER_COUNTER_UP;
        timer_initpara.period            = 65535;
        timer_initpara.clockdivision     = TIMER_CKDIV_DIV1;
        timer_initpara.repetitioncounter = 0;
        timer_init(TIMER0, &timer_initpara);

        /* TIMER0 configuration */
        /* TIMER0 CH1 input capture configuration */
        timer_channel_input_struct_para_init(&timer_icinitpara);
        timer_icinitpara.icpolarity  = TIMER_IC_POLARITY_RISING;
        timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
        timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
        timer_icinitpara.icfilter    = 0x0;

        timer_input_capture_config(TIMER0, TIMER_CH_0, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_CH_1, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_CH_2, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_CH_3, &timer_icinitpara);
       
       
        timer_input_capture_config(TIMER0, TIMER_MCH_0, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_MCH_1, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_MCH_2, &timer_icinitpara);
        timer_input_capture_config(TIMER0, TIMER_MCH_3, &timer_icinitpara);
       
        timer_master_slave_mode_config(TIMER0 , TIMER_MASTER_SLAVE_MODE_ENABLE);

        timer_multi_mode_channel_mode_config(TIMER0,TIMER_MCH_0,TIMER_MCH_MODE_INDEPENDENTLY);
        timer_multi_mode_channel_mode_config(TIMER0,TIMER_MCH_1,TIMER_MCH_MODE_INDEPENDENTLY);
        timer_multi_mode_channel_mode_config(TIMER0,TIMER_MCH_2,TIMER_MCH_MODE_INDEPENDENTLY);
        timer_multi_mode_channel_mode_config(TIMER0,TIMER_MCH_3,TIMER_MCH_MODE_INDEPENDENTLY);

        timer_input_trigger_source_select(TIMER0,TIMER_SMCFG_TRGSEL_MCI0FEM0);
        timer_input_trigger_source_select(TIMER0,TIMER_SMCFG_TRGSEL_MCI1FEM1);
        timer_input_trigger_source_select(TIMER0,TIMER_SMCFG_TRGSEL_MCI2FEM2);
        timer_input_trigger_source_select(TIMER0,TIMER_SMCFG_TRGSEL_MCI3FEM3);

        timer_slave_mode_select(TIMER0 , TIMER_SLAVE_MODE_EVENT);

        /* auto-reload preload enable */
        timer_auto_reload_shadow_enable(TIMER0);
        /* clear channel 0 interrupt bit */
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_CH0);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_CH1);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_CH2);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_CH3);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_MCH0);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_MCH1);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_MCH2);
        timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_MCH3);
       
        /* channel 0 interrupt enable */
        timer_interrupt_enable(TIMER0, TIMER_INT_CH0);
        timer_interrupt_enable(TIMER0, TIMER_INT_CH1);
        timer_interrupt_enable(TIMER0, TIMER_INT_CH2);
        timer_interrupt_enable(TIMER0, TIMER_INT_CH3);
        timer_interrupt_enable(TIMER0, TIMER_INT_MCH0);
        timer_interrupt_enable(TIMER0, TIMER_INT_MCH1);
        timer_interrupt_enable(TIMER0, TIMER_INT_MCH2);
        timer_interrupt_enable(TIMER0, TIMER_INT_MCH3);
       
        /* TIMER0 counter enable */
        timer_enable(TIMER0);
}

使用特权

评论回复
沙发
b5z1giu| | 2025-2-18 13:29 | 只看该作者
多模式通道(MCH)与普通通道(CH)的配置方式有所不同。多模式通道需要正确配置其工作模式和触发源

使用特权

评论回复
板凳
lamanius| | 2025-2-18 14:47 | 只看该作者
你当前将多模式通道配置为独立模式(TIMER_MCH_MODE_INDEPENDENTLY),这意味着每个通道独立工作。如果希望多模式通道与外部输入信号同步,可以尝试配置为其他模式,例如 TIMER_MCH_MODE_SYNCHRONIZED。

使用特权

评论回复
地板
p0gon9y| | 2025-2-18 15:52 | 只看该作者
看代码来说,你配置了多个触发源(TIMER_SMCFG_TRGSEL_MCI0FEM0 等),但可能没有正确关联到多模式通道。确保触发源与多模式通道的输入信号匹配。

使用特权

评论回复
5
d1ng2x| | 2025-2-18 17:05 | 只看该作者
确保输入捕获的极性配置正确。如果外部信号是下降沿触发,需要修改为下降沿捕获

使用特权

评论回复
6
lix1yr| | 2025-2-18 18:25 | 只看该作者
我看代码来说,其配置了从模式为事件模式(TIMER_SLAVE_MODE_EVENT),这通常用于同步计数器。如果希望多模式通道与外部信号同步,可以尝试其他从模式,例如复位模式(TIMER_SLAVE_MODE_RESET)。

使用特权

评论回复
7
liu96jp| | 2025-2-18 19:34 | 只看该作者
确保在中断处理函数中正确读取捕获值,并清除中断标志。

使用特权

评论回复
8
ex7s4| | 2025-2-19 09:06 | 只看该作者
保证TIMER0 的时钟和分频配置正确。你当前配置了预分频器为 299,周期为 65535,这适用于 100kHz 的信号捕获,但需要根据实际时钟频率进行调整。

使用特权

评论回复
9
w2nme1ai7| | 2025-2-19 11:03 | 只看该作者
使用示波器检查外部输入信号,确保信号频率和极性符合预期

使用特权

评论回复
10
kaif2n9j| | 2025-2-19 13:10 | 只看该作者
在调试模式下,检查 TIMER0 的寄存器值,确认多模式通道的配置是否正确。

使用特权

评论回复
11
cen9ce| | 2025-2-19 14:22 | 只看该作者
逐步简化配置,先测试单个多模式通道,确保其工作正常后再扩展到多个通道。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

主题

1

帖子

0

粉丝