OpenEdv-开源电子网

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

阿波罗H743开发板 freeRTOS队列实验问题

[复制链接]

2

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2015-4-2
在线时间
10 小时
发表于 2022-5-11 20:11:09 | 显示全部楼层 |阅读模式
1金钱
原子大哥你好:            我在用阿波罗H743开发板做队列实验的时候发现一个奇怪的问题。

           定时器5中断函数中,分配了一段内存存储队列的消息(消息数据是串口的内容)。前面几分钟运行都正常。过了几分钟以后就出异常了。
           串口连续输出:Error:..\FreeRTOS\queue.c,1441
           经过查询是:  buffer=mymalloc(SRAMIN,USART_REC_LEN) 中 buffer =0;而err=xQueueReceiveFromISR(Message_Queue,buffer,&xTaskWokenByReceive)中有检查buffer==0;所以输出错误信息。
           但是奇怪的是液晶屏上收到的消息是正确的。经过跟踪发现:0x00000000地址居然是可以写数据的。因为内存是使用0x20000000 或0x24000000开始的区域。
          0x00000000应该不能写吧?为什么?
            微信图片_20220511200921.png

最佳答案

查看完整内容[请看2#楼]

找到问题原因了:0x00000000 是ITCM 确实能读写,所以操作结果是正确的,错误提示的原因是内存溢出。溢出以后居然还找到一个可以操作内存,简直有点神奇。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2015-4-2
在线时间
10 小时
 楼主| 发表于 2022-5-11 20:11:10 | 显示全部楼层
找到问题原因了:0x00000000 是ITCM  确实能读写,所以操作结果是正确的,错误提示的原因是内存溢出。溢出以后居然还找到一个可以操作内存,简直有点神奇。
回复

使用道具 举报

0

主题

668

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1926
金钱
1926
注册时间
2021-8-13
在线时间
262 小时
发表于 2022-5-12 10:09:54 | 显示全部楼层
帮顶   
回复

使用道具 举报

14

主题

821

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2070
金钱
2070
注册时间
2021-7-17
在线时间
647 小时
发表于 2022-5-12 10:49:10 | 显示全部楼层
帮顶   
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2022-5-12 23:46:18 | 显示全部楼层
tly823875 发表于 2022-5-12 14:29
找到问题原因了:0x00000000 是ITCM  确实能读写,所以操作结果是正确的,错误提示的原因是内存溢出。溢出 ...

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

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-25 18:32

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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