ARM裸機(jī)開(kāi)發(fā)中內(nèi)存管理庫(kù)RT_HEAP的使用
首先,應(yīng)該初始化C堆,初始化代碼如下
本文引用地址:http://www.ex-cimer.com/article/201611/318216.htm
#include "malloc.h"#pragma import (__use_realtime_heap)//這個(gè)函數(shù)在rt_heap.h中聲明,需要用戶(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
指示的是我們管理的堆的開(kāi)始地址和結(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í)候一般還不能編譯過(guò)去,因?yàn)檫€需要一個(gè)錯(cuò)誤報(bào)告函數(shù),也就是庫(kù)出現(xiàn)問(wè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)論