OpenEdv-开源电子网

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

STM32F407在网络通信中出现问题

[复制链接]

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2015-11-16
在线时间
31 小时
发表于 2016-7-29 17:24:16 | 显示全部楼层 |阅读模式
10金钱
探索者开发板,MCU是STM32F407,用的UCOSII + LWIP,使用官方contrib-1.4.1的PING例程测试,在发出PING后出现错误“Assertion "netconn_accept: invalid recvmbox" failed at line 464 in ..\LWIP\lwip-1.4.1\src\api\api_lib.c”,接收邮箱无效。可是在测试TCP服务器时是能正常接收和发送数据的。请问是怎么回事呢?该如何解决?多谢!

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

14

主题

1592

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
2622
金钱
2622
注册时间
2014-7-17
在线时间
350 小时
发表于 2016-7-29 17:54:31 | 显示全部楼层
OS的信息事件设置大一点。。
回复

使用道具 举报

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2015-11-16
在线时间
31 小时
 楼主| 发表于 2016-7-29 18:06:45 | 显示全部楼层
已经是60了
回复

使用道具 举报

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2015-11-16
在线时间
31 小时
 楼主| 发表于 2016-7-29 18:07:08 | 显示全部楼层
#define OS_MAX_EVENTS            60u   /*应用中最多事件控制块的数目 Max. number of event control blocks in your application      */
#define OS_MAX_FLAGS             56u   /*系统最大的信号量集数/应用中最多事件标志组的数目Max. number of Event Flag Groups    in your application 6     */
#define OS_MAX_MEM_PART          6u   /*内存块数目 Max. number of memory partitions                    6         */
#define OS_MAX_QS                50u   /* 定义可以在任务中使用的最大消息队列数目Max. number of queue control blocks in your application   6   */
#define OS_MAX_TASKS             62u   /* 最多任务数,必须大于或者等于2Max. number of tasks in your application, MUST be >= 2       */
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2016-7-29 20:16:17 | 显示全部楼层
是移植的我们的代码么?
回复

使用道具 举报

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2015-11-16
在线时间
31 小时
 楼主| 发表于 2016-7-30 08:58:37 | 显示全部楼层
正点原子 发表于 2016-7-29 20:16
是移植的我们的代码么?

是在你们代码基础上加入的官方PING例程。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2016-7-30 19:41:17 | 显示全部楼层
lrser 发表于 2016-7-30 08:58
是在你们代码基础上加入的官方PING例程。

在内存管理里面(申请和释放函数),增加保护试试
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

15

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2015-11-16
在线时间
31 小时
 楼主| 发表于 2016-8-1 08:08:17 | 显示全部楼层
正点原子 发表于 2016-7-30 19:41
在内存管理里面(申请和释放函数),增加保护试试

已经加了保护:
//释放内存(外部调用)
//memx:所属内存块
//ptr:内存首地址
void myfree(u8 memx,void *ptr)  
{  
//        u32 offset;  
//    if(ptr==NULL)return;//地址为0.  
//         offset=(u32)ptr-(u32)mallco_dev.membase[memx];  
//    mymem_free(memx,offset);//释放内存  

        OS_CPU_SR cpu_sr=0;
        u32 offset;   
        if(ptr==NULL)return;                //地址为0.  
        OS_ENTER_CRITICAL();                //添加保护
        offset=(u32)ptr-(u32)mallco_dev.membase[memx];     
    mymem_free(memx,offset);//释放内存
        OS_EXIT_CRITICAL();
}  

//分配内存(外部调用)
//memx:所属内存块
//size:内存大小(字节)
//返回值:分配到的内存首地址.
void *mymalloc(u8 memx,u32 size)  
{  
//  u32 offset;                                                                               
//        offset=mymem_malloc(memx,size);                                               
//  if(offset==0XFFFFFFFF)return NULL;  
//  else return (void*)((u32)mallco_dev.membase[memx]+offset);  
        OS_CPU_SR cpu_sr=0;
    u32 offset;   
        OS_ENTER_CRITICAL();                //添加保护       
        offset=mymem_malloc(memx,size);  
        OS_EXIT_CRITICAL();                           
    if(offset==0XFFFFFFFF)return NULL;  
    else return (void*)((u32)mallco_dev.membase[memx]+offset);
}  
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2016-8-3 22:32:58 | 显示全部楼层
lrser 发表于 2016-8-1 08:08
已经加了保护:
//释放内存(外部调用)
//memx:所属内存块

那就慢慢调试找问题了.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2016-10-25
在线时间
5 小时
发表于 2017-6-22 21:52:42 | 显示全部楼层
我也遇到这个问题了,请问前辈如何解决的。

我是使用了6个线程,创建了3个TCP链接。tcp_clientconn = netconn_new(NETCONN_TCP);  3个发数据 。3个收数据. 任意两个链接上收发都没有问题。 只要3个都链接上。发数据正常,一开启第三个接收。就出现问题“Assertion "netconn_accept: invalid recvmbox" failed at line 464 in ..\LWIP\lwip-1.4.1\src\api\api_lib.c”,
回复

使用道具 举报

93

主题

745

帖子

1

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1843
金钱
1843
注册时间
2012-9-16
在线时间
285 小时
发表于 2017-10-23 13:36:39 | 显示全部楼层
我也遇到了,标记一下
纵浪大化中,不喜亦不惧;应尽便须尽,无复独多虑!
回复

使用道具 举报

1

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2017-4-18
在线时间
25 小时
发表于 2019-1-28 23:53:27 | 显示全部楼层
请问楼主解决了么?是什么问题
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-24 18:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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