OpenEdv-开源电子网

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

FreeRTOS+LWIP连上串口就一直输出\portable\RVDS\ARM_CM4F\port.c,441

[复制链接]

1

主题

3

帖子

0

精华

新手上路

积分
32
金钱
32
注册时间
2016-10-24
在线时间
10 小时
发表于 2017-8-9 10:24:46 | 显示全部楼层 |阅读模式
10金钱
FreeRTOS+LWIP连上串口就一直输出\portable\RVDS\ARM_CM4F\port.c,441。
另外编译的时候全编译时会报很多警告,再编译一下又不见了,对照了官方例程里边出现警告的位置代码都是一样的。

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

使用道具 举报

1

主题

3

帖子

0

精华

新手上路

积分
32
金钱
32
注册时间
2016-10-24
在线时间
10 小时
 楼主| 发表于 2017-8-10 06:26:23 来自手机 | 显示全部楼层
回复

使用道具 举报

558

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
164897
金钱
164897
注册时间
2010-12-1
在线时间
2100 小时
发表于 2017-8-12 02:11:34 | 显示全部楼层
帮顶
回复

使用道具 举报

5

主题

40

帖子

0

精华

初级会员

Rank: 2

积分
141
金钱
141
注册时间
2015-1-10
在线时间
19 小时
发表于 2017-9-19 19:57:27 | 显示全部楼层
同样问题,求教
回复

使用道具 举报

558

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
164897
金钱
164897
注册时间
2010-12-1
在线时间
2100 小时
发表于 2017-9-20 00:37:53 | 显示全部楼层
帮顶
回复

使用道具 举报

0

主题

27

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
461
金钱
461
注册时间
2014-1-11
在线时间
94 小时
发表于 2017-10-5 12:29:24 | 显示全部楼层
没有人知道么?我的串口中断里接收数据发送到队列,然后在任务里把队列打印出来,遇到了相同的问题,但是是可以用的.只是串口上输出这个错误
回复

使用道具 举报

15

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
230
金钱
230
注册时间
2015-3-12
在线时间
17 小时
发表于 2017-10-8 13:12:34 | 显示全部楼层
原子哥啥时候出FreeRTOS上做LWIP的视频呀
回复

使用道具 举报

558

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
164897
金钱
164897
注册时间
2010-12-1
在线时间
2100 小时
发表于 2017-10-8 18:22:53 | 显示全部楼层
挣点圆子 发表于 2017-10-8 13:12
原子哥啥时候出FreeRTOS上做LWIP的视频呀

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

使用道具 举报

0

主题

27

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
461
金钱
461
注册时间
2014-1-11
在线时间
94 小时
发表于 2017-10-10 18:55:28 | 显示全部楼层

我也在等这个视频哦.没计划也等,等到死
回复

使用道具 举报

12

主题

241

帖子

0

精华

高级会员

Rank: 4

积分
806
金钱
806
注册时间
2017-8-17
在线时间
159 小时
发表于 2017-10-21 16:45:44 | 显示全部楼层
不是写着问题在哪儿的么,去看看是哪个断言出错不就知道了
回复

使用道具 举报

22

主题

112

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
367
金钱
367
注册时间
2017-10-19
在线时间
71 小时
发表于 2017-11-10 16:27:44 | 显示全部楼层

请问你解决了吗?
回复

使用道具 举报

22

主题

112

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
367
金钱
367
注册时间
2017-10-19
在线时间
71 小时
发表于 2017-11-10 16:28:27 | 显示全部楼层
请问你解决了吗?
回复

使用道具 举报

22

主题

112

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
367
金钱
367
注册时间
2017-10-19
在线时间
71 小时
发表于 2017-11-10 16:28:50 | 显示全部楼层
qufu-cl 发表于 2017-10-5 12:29
没有人知道么?我的串口中断里接收数据发送到队列,然后在任务里把队列打印出来,遇到了相同的问题,但是是可以 ...

请问你解决了吗?
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2017-12-15
在线时间
8 小时
发表于 2018-3-9 14:37:23 | 显示全部楼层
F103+ENC28J60+LwIP+FreeRTOS:之前断言中的位置和你出现的位置是一样的。
调试了好久,发现在源码中low_level_input中有一个pbuf_alloc,而源码中恰恰有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也要用中断级入队函数。
出现这个问题应该就是在中断中调用了任务级临界保护,建议逐条查看中断中调用的函数中是否用到了任务级临界保护。
回复

使用道具 举报

5

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
90
金钱
90
注册时间
2018-4-18
在线时间
24 小时
发表于 2018-5-2 19:28:28 | 显示全部楼层
jljljadfd 发表于 2018-3-9 14:37
F103+ENC28J60+LwIP+FreeRTOS:之前断言中的位置和你出现的位置是一样的。
调试了好久,发现在源码中low_le ...

