专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
关于HAL库,在stm32f4上串口溢出问题。
2019-07-20 06:10
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
7084
6
1432
今天移植了原子的 ALIENTEK 阿波罗STM32F429开发板 的HAL库版串口程序,发现如果发送数量大于接收缓存就会造成串口溢出,表现为,之后PC端能正常接收到开发板发过来的信息,但是PC端发送给开发板信息无反应。各位有遇到过得嘛
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
linxiaoming
2019-07-21 01:53
本帖最后由 linxiaoming 于 2018-9-11 17:20 编辑
可以做一个双缓冲,用于 接收中断中存放接收字节的数组 rx_fifo可以设置为1。然后自己再根据实际需求,定义一个缓冲数组 fifo[];实测用PC发送一组数据到单片机,发送完成后触发超时,标志位F_timeout=1, 然后单片机再发给PC数据。
代码如下
#include "app.h"
/*============================================================================================
* 系统定时器中断
*============================================================================================*/
static uint16 count1 = 0;
static uint16 count2 = 0;
void HAL_SYSTICK_Callback(void)
{
sys.F_1ms = 1;
count1++;
if(count1>=10)
{
count1 = 0;
sys.F_10ms = 1;
}
count2++;
if(count2>=100)
{
count2 = 0;
sys.F_100ms = 1;
}
}
/*============================================================================================
* 串口接收中断
*============================================================================================*/
uint8 fifo[5000]; //二层接收缓冲
uint16 p1=0; //接收数量
uint8 rx_fifo[1]; //一层接收缓冲,用于官方库函数
extern UART_HandleTypeDef huart1;
/*============================================================================================
* 超时检测
*============================================================================================*/
uint8 E_timeout=0;
uint8 F_timeout=0;
uint8 C_timeout=0;
void func_timeout()
{
if(E_timeout)
{
C_timeout++;
if(C_timeout>=100)
{
C_timeout = 0;
F_timeout = 1;
}
}
else
{
C_timeout = 0;
F_timeout = 0;
}
}
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
uint8 i=0;
UNUSED(huart1);
HAL_UART_Receive_IT(&huart1,rx_fifo,sizeof(rx_fifo)); //接收函数
fifo[p1] = rx_fifo[0];
p1++;
if(p1>=5000)
{
p1 = 0;
}
/*接收超时检测:接收到数据-->开启超时检测并reset计数值*/
E_timeout = 1;
C_timeout = 0;
}
然后主程序中
if(sys.F_1ms)
{
sys.F_1ms = 0;
func_timeout();
if(F_timeout)
{
F_timeout = 0;
E_timeout = 0;
HAL_UART_Transmit_IT(&huart1,fifo,p1);
p1 = 0;
}
}
实测截图:同一段文字复制了很多次,一次发送总计4000多byte
file:///D:/%E5%B8%B8%E7%94%A8%E8%BD%AF%E4%BB%B6/YoudaoNote/%E7%AC%94%E8%AE%B0/qq127390A56C09F11E62A2848E550B9AE2/937870868bab47bf83f8b02436721836/%7Eqhb_d2d_gfa.png
加载中...
查看其它6个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
可以做一个双缓冲,用于 接收中断中存放接收字节的数组 rx_fifo可以设置为1。然后自己再根据实际需求,定义一个缓冲数组 fifo[];实测用PC发送一组数据到单片机,发送完成后触发超时,标志位F_timeout=1, 然后单片机再发给PC数据。
代码如下
#include "app.h"
/*============================================================================================
* 系统定时器中断
*============================================================================================*/
static uint16 count1 = 0;
static uint16 count2 = 0;
void HAL_SYSTICK_Callback(void)
{
sys.F_1ms = 1;
count1++;
if(count1>=10)
{
count1 = 0;
sys.F_10ms = 1;
}
count2++;
if(count2>=100)
{
count2 = 0;
sys.F_100ms = 1;
}
}
/*============================================================================================
* 串口接收中断
*============================================================================================*/
uint8 fifo[5000]; //二层接收缓冲
uint16 p1=0; //接收数量
uint8 rx_fifo[1]; //一层接收缓冲,用于官方库函数
extern UART_HandleTypeDef huart1;
/*============================================================================================
* 超时检测
*============================================================================================*/
uint8 E_timeout=0;
uint8 F_timeout=0;
uint8 C_timeout=0;
void func_timeout()
{
if(E_timeout)
{
C_timeout++;
if(C_timeout>=100)
{
C_timeout = 0;
F_timeout = 1;
}
}
else
{
C_timeout = 0;
F_timeout = 0;
}
}
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
uint8 i=0;
UNUSED(huart1);
HAL_UART_Receive_IT(&huart1,rx_fifo,sizeof(rx_fifo)); //接收函数
fifo[p1] = rx_fifo[0];
p1++;
if(p1>=5000)
{
p1 = 0;
}
/*接收超时检测:接收到数据-->开启超时检测并reset计数值*/
E_timeout = 1;
C_timeout = 0;
}
然后主程序中
if(sys.F_1ms)
{
sys.F_1ms = 0;
func_timeout();
if(F_timeout)
{
F_timeout = 0;
E_timeout = 0;
HAL_UART_Transmit_IT(&huart1,fifo,p1);
p1 = 0;
}
}
实测截图:同一段文字复制了很多次,一次发送总计4000多byte
file:///D:/%E5%B8%B8%E7%94%A8%E8%BD%AF%E4%BB%B6/YoudaoNote/%E7%AC%94%E8%AE%B0/qq127390A56C09F11E62A2848E550B9AE2/937870868bab47bf83f8b02436721836/%7Eqhb_d2d_gfa.png
一周热门 更多>