OpenEdv-开源电子网

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

UCos硬件错误问题.

[复制链接]

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
发表于 2014-10-21 17:57:36 | 显示全部楼层 |阅读模式
5金钱
我将原子兄的综合实验平台修改成自己的项目.

然后加了 IAP在线升级, flash偏移地址0x10000,然后以前一直正常使用,没有问题.
最近在一个文件中加了一个全局指针变量的时候,下图USART_Tx_Struct * Exten;
就出现硬件错误跳到HardFault_Handler
USART_Tx_Struct * Reader;是以前写的 能正常使用



仿真的时候在初始化内存时候开始出现问题.设置偏移以后


错误如上图,出现在
mem_init(SRAMIN); 函数的
mymemset(mallco_dev.memmap[memx], 0,memtblsize[memx]*2);//内存状态表数据清零
这句话.
仿真的时候发现mallco_dev.memmap[memx] 传递的指针指向正常情况下是0x20009D28 将内存状态清零. 
加了指针USART_Tx_Struct * Exten变量以后无论是给他分配空间或者不分配空间,都会在这里出错,
mallco_dev.memmap[memx] 传递的指针指向是0x00009D28 并不是0x20009D28 ,所以非法操作导致硬件错误了.
但是我将 IAP引导下载去掉,把偏移flash部分干掉以后,加了指针USART_Tx_Struct * Exten变量以后,程序是能正常运行.
我不明白问题所在,请各位指导下.

最佳答案

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

 不但不能定义 指针变量,只要定义4字节的变量都不行了. u32 Exten; 这样都不能定义了. 下面是map文件的对比.左边是不正常的,右边是正常的. 发现Malloc_dev的地址是不正常情况下,是奇数,右边是偶数,应该是这个原因,但是Malloc_dev的地址为什么是奇数而不是按4字节对齐的? 所以问题出来了.在struct _m_mallco_dev mallco_dev 前面加上 __align(4) 按4字节对齐.OK了.以上是我解决问题的所有步骤,欢迎参考. __align(4) ...
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-21 17:57:37 | 显示全部楼层
 不但不能定义 指针变量,只要定义4字节的变量都不行了.
u32 Exten;
这样都不能定义了.
下面是map文件的对比.左边是不正常的,右边是正常的.
发现Malloc_dev的地址是不正常情况下,是奇数,右边是偶数,应该是这个原因,但是Malloc_dev的地址为什么是奇数而不是按4字节对齐的?
所以问题出来了.在struct _m_mallco_dev mallco_dev 前面加上 __align(4) 按4字节对齐.OK了.以上是我解决问题的所有步骤,欢迎参考.

__align(4) struct _m_mallco_dev mallco_dev=
{
mem_init, //内存初始化
mem_perused, //内存使用率
mem1base,mem2base, //内存池
mem1mapbase,mem2mapbase,//内存管理状态表
0,0,   //内存管理未就绪
};

ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-10-21 23:08:59 | 显示全部楼层
只是定义了Exten,没有用到,也会死机?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-22 10:59:10 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
是的 ,只是定义了.没用到也死机.如果不做flash升级的偏移就不会.
mem_init(SRAMIN); 函数的
mymemset(mallco_dev.memmap[memx], 0,memtblsize[memx]*2);//内存状态表数据清零 
这句话.
仿真的时候发现mallco_dev.memmap[memx] 传递的指针指向正常情况下是0x20009D28 将内存状态清零. 
加了指针USART_Tx_Struct * Exten变量以后无论是给他分配空间或者不分配空间,都会在这里出错,
mallco_dev.memmap[memx] 传递的指针指向是0x00009D28 并不是0x20009D28 ,所以非法操作导致硬件错误了.
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-22 11:03:07 | 显示全部楼层
不明白为什么加个指针变量就导致了 内存指向的空间出错了.堆区和栈区都增大了也不行.也会错误....
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-22 13:42:50 | 显示全部楼层
回复【4楼】a4615800:
---------------------------------
1.....
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-22 15:03:49 | 显示全部楼层
可能的原因都没人知道吗?
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-10-22 23:37:56 | 显示全部楼层
回复【3楼】a4615800:
---------------------------------
那真是个比较诡异的问题了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

38

主题

302

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2012-3-6
在线时间
5 小时
 楼主| 发表于 2014-10-23 09:08:08 | 显示全部楼层
回复【8楼】正点原子:
---------------------------------
也算不上诡异,编译分配的时候地址没按4字节对齐.CPU读不到0x200000b1这个单字节地址,所有读出来的数据0x20009d28丢了最高位了.然后清内存的时候指向地址不对 非法操作了.通过map文件对比就出来了
ES?全称?Embedded?Show;ES是由众多嵌入式爱好者组织的一个团队,致力于带领学生进步,帮助毕业生找到工作,更重要的是在职的嵌入式工作者提供自主外包和创业的机会。(详情进群查看) ES的宗旨是:交流共享与合作发展。ES?QQ群?第三群:152820643?。群内论坛有很多嵌入式开发模块解决方案可以参考。进群的立马共享自己做的模块简介。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-10-23 23:31:34 | 显示全部楼层
回复【9楼】a4615800:
---------------------------------
谢谢分享
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-30 06:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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