OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7661|回复: 5

FreeRTOS+LWIP+DM9000串口一直向外面打印错误Error:..\FreeRTOS\portable\RVDS\ARM_CM3\port.c,378

[复制链接]

3

主题

6

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2017-4-12
在线时间
6 小时
发表于 2017-7-31 11:33:34 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 guoguomingming 于 2017-7-31 11:39 编辑

FreeRTOS+LWIP+DM9000在STM32F103ZET6上移植后,下载到战舰V3开发板后,串口一直向外面打印错误Error:..\FreeRTOS\portable\RVDS\ARM_CM3\port.c,378。
希望知道的能给小弟指点一二。

378行的代码如下图

378行的代码如下图
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2017-8-1 01:02:22 | 显示全部楼层
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手上路

积分
27
金钱
27
注册时间
2018-2-6
在线时间
3 小时
发表于 2018-2-6 16:11:36 | 显示全部楼层
你应该是在某个地方调用了delay_ms();这个函数,导致了任务调度,你把delay_ms();换成delay_xms();就不会引起任务调度了,也就没那个错误了。
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2017-12-15
在线时间
8 小时
发表于 2018-3-9 14:44:46 | 显示全部楼层
F103+ENC28J60+LwIP+FreeRTOS:之前断言中的位置和你出现的位置是一样的。
调试了好久,发现在源码中low_level_input中有一个pbuf_alloc中调用的memp_malloc,而源码中恰恰有sys_arch.c的sys_arch_protect()和sys_arch_unprotect()的临界保护。而low_level_input是在中断中调用的。发现参考DEMO的sys_arch.c中的sys_arch_protect()和sys_arch_unprotect()是使用的任务级的临界保护,所以芯片会出现未知的异常。改成中断级临界保护,此问题解决。此外sys_mbox_trypost也要用中断级入队函数。
出现这个问题应该就是在中断中调用了任务级临界保护,建议逐条查看中断中调用的函数中是否用到了任务级临界保护。
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2018-6-1
在线时间
2 小时
发表于 2018-6-8 14:11:41 | 显示全部楼层
顶一个
回复

使用道具 举报

1

主题

8

帖子

0

精华

新手上路

积分
45
金钱
45
注册时间
2018-6-6
在线时间
6 小时
发表于 2018-6-23 11:07:59 | 显示全部楼层
是你的接收函数有问题
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 20:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表