STM32CubeMx定时器基本使用方法

第一步:
具体配置如下图:激活需要使用到的外设定时器,当系统时钟频率为64mhz时,我们希望1ms发生中断一次; 就可以把时钟的预分频系数设置为64-1; 计数周期设置为1000-1; 计数方式为 up 向上计数,此时得到的中断频率为:64,000,000 /64 /1000 = 1ms = 1khz ;
第二步:
可以根据自身需要在nvic 中断控制器中配置中断响应优先级。
第三步:
代码分析:
先看tim7的初始化函数:static void mx_tim7_init(void)static void mx_tim7_init(void){ /* user code begin tim7_init 0 */ /* user code end tim7_init 0 */ tim_masterconfigtypedef smasterconfig = {0}; /* user code begin tim7_init 1 */ /* user code end tim7_init 1 */ htim7.instance = tim7; htim7.init.prescaler = 64-1; htim7.init.countermode = tim_countermode_up; htim7.init.period = 1000-1; htim7.init.autoreloadpreload = tim_autoreload_preload_disable; if (hal_tim_base_init(&htim7) != hal_ok) { error_handler(); } smasterconfig.masteroutputtrigger = tim_trgo_reset; smasterconfig.masterslavemode = tim_masterslavemode_disable; if (hal_timex_masterconfigsynchronization(&htim7, &smasterconfig) != hal_ok) { error_handler(); } /* user code begin tim7_init 2 */ //在这这里添加这行代码,意思是初始化完成便开启定时器中断计数 hal_tim_base_start_it(&htim7); /* user code end tim7_init 2 */}/* user code begin 4 *///在begin 4 中添加定时器中断服务函数void hal_tim_periodelapsedcallback(tim_handletypedef *htim){ if (htim->instance == htim7.instance) //如果是tim7响应进来的中断 { ms ++; //前面配置中断更新时间为1ms,那么这里进来一次ms加一次 if(ms == 1000) //当ms加到1000时,即1s { hal_gpio_togglepin(led1_gpio_port,led1_pin); //即1s led翻转一次 ms =0; //ms用完后记得清0 } }}/* user code end 4 */如果能理解到这里,恭喜你已经学会了定制器的基本操作!

电动汽车电池技术的发展道路依旧漫长
Linux系统不停的报磁盘已满应该如何处理
压力校验台怎样分类
常规全彩LED显示屏与舞台LED显示屏的区别
你需要更合适的AR/VR 交互方式吗?Claw 或许可以
STM32CubeMx定时器基本使用方法
09新款MacBook全方位赏析
中美贸易战下一个殃及之鱼——金融市场
一面听话的智能魔镜!
单片机驱动步进电机程序
数字化是如何推动城市更智慧的
封测、芯片涨价潮对国内影响几何?
锤子科技已经陷入了巨大资金危机中
OPPO K3即将发布搭载骁龙710处理器起售价最高为1799元
西门子S7-200SMART指针的建立方法
多层PCB板其中有什么奥秘
从端到端 英特尔全面激活无人驾驶生态势能
深入探讨功率MOSFET变化对电流和电压回路行为的影响
为什么要使用医用超声波清洗机来清洗医疗器械呢?
LDR6028/LDR6023ss 数据快充传输pd芯片性价比方案