日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

ARM嵌入式系统malloc的实现(C源码)

發布時間:2023/12/15 windows 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ARM嵌入式系统malloc的实现(C源码) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在ARM嵌入式系統實現malloc內存分配機制。

在ARM cpu上驗證通過。

ps:也可在pc ubuntu linux進行驗證

#include "include/lib_replace.h"#include "usb.h"//#define TEST_MALLOC y #ifdef TEST_MALLOC #include <stdio.h> #define PRINT printf #else #define PRINT print #endif#define MEM_SIZE 0x1500 //5kchar __attribute((aligned (16))) mem[MEM_SIZE]; //16 byte aligned #define MEM_START &mem[0] #define MEM_END &mem[MEM_SIZE]// #define MEM_START 0x400012fb0 // #define MEM_END 0x400012fb0 + MEM_SIZE // #define mem ((void *) MEM_START)#define UNUSED 0 #define USED 1#define PACKED_SIZE 16#pragma pack(8) typedef struct mem_block{ /*定義內存管理塊的數據結構*/void *mem_ptr; /*當前內存塊的內存地址*/struct mem_block *nxt_ptr; /*下一個內存管理塊的地址*/u64 mem_size; /*當前內存塊的大小*/u64 mem_sta; /*當前內存塊的狀態*/ }mem_block; #pragma pack()#define BLK_SIZE sizeof(mem_block) /*內存管理塊的大小*/ #define HEAD_NODE (MEM_END - BLK_SIZE)/*頭內存管理塊的地址*/static signed char mem_init_flag = -1; /*內存分配系統初始化的標志(-1 未初始化),(1 已初始化)*/ static int total_size = 0;int get_total_size(void) {return total_size; }void *memset_pro(void *addr, char c, unsigned int size) {int i;unsigned long long *p = (unsigned long long *)addr;unsigned int cnt = size / sizeof(unsigned long long);//unsigned int cnt2 = size % sizeof(unsigned long long);if(p == NULL)return NULL;for(i = 0; i < cnt; i ++){*(p + i) = c;}return addr; }void mem_init_ex(void) {PRINT("mem_init_ex: MEM_START:%p, MEM_END:%p, HEAD_NODE:%p, BLK_SIZE:%d\r\n", mem, (void *)MEM_END, (void *)HEAD_NODE, BLK_SIZE);mem_block *node;memset_pro(mem, 0, sizeof(mem));node = (mem_block *)HEAD_NODE;node->mem_ptr = MEM_START;node->nxt_ptr = (mem_block *)HEAD_NODE;node->mem_size = MEM_SIZE - BLK_SIZE;node->mem_sta = UNUSED;mem_init_flag = 1; }void *malloc_ex(unsigned int nbytes) {u64 suit_size = 0xFFFFFFFFFFFFUL;mem_block *head_node=NULL, *tmp_node=NULL, *suit_node=NULL;if(nbytes % PACKED_SIZE)nbytes = (nbytes/PACKED_SIZE + 1) * PACKED_SIZE;//PRINT("malloc_ex size:%d\r\n", nbytes);if(nbytes == 0){return NULL;}if(mem_init_flag < 0){mem_init_ex();}head_node = tmp_node = (mem_block *)HEAD_NODE;while(1){if(tmp_node->mem_sta == UNUSED){if(nbytes <= tmp_node->mem_size && tmp_node->mem_size < suit_size){suit_node = tmp_node;suit_size = suit_node->mem_size;}}tmp_node = tmp_node->nxt_ptr;if(tmp_node == head_node){if(suit_node == NULL){PRINT("NULL\r\n");return NULL;}break;}}if(nbytes <= suit_node->mem_size && (nbytes + BLK_SIZE) >= suit_node->mem_size){suit_node->mem_sta = USED;total_size += nbytes;PRINT("malloc_ex: addr:%p, size:%d\r\n", suit_node->mem_ptr, nbytes);return suit_node->mem_ptr;}else if(suit_node->mem_size > (nbytes + BLK_SIZE)){tmp_node = suit_node->mem_ptr; tmp_node = (mem_block *)((unsigned char *)tmp_node + nbytes);tmp_node->mem_ptr = suit_node->mem_ptr;tmp_node->nxt_ptr = suit_node->nxt_ptr;tmp_node->mem_size = nbytes;tmp_node->mem_sta = USED;//PRINT("tmp_node->mem_ptr:%p\r\n", tmp_node->mem_ptr);suit_node->mem_ptr = (mem_block *)((unsigned char *)tmp_node + BLK_SIZE);//PRINT("suit_node->mem_ptr:%p\r\n", suit_node->mem_ptr);suit_node->nxt_ptr = tmp_node;suit_node->mem_size -= (nbytes + BLK_SIZE);suit_node->mem_sta = UNUSED;total_size += nbytes;PRINT("malloc_ex: addr:%p, size:%d\r\n", tmp_node->mem_ptr, nbytes);return tmp_node->mem_ptr;}else{PRINT("%s,size err!\r\n",__FUNCTION__);}return NULL; }void free_ex(void *ap) {mem_block *head_node, *tmp_node, *nxt_node;if(ap == NULL)return;if(mem_init_flag < 0){return;}head_node = tmp_node = (mem_block *)HEAD_NODE;while(1){//PRINT("head_node:%p, tmp_node->mem_ptr:%p\r\n", head_node, tmp_node->mem_ptr);if(tmp_node->mem_ptr == ap){if(tmp_node->mem_sta != UNUSED){PRINT("free_ex: p=%p, size:%ld\r\n", ap, tmp_node->mem_size);total_size = total_size - tmp_node->mem_size;tmp_node->mem_sta = UNUSED;break;}else{return;}}tmp_node = tmp_node->nxt_ptr;if(tmp_node == head_node){PRINT("%s,can not found ap!\r\n",__FUNCTION__);return ;}}AGAIN: head_node = tmp_node = (mem_block *)HEAD_NODE;while(1){nxt_node = tmp_node->nxt_ptr;if(nxt_node == head_node){break;}if(tmp_node->mem_sta == UNUSED && nxt_node->mem_sta == UNUSED){tmp_node->mem_ptr = nxt_node->mem_ptr;tmp_node->nxt_ptr = nxt_node->nxt_ptr;tmp_node->mem_size += nxt_node->mem_size + BLK_SIZE;tmp_node->mem_sta = UNUSED;goto AGAIN;}tmp_node = nxt_node;} }#ifdef TEST_MALLOC int main(void) {char *p, *p1, *p3, *p4;PRINT("start:%p\r\n", mem);p = malloc_ex(8);memset_ex(p, 'a', 9);PRINT("p:%p, p=%s\r\n", p, p);free_ex(p);p1 = malloc_ex(10000);memset_ex(p1, 'b', 9);PRINT("p1:%p, p1=%s\r\n", p1, p1); free_ex(p1);p3 = malloc_ex(16);memset_ex(p3, 'c', 9);PRINT("p3:%p, p3=%s\r\n", p3, p3); //free_ex(p3);p4 = malloc_ex(5);memset_ex(p4, 'd', 9);PRINT("p4:%p, p4=%s\r\n", p4, p4); free_ex(p4);while(1); } #endif

?

?

總結

以上是生活随笔為你收集整理的ARM嵌入式系统malloc的实现(C源码)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。