stm32查看代码运行时间[stm32f7xx]

1、初始化1个定时器

TIM5_Init(-1,108-1);//arr为最大值(unsigned int)-1,让其一直往上加,最大值42亿us,即最大可表示4200秒,分频系数psc为108,即每+1等于1us

void TIM5_Init(u32 arr,u16 psc)
{  
    TIM5_Handler.Instance=TIM5;                                          //通用定时器5
    TIM5_Handler.Init.Prescaler=psc;     //分频  //可设置范围为0至65535,实现1至65536分频 此处psc+1分频
    TIM5_Handler.Init.CounterMode=TIM_COUNTERMODE_UP;                    //向上计数器
    TIM5_Handler.Init.Period=arr;                                        //自动装载值
    TIM5_Handler.Init.ClockDivision=TIM_CLOCKDIVISION_DIV1;              //时钟分频因子
    HAL_TIM_Base_Init(&TIM5_Handler);
    HAL_TIM_Base_Start_IT(&TIM5_Handler);       //使能定时器5和定时器5更新中断:TIM_IT_UPDATE 
}

2、定义全局变量

unsigned int t1,t2;//用于保存执行代码前后的定时器5的计数器值

 

3、具体运用在代码上

    t1=TIM5_Handler.Instance->CNT;
    AT24CXX_Write(79,ppp,30);//查看改行代码花费时间
    t2=TIM5_Handler.Instance->CNT;

    t2-t1等于代码执行花费时间,单位为us

 

4、特别说明:TIM5_Handler.Instance->CNT超过最大值42亿时,会清零

 

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值