请问您是怎么解决的,没有搞懂。能发个例程看一下吗?一直没调好,麻烦你了
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2017-12-15
在线时间
8 小时
发表于 2018-5-11 14:21:55 | 显示全部楼层
Zcf5252057 发表于 2018-5-2 19:28
请问您是怎么解决的,没有搞懂。能发个例程看一下吗?一直没调好,麻烦你了

留个邮箱吧 这个我不知道怎么上传
回复

使用道具 举报

0

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
181
金钱
181
注册时间
2017-12-13
在线时间
46 小时
发表于 2018-10-12 09:10:01 | 显示全部楼层
jljljadfd 发表于 2018-5-11 14:21
留个邮箱吧 这个我不知道怎么上传

能麻烦传一下你的例程吗
论坛上传附件就可以了,回复时点-高级模式-附件,就可以了
最近在弄这个,也出现了这个问题。。。
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
13
金钱
13
注册时间
2019-2-13
在线时间
2 小时
发表于 2019-2-16 14:30:56 | 显示全部楼层
你好   请问问题解决了吗  我也遇到了
回复

使用道具 举报

9

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2013-4-26
在线时间
19 小时
发表于 2019-4-18 15:13:47 | 显示全部楼层
jljljadfd 发表于 2018-5-11 14:21
留个邮箱吧 这个我不知道怎么上传

你好,麻烦您可以发我一份不,我现在也碰到这个问题,非常感谢,我的邮箱1499559845@qq.com.
回复

使用道具 举报

0

主题

23

帖子

0

精华

初级会员

Rank: 2

积分
122
金钱
122
注册时间
2018-9-26
在线时间
25 小时
发表于 2019-9-2 08:37:58 | 显示全部楼层
jljljadfd 发表于 2018-3-9 14:37
F103+ENC28J60+LwIP+FreeRTOS:之前断言中的位置和你出现的位置是一样的。
调试了好久,发现在源码中low_le ...

的确是这样的,我也碰到相同的问题,根据楼主所说的,改了一下就OK了
#define SCB_ICSR_REG                 (*((volatile unsigned int *)0xE000ED04))
sys_prot_t sys_arch_protect(void)
{
        //vPortEnterCritical();
        //return 1;

        if(SCB_ICSR_REG & 0xFF)
        {
                return taskENTER_CRITICAL_FROM_ISR();
        }
        else
        {
                taskENTER_CRITICAL();
                return 0;
        }
}

void sys_arch_unprotect(sys_prot_t pval)
{
        //( void ) pval;
        //vPortExitCritical();

        if(SCB_ICSR_REG & 0xFF)
        {
                taskEXIT_CRITICAL_FROM_ISR(pval);
        }
        else
        {
                taskEXIT_CRITICAL();
        }       
}

err_t sys_mbox_trypost(sys_mbox_t *mbox, void *msg)
{
//err_t result;

//   if ( xQueueSend( *mbox, &msg, 0 ) == pdPASS )
//   {
//      result = ERR_OK;
//   }
//   else {
//      // could not post, queue must be full
//      result = ERR_MEM;
//                       
//#if SYS_STATS
//      lwip_stats.sys.mbox.err++;
//#endif /* SYS_STATS */                       
//   }

//   return result;

    BaseType_t xHigherPriorityTaskWoken = pdFALSE;

    if(msg==NULL)
        msg= (void*)&NullMessage;

    if((SCB_ICSR_REG&0xFF) == 0)
    {
        if(xQueueSendToBack(*mbox, &msg, 0)!= pdPASS)
                return ERR_MEM;
    }
    else
    {
        if(xQueueSendToBackFromISR(*mbox, &msg, &xHigherPriorityTaskWoken)!= pdPASS)
                return ERR_MEM;
        portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
    }
    return ERR_OK;
}
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2019-5-5
在线时间
11 小时
发表于 2019-9-2 14:58:07 | 显示全部楼层


原子哥,我想用LWIP协议,NETCONN-TCP客户端实验给上位机发送ADC采样的电压值,但是我看netconn_write函数发送的数据为常量,怎样发送ADC的采样值到上位机呢?求指点,谢谢
回复

使用道具 举报

12

主题

101

帖子

0

精华

高级会员

Rank: 4

积分
963
金钱
963
注册时间
2016-3-16
在线时间
109 小时
发表于 2019-11-22 23:11:39 | 显示全部楼层
看一下源码就知道,导致这个问题的根本原因是因为中断里调用了任务版本的API,FreeRTOS有两个版本的API。解决办法是重实现sys_mbox_trypost函数。
回复

使用道具 举报

22

主题

203

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
378
金钱
378
注册时间
2017-11-29
在线时间
135 小时
发表于 2020-5-26 15:33:36 | 显示全部楼层
zdsurge 发表于 2019-9-2 08:37
的确是这样的,我也碰到相同的问题,根据楼主所说的,改了一下就OK了
#define SCB_ICSR_REG                 (*((volat ...

Error:..\FreeRTOS\portable\RVDS\ARM_CM4F\port.c,768 找您这样改后441的错误没有了,但是768出现了!!!???
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-6-9 18:37

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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