欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载  

    内存非常重要!浅谈嵌入式裸机编程最重要的事.doc

    • 资源ID:3389355       资源大小:22.50KB        全文页数:5页
    • 资源格式: DOC        下载积分:2
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要2
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    内存非常重要!浅谈嵌入式裸机编程最重要的事.doc

    内存非常重要!浅谈嵌入式裸机编程最重要的事在嵌入式裸机编程中,作为一名初级的CODER。经常要与CPU、内存等打交道。CPU作为系统的动力源,其重要程度不言而喻。但是,在裸机编程中,对内存的管理也不容忽视。如果稍微不注意,轻则,可能造成内存泄漏,重则造成内存访问异常。导致系统死机。嵌入式产品,对稳定性要求及其严格。动不动就死机,那可就麻烦大了。以下,是我本人对嵌入式系统裸机编程的内存管理的一些简介。1. 万万不可使用系统自带的malloc和free。malloc和free在PC编程中是很好用的一种内存分配手段。但是,其在嵌入式中,就未必好用了。由于嵌入式裸机编程中,无MMU,即内存管理单元。无法实现对内存进行动态映射(不明白什么叫动态映射的同学,可以参考网上的资料)。也就是说,实际上,malloc和free并不能实现动态的内存的管理。这需要在启动阶段专门给其分配一段空闲的内存区域作为malloc的内存区。如STM32中的启动文件startup_stm32f10x_md.s中见以下信息:plain view plain copyHeap_Size EQU 0x00000800 AREA HEAP, NOINIT, READWRITE, ALIGN=3_heap_baseHeap_Mem SPACE Heap_Size_heap_limit其中,Heap_Size即定义一个宏定义。数值为0x00000800。Heap_Mem则为申请一块连续的内存,大小为 Heap_Size。简化为C语言版本如下:#define Heap_Size 0x00000800unsigned char Heap_MemHeap_Size = 0;在这里申请的这块内存,在接下来的代码中,被注册进系统中给malloc和free函数所使用:_user_iniTIal_stackheapLDR R0, = Heap_Mem ; 返回系统中堆内存起始地址LDR R1, =(Stack_Mem + Stack_Size)LDR R2, = (Heap_Mem + Heap_Size); 返回系统中堆内存的结束地址LDR R3, = Stack_MemBX LR就如上面分析的那样,其实,在裸机编程的时候,对堆内存的管理。并非是智能化的,并非你想申请多少就多少。而是使用一块固定的内存用作堆内存的分配。这在设计的时候,往往不是最佳的方案。这块内存,如果被多次按照不同的大小进行申请,就会造成内存碎片。最终导致无法申请到足够的内存。导致系统运行出错。这在原本内存就已经很少的嵌入式系统中,更是不能接受的。所以,建议是把那个Heap_Size设置成 0 吧。放弃其使用吧。而更为致命的是,有些malloc,free函数,由于工程人员的偷懒。实现甚至可能如下:unsigned char mem_buffer512;unsigned char *mem_offset = mem_buffer;void *malloc(int size)unsigned char *tmp = mem_offset;mem_offset += size;return (void *)tmp;void free(void *mem)mem_offset = mem;2. 更好的替代方案:内存池。可能有些同学,觉得:内存池,这是什么东西?内存池,简洁地来说,就是预先分配一块固定大小的内存。以后,要申请固定大小的内存的时候,即可从该内存池中申请。用完了,自然要放回去。注意,内存池,每次申请都只能申请固定大小的内存。这样子做,有很多好处:(1)每次动态内存申请的大小都是固定的,可以有效防止内存碎片化。(至于为什么,可以想想,每次申请的都是固定的大小,回收也是固定的大小)(2)效率高,不需要复杂的内存分配算法来实现。申请,释放的时间复杂度,可以做到O(1)。(3)实现简单,易用。(4)内存的申请,释放都在可控的范围之内。不会出现以后运行着,运行着,就再也申请不到内存的情况。内存池,并非什么很厉害的技术。实现起来,其实可以做到很简单。只需要一个链表即可。在初始化的时候,把全局变量申请来的内存,一个个放入该链表中。在申请的时候,只需要取出头部并返回即可。在释放的时候,只需要把该内存插入链表。以下是一种简单的例子(使用移植来的linux内核链表,对该链表的移植,以后有时间再去分析):#define MEM_BUFFER_LEN 5 /内存块的数量#define MEM_BUFFER_SIZE 256 /每块内存的大小/内存池的描述,使用联合体,体现穷人的智慧。就如,我一同学说的:一个字节,恨不得掰成8个字节来用。typedef union mem struct list_head list;unsigned char bufferMEM_BUFFER_SIZE;mem_t;staTIc union mem gmemMEM_BUFFER_LEN;LIST_HEAD(mem_pool);/分配内存void *mem_pop()union mem *ret = NULL;psr_t psr;psr = ENTER_CRITICAL();if(!list_empty(mem_pool) /有可用的内存池ret = list_first_entry(mem_pool, union mem, list);/printf(mem_pool = 0x%p ret = 0x%pn, mem_pool, ret-list);list_del(ret-list);EXIT_CRITICAL(psr);return ret;/-buffer;/回收内存void mem_push(void *mem)union mem *tmp = NULL;psr_t psr;tmp = (void *)mem;/container_of(mem, struct mem, buffer);psr = ENTER_CRITICAL();list_add(tmp-list, mem_pool);/printf(free = 0x%pn, tmp-list);EXIT_CRITICAL(psr);/初始化内存池void mem_pool_init()int i;psr_t psr;psr = ENTER_CRITICAL();for(i=0; ilist_add(gmemi.list), mem_pool);/printf(add mem 0x%pn, (gmemi.list);EXIT_CRITICAL(psr);

    注意事项

    本文(内存非常重要!浅谈嵌入式裸机编程最重要的事.doc)为本站会员(白大夫)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开