新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM裸機(jī)開發(fā)中內(nèi)存管理庫(kù)RT_HEAP的使用

ARM裸機(jī)開發(fā)中內(nèi)存管理庫(kù)RT_HEAP的使用

作者: 時(shí)間:2016-11-19 來(lái)源:網(wǎng)絡(luò) 收藏
在使用arm芯片進(jìn)行裸機(jī)開發(fā)的時(shí)候,很多時(shí)候都需要內(nèi)存管理的功能,我們可以使用自己寫的內(nèi)存管理程序,也可以直接使用標(biāo)準(zhǔn)庫(kù),不過我一般比較喜歡標(biāo)準(zhǔn)庫(kù),速度快,今天就來(lái)說說在C語(yǔ)言環(huán)境下怎么樣進(jìn)行內(nèi)存的動(dòng)態(tài)使用

首先,應(yīng)該初始化C堆,初始化代碼如下

本文引用地址:http://m.butianyuan.cn/article/201611/318216.htm

#include "malloc.h"#pragma import (__use_realtime_heap)//這個(gè)函數(shù)在rt_heap.h中聲明,需要用戶自己去實(shí)現(xiàn),返回任意值  unsigned __rt_heap_extend(unsigned size, void **block)  {  return 0;  }  void MallocInit(void){_init_alloc(MALLOC_HEAP_ADDRESS_START,MALLOC_HEAP_ADDRESS_END);      //初始化堆的范圍 }

這里面主要是幾個(gè)工作,一個(gè)是導(dǎo)入運(yùn)行庫(kù),第二是初始化C堆,其中定義了兩個(gè)宏MALLOC_HEAP_ADDRESS_START和MALLOC_HEAP_ADDRESS_END

指示的是我們管理的堆的開始地址和結(jié)束地址,我的使用是這樣(根據(jù)實(shí)際情況來(lái))

#define MALLOC_HEAP_ADDRESS_START    SDRAM_BASE_ADDR#define MALLOC_HEAP_ADDRESS_END        SDRAM_BASE_ADDR+SDRAM_LENGTHunsigned __rt_heap_extend(unsigned size, void **block);void MallocInit(void);

這時(shí)候一般還不能編譯過去,因?yàn)檫€需要一個(gè)錯(cuò)誤報(bào)告函數(shù),也就是庫(kù)出現(xiàn)問題的時(shí)候把錯(cuò)誤信息反饋出來(lái)的方式,一般可以選擇串口打印,如下

//加入以下代碼,支持printf函數(shù),而不需要選擇use MicroLIB      #pragma import(__use_no_semihosting)             //標(biāo)準(zhǔn)庫(kù)需要的支持函數(shù)                 struct __FILE { int handle; }; FILE __stdout;       //定義_sys_exit()以避免使用半主機(jī)模式    _sys_exit(int x) { x = x; } _ttywrch(int ch)//這里就是我們要實(shí)現(xiàn){ch = ch;}//重定義fputc函數(shù) int fputc(int ch, FILE *f){      while((USART1->SR&0X40)==0);//循環(huán)發(fā)送,直到發(fā)送完畢   USART1->DR = (u8) ch;      return ch;}

這樣就能夠同時(shí)支持printf和動(dòng)態(tài)內(nèi)存管理了,

到這里,malloc和free函數(shù)就能夠正常使用了,記得包含stdlib.h文件哦



評(píng)論


技術(shù)專區(qū)

關(guān)閉