打印

兆易专家看过来,GD32F103守时器的最小分频是4分频

[仿制链接]
235|8
跳转到指定楼层
楼主
本帖最终由 davidgdg 于 2019-6-19 18:05 修改

      有个旧项目,想把代码移植到GD32F103上来,现遇到这样一个问题。原先运用的是Ti的TMS320F28027,芯片,主频运用的50M,守时能够做到最小0分频,也便是Timer的步长为20ns,现在运用GD32F103C8T6芯片,运用的内部晶振108M,想取得分辨率更高的守时,甚至于到达0分频,但是我设置如下,用示波器测验Timer的最小分频是4分频,也就最小步长是27ns,明显这个108M的芯片,精度还不如50M芯片的精度高。请技能专家帮我剖析一下,代码如下:
void PWM0_Configuration(void)
{
    timer_oc_parameter_struct timer_ocintpara;
    timer_parameter_struct timer_initpara;
    timer_break_parameter_struct timer_breakpara;

    rcu_periph_clock_enable(RCU_TIMER0);

    timer_deinit(TIMER0);

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

    /* CH0/CH0N configuration in PWM mode0 */
    timer_ocintpara.outputstate  = TIMER_CCX_ENABLE;
    timer_ocintpara.outputnstate = TIMER_CCXN_ENABLE;
    timer_ocintpara.ocpolarity   = TIMER_OC_POLARITY_HIGH;
    timer_ocintpara.ocnpolarity  = TIMER_OCN_POLARITY_HIGH;
    timer_ocintpara.ocidlestate  = TIMER_OC_IDLE_STATE_LOW;
    timer_ocintpara.ocnidlestate = TIMER_OCN_IDLE_STATE_LOW;

    timer_channel_output_config(TIMER0,TIMER_CH_0,&timer_ocintpara);

    timer_channel_output_pulse_value_config(TIMER0,TIMER_CH_0,175);  //
    timer_channel_output_mode_config(TIMER0,TIMER_CH_0,TIMER_OC_MODE_PWM0);
    timer_channel_output_shadow_config(TIMER0,TIMER_CH_0,TIMER_OC_SHADOW_DISABLE);

    /* automatic output enable, break, dead time and lock configuration*/
    timer_breakpara.runoffstate      = TIMER_ROS_STATE_DISABLE;
    timer_breakpara.ideloffstate     = TIMER_IOS_STATE_DISABLE ;
    timer_breakpara.deadtime         = 10;
    timer_breakpara.breakpolarity    = TIMER_BREAK_POLARITY_LOW;
    timer_breakpara.outputautostate  = TIMER_OUTAUTO_ENABLE;
    timer_breakpara.protectmode      = TIMER_CCHP_PROT_OFF;
    timer_breakpara.breakstate       = TIMER_BREAK_ENABLE;
    timer_break_config(TIMER0,&timer_breakpara);

    /* TIMER0 primary output function enable */
    timer_primary_output_config(TIMER0,ENABLE);
    timer_auto_reload_shadow_enable(TIMER0);
    timer_enable(TIMER0);
}
沙发
| 2019-6-19 22:36 | 只看该作者
话说你用TI也是运用它的内部晶振吗,,,,GD的内部RC振荡器你了解过吗
板凳
| 2019-6-19 23:59 | 只看该作者
看了手册,,,TIMER0的分辨率应该是最高的,,,假如timer0都不可恐怕只能换其他的,,或许超频试试
地板
 楼主 | 2019-6-20 08:40 | 只看该作者
没有GD的专家过来看一下吗?Timer0的最小步长能为1/108M ns吗?  Ti我是运用的内部晶振50M  能够输出到最小步长 1/50M,也便是20ns。
5
| 2019-6-20 11:17 | 只看该作者
我估量是IO翻转速度的原因,比方你说的最小步是1/108ns,假如你测验2小步,10小步或许爽性108小步试试。
6
 楼主 | 2019-6-20 16:04 | 只看该作者
现在测验成果便是,不管我设置timer_initpara.clockdivision     = TIMER_CKDIV_DIV1; 或许timer_initpara.clockdivision     = TIMER_CKDIV_DIV4; 得到的成果都是相同的,也便是体系默许的现已对主频进行了4分频的操作。我不知道这是什么原因,请原厂解释一下。
7
| 2019-6-20 16:38 | 只看该作者
去看看手册,“复位和时钟单元(RCU)”,看看上级是不是分配了
8
| 2019-6-20 16:41 | 只看该作者
这个时钟分频是和死区时刻有联络的,所以改动这个值,只会导致死区时刻不相同,不会对PWM波频率产生影响,Timer0是挂在APB2总线上的,最大的频率是108MHZ,假如想要从源头就改Timer0的时钟,那么就要设置APB2分频,而不是timer_initpara.clockdivision这个值。至于IO步长,因为遭到IO速度的影响,只能最大到50M,也便是20ns,假如还不能满意要求,能够试试兆易的F303芯片或许E103芯片,这两款都能够将IO翻转速度设置为最大120M,我想应该能满意你的要求。

468935d0b45cad1b7f.png (72.83 KB, 下载次数: 0)

468935d0b45cad1b7f.png
9
| 2019-7-10 10:02 | 只看该作者
看帖子长常识了
扫描二维码,随时随地手机跟帖
*滑动验证:
您需求登录后才能够回帖 登录 | 注册

本版积分规矩

我要发帖 投诉主张 创立版块 请求版主

快速回复

您需求登录后才能够回帖
登录 | 注册
高档形式

论坛热帖

在线客服 快速回复 回来顶部 回来列表