/***************************************************************************** * 函 数 名 : BSP_Free * * 功能描述 : BSP 动态内存释放(Debug接口) * * 输入参数 : pMem: 动态内存指针 * pFileName: 使用的源文件 * u32Line: 所在文件的行号 * * 输出参数 : 无 * 返 回 值 : 无 *****************************************************************************/ void bsp_free_dbg(void* pMem, u8* pFileName, u32 u32Line) { #ifdef __BSP_MEM_DEBUG__ /* 检查当前内存是否有效 */ if (bsp_ptr_invalid(pMem)) { bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM, "invalid mem block, ptr:0x%x, line:%d\n", pMem, __LINE__); return; } if (MEM_FREE == MEM_ITEM_STATUS(pMem) || MEM_NORM_DDR_POOL != MEM_ITEM_FLAGS(pMem)) { bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM, "warning! ptr:0x%x, may free twice, or wrong mem flags line:%d\n", pMem, __LINE__); return; } #endif bsp_free(pMem); #ifdef __BSP_MEM_DEBUG__ /* 更新MGR Debug信息 */ MEM_ITEM_LINE(pMem) = u32Line; MEM_ITEM_FILE_NAME(pMem) = (u32)pFileName; #endif return; }
/***************************************************************************** * 函 数 名 : BSP_Free * * 功能描述 : BSP 动态内存释放(Debug接口) * * 输入参数 : pMem: 动态内存指针 * pFileName: 使用的源文件 * u32Line: 所在文件的行号 * * 输出参数 : 无 * 返 回 值 : 无 *****************************************************************************/ void bsp_free_dbg(void* pMem, u8* pFileName, u32 u32Line) { /* coverity[USE_AFTER_FREE] */ #ifdef __BSP_MEM_DEBUG__ /* 检查当前内存是否有效 */ if (bsp_ptr_invalid(pMem)) { printk("invalid mem block, ptr:0x%x, line:%d\n", (unsigned int)pMem, __LINE__); return; } if (MEM_FREE == MEM_ITEM_STATUS(pMem) || MEM_NORM_DDR_POOL != MEM_ITEM_FLAGS(pMem)) { printk("warning! ptr:0x%x, may free twice, or wrong mem flags line:%d\n", (unsigned int)pMem, __LINE__); return; } #endif /* coverity[freed_arg] */ bsp_free(pMem); #ifdef __BSP_MEM_DEBUG__ /* 更新MGR Debug信息 */ /* coverity[use_after_free] */ MEM_ITEM_LINE(pMem) = u32Line; MEM_ITEM_FILE_NAME(pMem) = (u32)pFileName; #endif return; }
void* bsp_get_item(MEM_ALLOC_INFO* pAllocInfo, u32 cnt, u32 u32PoolType, u32 u32Size) { void *pItem; void **ppHead = &(pAllocInfo->allocList[cnt]); /* 如果链表中没有节点,则从内存池中分配 */ if (!*ppHead) { /* 判断是否达到最大个数 */ if((u32PoolType != MEM_ICC_DDR_POOL) || (pAllocInfo->allocNum[cnt] < sg_AllocMaxNum[cnt])) { /* 注意从内存池中分配的尺寸要额外包含 MGR 的部分 */ pItem = bsp_pool_alloc(pAllocInfo, u32Size+pAllocInfo->memPoolInfo.u32MgrSize); if (NULL == pItem) { pAllocInfo->u32AllocFailCnt++; return NULL; } MEM_ITEM_MAGIC(pItem) = (u32)MEM_MAGIC_NUM; MEM_ITEM_SIZE(pItem) = u32Size; MEM_ITEM_FLAGS(pItem) = u32PoolType; if(MEM_ICC_DDR_POOL == u32PoolType) { pAllocInfo->allocNum[cnt]++; } #ifdef __BSP_MEM_DEBUG__ MEM_ITEM_FILE_NAME(pItem) = 0; MEM_ITEM_LINE(pItem) = 0; #endif } else { pAllocInfo->u32AllocFailCnt++; return NULL; } } /* 从链表中取出节点 */ else { pItem = (void*)PHY_TO_VIRT((unsigned int)*ppHead); /* Invalid Cache */ MEM_INVALID_CACHE_BY_TYPE(MEM_GET_ALLOC_ADDR(pItem), MEM_MGR_SIZE_FOR_CACHE, u32PoolType); *ppHead = (void*)MEM_ITEM_NEXT(pItem); } return pItem; }
/***************************************************************************** * 函 数 名 : bsp_malloc_dbg * * 功能描述 : BSP 动态内存分配(Debug接口) * * 输入参数 : u32Size: 分配的大小(byte) * enFlags: 内存属性(暂不使用,预留) * pFileName: 使用的源文件 * u32Line: 所在文件的行号 * 输出参数 : 无 * 返 回 值 : 成功/失败 *****************************************************************************/ void* bsp_malloc_dbg(u32 u32Size, MEM_POOL_TYPE enFlags, u8* pFileName, u32 u32Line) { u8 *pItem; /* 分配内存 */ pItem = bsp_memory_alloc((u32)enFlags, (u32)u32Size); #ifdef __BSP_MEM_DEBUG__ if (NULL != pItem) { /* Debug模式要更新MGR 信息 */ MEM_ITEM_LINE(pItem) = u32Line; MEM_ITEM_FILE_NAME(pItem) = (u32)pFileName; } #endif return (void*)pItem; }
STATIC s32 bsp_mem_dump_block(u32 u32Addr) { BSP_BOOL bBlockInvalid = FALSE; bBlockInvalid = bBlockInvalid; if (NULL == (void *)u32Addr) { bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"can't dump the block, the input ptr is NULL\n"); return BSP_ERROR; } if (MEM_MAGIC_NUM != MEM_ITEM_MAGIC(u32Addr)) { bBlockInvalid = TRUE; bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"The Block:0x%x may Invalid!\n", u32Addr); } /* 为确保正确,统一刷下Cache */ MEM_INVALID_CACHE(MEM_GET_ALLOC_ADDR(u32Addr), MEM_MGR_SIZE_FOR_CACHE); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"================================\n"); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"dump mem block info:\n"); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"================================\n"); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"usr ptr: 0x%x\n", u32Addr); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"alloc ptr: 0x%x\n", (u32)MEM_GET_ALLOC_ADDR(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"magic num: 0x%x\n", MEM_ITEM_MAGIC(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"block size: %d\n", MEM_ITEM_SIZE(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"mem flags: 0x%x\n", MEM_ITEM_FLAGS(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"mem item next: 0x%x\n", MEM_ITEM_NEXT(u32Addr)); #ifdef __BSP_MEM_DEBUG__ bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"used file name: %s\n", (bBlockInvalid) ? ("invalid") : (BSP_CHAR*)MEM_ITEM_FILE_NAME(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"used line: %d\n", MEM_ITEM_LINE(u32Addr)); bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"mem status: %s\n", (MEM_ITEM_STATUS(u32Addr)) ? ("ALLOC") : ("FREE")); #endif bsp_trace(BSP_LOG_LEVEL_ERROR, BSP_MODU_MEM,"================================\n"); return BSP_OK; }