
前言 STM32 最早提供固件库开发,在当时也是一个很大的创新。导致大量攻城狮熟悉了固件库开发,后面STM32又慢慢推出HAL开发模式,这种开发模式是开发过程更高效便捷,但是最大的缺点就是效率。其实熟悉STM32的开发人员,可以将HAL库转为固件库开发方式,这里以串口为例提供一点自己的看法。 历经STM32从寄存器到固件库到hal库开发过程,这个过程还是有很多感触的。现在ST也是主推hal库开发,hal库开发以串口为例,ST实现了很多串口的处理过程,使开发更便捷,但是效率太低了,占用了比较多的ROM和ram资源,这针对成本敏感的应用场景是不能接受的。 但是攻城狮就要放弃hal库开发吗,个人看法不是的。Hal库开发是主流吧,随着芯片工艺越来越高,芯片集成度越来越高,嵌入的IP也是越来越复杂。随着芯片的主频越高,算力越强hal库开发的优点就越突出。 其实还有一种方式,就是优化hal库,你不是嫌弃ST的处理过程复杂吗,你可以同样使用hal库,修改成自己的处理方式。 案例1 案例1:串口中断方式接收数据 这里可以选择打开串口接收中断,在串口接收中断中,将数据收集到缓存中。配置CUBE如下图 ![]() ![]() 打开串口中断 __HAL_UART_ENABLE_IT(&huart1, UART_IT_RXNE); 针对串口中断的处理如下图所示, 其中1,清除串口接收中断,处理接收的串口数据 其中2,清除溢出中断 其中3,屏蔽掉hal库函数的串口处理过程 ![]() 这样几步处理下来,基本回到了固件库的编程模式,这是习惯了固件库开发的攻城狮喜欢的方式。 后面希望可以做出更多,这样更改的案例。 ———————————————— 版权声明:大牛攻城狮 |
STM32 GUI LTDC 最大像素时钟评估方法
【2025·STM32峰会】GUI解决方案实训分享1-对LVGL咖啡机例程的牛刀小试以及问题排查
OpenBLT移植到STM32F405开发板
为什么要先开启STM32外设时钟?
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【经验分享】STM32实例-RTC实时时钟实验④-获取RTC时间函数与中断服务函数
STM32 以太网 MAC Loopback 的实现
STM32功能安全设计包,助力产品功能安全认证
基于STM32启动过程startup_xxxx.s文件经验分享
HRTIM 指南