选型,实现USB转2路CAN功能,目前看到STM32F407和STM32H750都有2路CAN,都能实现功能吗?
STM32H743 HSE 48MHz晶振无法实现
STM32H743 配置USBOTG 使用U盘几周后 stm32无法识别usb
STM32H7A3RGT6 ADC 8位采样速度只能达到3.5MSPS达不到数据手册上的7MSPS ?
关于硬件ECC
LPTIM5的事件Lptim5_ait作为14号Trigger input输入到DMAMUX2 Request generator触发BDMA未生成中断问题
关于NAND FLASH加LittleFS的方案
DMAMUX 使用内部外设Request Event(不使用TIM12和LPTIM)
【经验分享】STM32H7 DMA+UART不定长接收实战:解决缓存溢出与数据错位问题
STM32H747 D2域的问题
微信公众号
手机版
[md]不同任务使用同一个串口发送,当然要保证上一帧发送完成才发送下一帧。可以使用消息队列等方式,将同一个串口的发送函数放到同一个任务中。
HAL库串口使用中断方式接收时,如果发送用阻塞或者DMA方式,会有可能卡死。如果是485半双工通信,收发不同时发生,一般没问题。至于为什么,在
HAL_UART_Receive_IT处理过程中会先LOCK串口,处理完再UNLOCK,实际上这段时间内串口变成半双工了。可以收发都用IT方式,怕消耗CPU资源都用DMA也好。
[md]你分析的是收和发的冲突,实际上我把程序中所有串口的收发全改成中断方式后仍然存在极小概率死机(每秒一次发送,大概1小时到一天左右发生一次)的现象,死机位置是一直等待串口发送完成,因此我怀疑是两个不同优先级的线程同时使用串口发送引起的,目前的做法是不同线程如果需要使用同一个串口的发送函数,那么让不同线程分别在不同时间段发送(时间分段)。
[md]如果多任务使用同一个串口的发送,肯定得保证上一帧发送完成才发送下一帧。可以使用消息队列等方式,让串口的发送函数保持在一个任务中处理。
[md]谢谢,习惯了以前前后台的编程方式,转FreeRTOS只会简单的拆分任务,像一些消息队列类的还做不到能灵活处理,慢慢适应吧!