ARM裸機(jī)開發(fā)中內(nèi)存管理庫RT_HEAP的使用
首先,應(yīng)該初始化C堆,初始化代碼如下
本文引用地址:http://cafeforensic.com/article/201611/318216.htm
#include "malloc.h"#pragma import (__use_realtime_heap)//這個函數(shù)在rt_heap.h中聲明,需要用戶自己去實現(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); //初始化堆的范圍 }
這里面主要是幾個工作,一個是導(dǎo)入運(yùn)行庫,第二是初始化C堆,其中定義了兩個宏MALLOC_HEAP_ADDRESS_START和MALLOC_HEAP_ADDRESS_END
指示的是我們管理的堆的開始地址和結(jié)束地址,我的使用是這樣(根據(jù)實際情況來)
#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ù),也就是庫出現(xiàn)問題的時候把錯誤信息反饋出來的方式,一般可以選擇串口打印,如下
//加入以下代碼,支持printf函數(shù),而不需要選擇use MicroLIB #pragma import(__use_no_semihosting) //標(biāo)準(zhǔn)庫需要的支持函數(shù) struct __FILE { int handle; }; FILE __stdout; //定義_sys_exit()以避免使用半主機(jī)模式 _sys_exit(int x) { x = x; } _ttywrch(int ch)//這里就是我們要實現(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;}
這樣就能夠同時支持printf和動態(tài)內(nèi)存管理了,
到這里,malloc和free函數(shù)就能夠正常使用了,記得包含stdlib.h文件哦
評論