123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- #include "malloc.h"
- //内存池(32字节对齐)
- __align(32) uint8_t mem1base[MEM1_MAX_SIZE]; //内部SRAM内存池
- __align(32) uint8_t mem2base[MEM2_MAX_SIZE] __attribute__((at(0X68000000))); //外部SRAM内存池
- //内存管理表
- uint16_t mem1mapbase[MEM1_ALLOC_TABLE_SIZE]; //内部SRAM内存池MAP
- uint16_t mem2mapbase[MEM2_ALLOC_TABLE_SIZE] __attribute__((at(0X68000000+MEM2_MAX_SIZE))); //外部SRAM内存池MAP
- //内存管理参数
- const uint32_t memtblsize[SRAMBANK]={MEM1_ALLOC_TABLE_SIZE,MEM2_ALLOC_TABLE_SIZE}; //内存表大小
- const uint32_t memblksize[SRAMBANK]={MEM1_BLOCK_SIZE,MEM2_BLOCK_SIZE}; //内存分块大小
- const uint32_t memsize[SRAMBANK]={MEM1_MAX_SIZE,MEM2_MAX_SIZE}; //内存总大小
- //内存管理控制器
- struct _m_mallco_dev mallco_dev=
- {
- my_mem_init, //内存初始化
- my_mem_perused, //内存使用率
- mem1base,mem2base, //内存池
- mem1mapbase,mem2mapbase, //内存管理状态表
- 0,0, //内存管理未就绪
- };
- //复制内存
- //*des:目的地址
- //*src:源地址
- //n:需要复制的内存长度(字节为单位)
- void mymemcpy(void *des,void *src,uint32_t n)
- {
- uint8_t *xdes=des;
- uint8_t *xsrc=src;
-
-
- while(n--)*xdes++=*xsrc++;
-
- }
- //设置内存
- //*s:内存首地址
- //c :要设置的值
- //count:需要设置的内存大小(字节为单位)
- void mymemset(void *s,uint8_t c,uint32_t count)
- {
- uint8_t *xs = s;
- while(count--)*xs++=c;
-
- }
- //内存管理初始化
- //memx:所属内存块
- void my_mem_init(uint8_t memx)
- {
- mymemset(mallco_dev.memmap[memx], 0,memtblsize[memx]*2);//内存状态表数据清零
- mymemset(mallco_dev.membase[memx], 0,memsize[memx]); //内存池所有数据清零
- mallco_dev.memrdy[memx]=1; //内存管理初始化OK
- }
- //获取内存使用率
- //memx:所属内存块
- //返回值:使用率(0~100)
- uint8_t my_mem_perused(uint8_t memx)
- {
- uint32_t used=0;
- uint32_t i;
-
-
- for(i=0;i<memtblsize[memx];i++)
- {
- if(mallco_dev.memmap[memx][i])used++;
- }
-
- return (used*100)/(memtblsize[memx]);
-
- }
- //内存分配(内部调用)
- //memx:所属内存块
- //size:要分配的内存大小(字节)
- //返回值:0XFFFFFFFF,代表错误;其他,内存偏移地址
- uint32_t my_mem_malloc(uint8_t memx,uint32_t size)
- {
- signed long offset=0;
- uint32_t nmemb; //需要的内存块数
- uint32_t cmemb=0;//连续空内存块数
- uint32_t i;
-
-
- if(!mallco_dev.memrdy[memx])mallco_dev.init(memx);//未初始化,先执行初始化
-
- if(size==0)
- return 0XFFFFFFFF;//不需要分配
-
- nmemb=size/memblksize[memx]; //获取需要分配的连续内存块数
-
- if(size%memblksize[memx])nmemb++;
-
- for(offset=memtblsize[memx]-1;offset>=0;offset--)//搜索整个内存控制区
- {
- if(!mallco_dev.memmap[memx][offset])cmemb++;//连续空内存块数增加
- else cmemb=0; //连续内存块清零
-
- if(cmemb==nmemb) //找到了连续nmemb个空内存块
- {
- for(i=0;i<nmemb;i++) //标注内存块非空
- {
- mallco_dev.memmap[memx][offset+i]=nmemb;
- }
- return (offset*memblksize[memx]);//返回偏移地址
- }
-
- }
-
- return 0XFFFFFFFF;//未找到符合分配条件的内存块
-
- }
- //释放内存(内部调用)
- //memx:所属内存块
- //offset:内存地址偏移
- //返回值:0,释放成功;1,释放失败;
- uint8_t my_mem_free(uint8_t memx,uint32_t offset)
- {
- int i;
-
-
- if(!mallco_dev.memrdy[memx])//未初始化,先执行初始化
- {
- mallco_dev.init(memx);
- return 1;//未初始化
- }
-
- if(offset<memsize[memx])//偏移在内存池内.
- {
- int index=offset/memblksize[memx]; //偏移所在内存块号码
- int nmemb=mallco_dev.memmap[memx][index]; //内存块数量
- for(i=0;i<nmemb;i++) //内存块清零
- {
- mallco_dev.memmap[memx][index+i]=0;
- }
- return 0;
- }
- else
- return 2;//偏移超区了.
-
- }
- //释放内存(外部调用)
- //memx:所属内存块
- //ptr:内存首地址
- void myfree(uint8_t memx,void *ptr)
- {
- uint32_t offset;
-
-
- if(ptr==NULL)return;//地址为0.
- offset=(uint32_t)ptr-(uint32_t)mallco_dev.membase[memx];
- my_mem_free(memx,offset); //释放内存
-
- }
- //分配内存(外部调用)
- //memx:所属内存块
- //size:内存大小(字节)
- //返回值:分配到的内存首地址.
- void *mymalloc(uint8_t memx,uint32_t size)
- {
- uint32_t offset;
-
-
- offset=my_mem_malloc(memx,size);
-
- if(offset==0XFFFFFFFF)return NULL;
- else return (void*)((uint32_t)mallco_dev.membase[memx]+offset);
-
- }
- //重新分配内存(外部调用)
- //memx:所属内存块
- //*ptr:旧内存首地址
- //size:要分配的内存大小(字节)
- //返回值:新分配到的内存首地址.
- void *myrealloc(uint8_t memx,void *ptr,uint32_t size)
- {
- uint32_t offset;
-
-
- offset=my_mem_malloc(memx,size);
- if(offset==0XFFFFFFFF)return NULL;
- else
- {
- mymemcpy((void*)((uint32_t)mallco_dev.membase[memx]+offset),ptr,size); //拷贝旧内存内容到新内存
- myfree(memx,ptr); //释放旧内存
- return (void*)((uint32_t)mallco_dev.membase[memx]+offset); //返回新内存首地址
- }
-
- }
- #include "string.h"
- void *mycalloc(size_t num, size_t size) {
- void* ptr = mymalloc(SRAMEX,num * size); // 分配内存
- if (ptr == NULL) {
- return NULL; // 检查内存分配是否成功
- }
- memset(ptr, 0, num * size); // 初始化内存为零
- return ptr;
- }
|