FreeRTOS heap4

Init:

c 复制代码
xStart.pxNextFreeBlock = ( void * ) uxStartAddress;
xStart.xBlockSize = ( size_t ) 0;

pxEnd= uxStartAddress + xTotalHeapSize - xHeapStructSize
pxEnd->xBlockSize = 0;
pxEnd->pxNextFreeBlock = NULL;

pxFirstFreeBlock = uxStartAddress;
pxFirstFreeBlock->xBlockSize = pxEnd - uxStartAddress;
pxFirstFreeBlock->pxNextFreeBlock = pxEnd;

malloc:

c 复制代码
xWantedSize += xHeapStructSize;
pxPreviousBlock = &xStart;
pxBlock = px First FreeBlock; //until first free block
pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock; // pxblock 从freeblock list中剔除

pxNewBlockLink = ( void * ) ( ( ( uint8_t * ) pxBlock ) + xWantedSize );//新块位置
pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;//新块尺寸
pxNewBlockLink->pxNextFreeBlock = pxPreviousBlock->pxNextFreeBlock;//新块指向后方链表
pxPreviousBlock->pxNextFreeBlock = pxNewBlockLink;//新块被指向

pxBlock->xBlockSize = xWantedSize;//malloc之后的老块尺寸更新

heapALLOCATE_BLOCK( pxBlock );//标记为被使用

Free

c 复制代码
puc = ( uint8_t * ) pv; puc -= xHeapStructSize;
pxLink = ( void * ) puc;
heapFREE_BLOCK( pxLink );

//找到第一个freeblock, 记录在pxIterator 
for( pxIterator = &xStart; pxIterator->pxNextFreeBlock < pxBlockToInsert; pxIterator = pxIterator->pxNextFreeBlock ) 

向前合并

c 复制代码
puc = ( uint8_t * ) pxIterator;
if( ( puc + pxIterator->xBlockSize ) == ( uint8_t * ) pxBlockToInsert ) // 待freeblock 与 前一个freeblock相邻??
	pxIterator->xBlockSize += pxBlockToInsert->xBlockSize; //previous free block直接扩张
	pxBlockToInsert = pxIterator;//变更pxBlockToInsert ,可能还需要与后面的freeblock合并

向后合并

c 复制代码
puc = ( uint8_t * ) pxBlockToInsert;
if( ( puc + pxBlockToInsert->xBlockSize ) == ( uint8_t * ) pxIterator->pxNextFreeBlock ) // 待freeblock 与 后一个freeblock相邻??
 	pxBlockToInsert->xBlockSize += pxIterator->pxNextFreeBlock->xBlockSize; //扩张
            	pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock->pxNextFreeBlock; 指向后面的后面
else
	pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock; //不可以向后合并, 那么更新next指针

pxIterator->pxNextFreeBlock = pxBlockToInsert;
相关推荐
apocelipes19 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
创龙科技-黄工1 天前
创龙 RK3588 单板 / 工控机 NPU 开发手册
嵌入式开发·硬件开发·工业控制·工业开发板
LDR00616 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
✎ ﹏梦醒͜ღ҉繁华落℘16 天前
单片机基础知识---stm32单片机的优先级
stm32·单片机·mongodb
Luminous.16 天前
C语言--day30
c语言·开发语言
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
謓泽16 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
不会C语言的男孩16 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
牛根生同志16 天前
SPI数据收发的时候 TXE与RXNE标志位置位的时机
stm32·spi·transfer
2601_9516438816 天前
C语言长文整理,关键字和数据类型
c语言·数据类型·关键字·嵌入式开发·格式化输出