当前位置: 首页 > wzjs >正文

加强企业网站建设163网易免费企业邮箱

加强企业网站建设,163网易免费企业邮箱,百度快速收录权限域名,会建网站的人刚入行单片机开发,赶鸭子上架,简单开聊,纯粹是做一个记录, 总体来说,问题本身比较低端,但是在缺乏调试手段(Keil的没有),不熟悉代码,碰到这种问题还真不是一…

刚入行单片机开发,赶鸭子上架,简单开聊,纯粹是做一个记录,

总体来说,问题本身比较低端,但是在缺乏调试手段(Keil的没有),不熟悉代码,碰到这种问题还真不是一时半会可以搞定。

简单描述,串口上看到单板启动后,出现如下错误。

free memory: memory[0x60001470], block[0x60001458] 
((header_ptr->magic & RT_MEMHEAP_MASK) == RT_MEMHEAP_MAGIC) assertion failed at function:rt_memheap_free, line number:515

一个典型的内存释放时,发现魔术字不对的问题。

由于地址看起来正常,野指针访问的可能性有点大

0x60000000开口的512K,实际就是外部RAM,当前单片机STM32F407,自带128K RAM

#define STM32_SRAM_SIZE           128

#define STM32_SRAM_END            (0x20000000 + STM32_SRAM_SIZE * 1024)

设计上,增加了512K 外设RAM

#define STM32_ESRAM_START          0x60000000

#define STM32_ESRAM_SIZE           512

#define STM32_ESRAM_END            (0x60000000 + STM32_ESRAM_SIZE * 1024)

想要得到足够的信息,还得打开日志开关,

#ifndef RT_DEBUG_MEMHEAP

#define RT_DEBUG_MEMHEAP               1

#endif

于是差不多有刷屏的打印,好在问题出在单板初始化阶段,眼里尚能抵达。

allocate 72 on heap:heapSRAMsplit: block[0x60001454] nextm[0x6007ffe8] prevm[0x6000142c] to new[0x600014b4]
new ptr: next_free 0x20009568, prev_free 0x20009568
alloc mem: memory[0x6000146c], heap[0x60001454], size: 72 -->这里0x6000146c - 0x60001454 = 24 字节,就是内存管理头大小。
free memory: memory[0x60001358], block[0x60001340]

/*** memory item on the heap*/
struct rt_memheap_item
{rt_uint32_t             magic;                      /**< magic number for memheap */struct rt_memheap      *pool_ptr;                   /**< point of pool */struct rt_memheap_item *next;                       /**< next memheap item */struct rt_memheap_item *prev;                       /**< prev memheap item */struct rt_memheap_item *next_free;                  /**< next free memheap item */struct rt_memheap_item *prev_free;                  /**< prev free memheap item */
};

跟踪alloc+free的配对流程,对照assert前的地址,差不多能够确定可疑点。

merge: right node 0x600013d4, next_free 0x600014b4, prev_free 0x20009568
insert to free list: next_free 0x600014b4, prev_free 0x20009568
free memory: memory[0x60001470], block[0x60001458] --> 实际上应该是0x60001454,指针偏移了4字节。
((header_ptr->magic & RT_MEMHEAP_MASK) == RT_MEMHEAP_MAGIC) assertion failed at function:rt_memheap_free, line number:515
 

笔者想偷懒,结果没有成功,方法是替换assert,代码替换为除零错误,来激发cmbacktrace,这样就可以拿到调用栈,可惜总是不成功,刚入行,还不知道多少坑要填。

最后老老实实走读代码,非常费眼神,有调试器的话,其实就分分钟的事。

碰到的问题,其实不仅仅如此,初始化过程中还存在着一个小内存操作,从片外拷贝到片内,然后crash了,代码走读看起来没有问题,尚不知道原因。

规避方法为,对于该模块内部,所有的内存申请和释放,用8字节对齐方式。

void cJSON_free(void *ptr)
{/* free a RT_NULL pointer */if (ptr == RT_NULL)return ;rt_free_align(ptr);
}
void* cJSON_malloc(rt_size_t size)
{return rt_malloc_align(size, 8);
}

http://www.dtcms.com/wzjs/817124.html

相关文章:

  • 有哪些网站可以做全屏代码网站开发推荐英文字体
  • 太原提高网站排名优化营商环境个人心得
  • 淄博网站电子商城平台建设网站建立的重要性
  • wordpress views深圳做seo有哪些公司
  • 河南省住房建设厅官方网站linux怎么使用wordpress
  • 网站如何做品牌宣传没有服务器如何做网站
  • 网站如何改版浙江微信网站建设
  • 修改网站图片做网站维护价格
  • 做电商网站的公司梅州东莞网站建设
  • 揭阳 网站建设做茶道网站
  • 西安做商铺的网站免费网站商城模板
  • 河南网站备案代理成都网站优化方案
  • 上海设计网站wordpress monster
  • 清远市企业网站seo联系方式国外网站设计版式欣赏
  • 点网站建设wordpress替换谷歌字体库
  • 成品网站1688网页老河口城乡建设局网站
  • 成都著名网站建设公司做笑话网站需要什么
  • 教你如何建设网站打电话拉客户用网站做广告怎么做 好做吗
  • 企业内部网站打不开免费学做美食视频网站有哪些
  • 公司策划方案网站seo链接购买
  • 海口个人建站模板番禺网站 建设信科网络
  • 淘宝客网站建设多少钱弓长岭网站建设
  • 学生可做的网站主题企业管理培训课程方案
  • 青岛城市建设投资建设集团网站网站底版照片怎么做
  • xp系统中做网站服务器吗昆明做网站软件
  • 一键安装网站运行环境城乡建设厅建筑特种作业证书查询
  • 网站建设创客郑州微盟网站建设公司
  • 学校网站建设策划店铺设计叫什么
  • wordpress精致建站北京网站建设公司联系方式
  • 昆明做网站seo香水推广软文