OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3417|回复: 5

请教关于MDK优化等级的问题 同样的程序不同优化等级得到结果不同

[复制链接]

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2018-6-16
在线时间
19 小时
发表于 2019-2-26 23:36:05 | 显示全部楼层 |阅读模式
1金钱
程序如下:
         GPIO_InitTypeDef GPIO_InitStructure;
        TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
        TIM_OCInitTypeDef  TIM_OCInitStructure;

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;  
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE);
        // PWM初始化
        // 自动重装载寄存器的值,累计TIM_Period+1个频率后产生一个更新或者中断
        TIM_TimeBaseStructure.TIM_Period = 654;
        // 时钟预分频数
        TIM_TimeBaseStructure.TIM_Prescaler = (100 - 1);
        // 时钟分频因子 ,
        TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
        // 计数器计数模式,设置为向上计数
        TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
        // 重复计数器的值,没用到不用管
        TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
        // 初始化定时器
        TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);

        // 配置为PWM模式1
        TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2;
        // 输出使能
        TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
        // 输出通道脉宽
        TIM_OCInitStructure.TIM_Pulse = 354;  
        // 输出通道电平极性配置        
        TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
        TIM_OC1Init(TIM1, &TIM_OCInitStructure);
        TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Enable);

        //在ARR上启用或禁用TIMx外围设备预加载寄存器。
        TIM_ARRPreloadConfig(TIM1, ENABLE);
        //声音输出TIM通道比较寄存器缓冲使能
        TIM_CtrlPWMOutputs(TIM1,ENABLE);
        TIM_Cmd(TIM1, ENABLE);



用o0优化等级没有方波
用o2优化等级有方波 正常


正常

正常

正常

正常

有问题

有问题

有问题

有问题

最佳答案

查看完整内容[请看2#楼]

很正常,运行效率不一样,执行TIM开启的时间也不一样,你看CNT的时候,数据变化也不一样。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2019-2-26 23:36:06 | 显示全部楼层
很正常,运行效率不一样,执行TIM开启的时间也不一样,你看CNT的时候,数据变化也不一样。
回复

使用道具 举报

11

主题

1044

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3722
金钱
3722
注册时间
2011-5-23
在线时间
2013 小时
发表于 2019-2-27 00:11:47 | 显示全部楼层
[mw_shl_code=cpp,true]                GPIO_InitTypeDef GPIO_InitStructure;
        TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
        TIM_OCInitTypeDef  TIM_OCInitStructure;
[/mw_shl_code]
目测是这3个结构体里面有末初始化所成员,请检查一下。
RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

6

主题

315

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1669
金钱
1669
注册时间
2018-1-29
在线时间
160 小时
发表于 2019-2-27 07:04:56 | 显示全部楼层
这就是传说中的负优化吗?
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2018-6-16
在线时间
19 小时
 楼主| 发表于 2019-2-28 15:49:41 | 显示全部楼层
aozima 发表于 2019-2-27 00:11
[mw_shl_code=cpp,true]                GPIO_InitTypeDef GPIO_InitStructure;
        TIM_TimeBaseInitTypeDef  TIM_T ...

谢谢 帮助 我去试试
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2018-6-16
在线时间
19 小时
 楼主| 发表于 2019-2-28 15:50:30 | 显示全部楼层
正点原子 发表于 2019-2-26 23:36
很正常,运行效率不一样,执行TIM开启的时间也不一样,你看CNT的时候,数据变化也不一样。

谢谢 帮助
但是还是不太明白
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-23 17:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表