threadx之动态内存的实现记录

前言

  1. threadx 里面在汇编文件中有个宏定义是提供了,动态分配内存的首地址,并不完善,这里进行了一次封装。

汇编文件修改

在这里插入图片描述
在这里插入图片描述

内存管理代码

头文件

void tx_mem_pool_init(void *start_addr);

void *app_malloc(ULONG size);

void app_free(void *mem_ptr);

void *app_realloc(void *ptr, ULONG size);

源文件

/*
 * Copyright (c) 2024-2024,shchl
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Change Logs:
 * Date           Author       Notes
 * 2024-4-9     shchl   first version
 */
#include "includes.h"

#define RAM_START              (0x20000000)   /*ram起始地址*/
#define RAM_SIZE               (128 * 1024)   /*总大小*/
#define RAM_END                (RAM_START + RAM_SIZE) /*结束地址*/

#define STAND_C_LIB      0  /*使用c标准库提供的内存分配函数进行管理*/
#define TX_BYTE_POOL_MEM 1  /*使用threadx提供的字节池对象进行内存分配管理*/
#define MEM_MANAGER_MODE TX_BYTE_POOL_MEM
/*
*********************************************************************************************************
*                                       静态全局变量
*********************************************************************************************************
*/
static TX_BYTE_POOL g_byte_pool; /*全局字节池*/
static ULONG mem_size;  /*内存总大小(字节)*/

/*
*********************************************************************************************************
*                                      外部函数
*********************************************************************************************************
*/
/**
 * @brief 内存池初始化
 * @param start_addr 其实地址
 */
void tx_mem_pool_init(void *start_addr) {
#if MEM_MANAGER_MODE == TX_BYTE_POOL_MEM

    // 地址对齐-保证4字节 内部已处理这里就不需要进行字节对齐处理了
    ULONG begin_align =(ULONG) start_addr;
    mem_size = (RAM_END - begin_align); /*动态内存总大小(字节)*/
    /*通过threadx 提供的字节池对象进行管理动态内存空间*/
    if (tx_byte_pool_create(&g_byte_pool, "heap",start_addr, mem_size) != TX_SUCCESS) {
        /*错误处理*/
        Error_Handler();
    }

#elif MEM_MANAGER_MODE == TX_BYTE_POOL_MEM
#endif
}


/**
 * @brief 内存分配
 * @param size 分配大小(字节)
 * @return 指向分配内存的首地址
 */
void *app_malloc(ULONG size) {
#if MEM_MANAGER_MODE == TX_BYTE_POOL_MEM

    static void *mem_ptr = NULL; /*这里要用全局静态变量,不能放在栈上面*/
    tx_byte_allocate(&g_byte_pool, (void **) &mem_ptr,
                     size, TX_NO_WAIT);
    return mem_ptr;
#else
    return malloc(size);
#endif

}

/**
 * @brief 释放内存
 * @param mem_ptr
 */
void app_free(void *mem_ptr) {
#if MEM_MANAGER_MODE == TX_BYTE_POOL_MEM
    tx_byte_release(mem_ptr);
#else
    free(mem_ptr);
#endif


}

/**
 * @brief 重新分配内存空间
 * @param ptr 原始内存指向的指针
 * @param size 重新分配的大小
 * @return 新分配内存空间的首地址
 *  @note 需要用返回回去的指针覆盖原始指针,防止重新分配的内存首地址发生改变
 */
void *app_realloc(void *ptr, ULONG size) {
#if MEM_MANAGER_MODE == TX_BYTE_POOL_MEM
    void *nw_ptr = app_malloc(size);
    memcpy(nw_ptr, ptr, size);
    app_free(ptr);
    return nw_ptr;

#else
    return realloc(ptr,size);
#endif

}



函数调用

在这里插入图片描述

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

詩不诉卿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值