常见场景
内存管理模型用于在仿真中模拟驱动对内存的地址空间分配记录和管理,避免内存地址空间的重叠,为驱动和 device 提供内存空间读写访问接口,并实现对非法地址访问的检查,在 DMA 的验证中起着至关重要的作用。
分配内存,释放内存,属性检查,越界检查。
uvm_mem_mam
uvm_mem_mam(全称:UVM Memory Allocation Manager,内存分配管理器),是 UVM 类库中专门用于模拟硬件内存地址空间分配、管理与跟踪的核心组件,主要服务于需要对内存地址进行动态分配 / 释放的验证场景(如 DMA、CPU 内存访问、外设寄存器映射等),是实现 UVM 内存管理模型的核心工具。
初始化uvm_mem_mam时可配置核心参数,确保符合硬件内存特性:
alignment:地址对齐要求(如 4 字节对齐、8 字节对齐,默认 1 字节);granularity:内存分配粒度(最小可分配单位,默认 1 字节);wrap:是否支持地址环绕(仅用于环形缓冲区场景);access_policy:内存访问权限策略(读 / 写 / 只读 / 只写,默认全权限)。
uvm_mem_mam的使用遵循 "初始化→分配→使用→释放" 的闭环流程。
核心特性与注意事项
-
地址冲突防护 :
uvm_mem_mam内部会自动检查地址范围,若申请的地址已被分配或超出管理范围,会返回null并输出警告,杜绝地址重叠; -
内存块自动合并 :释放相邻的空闲内存块时,
uvm_mem_mam会自动将其合并为一个大的空闲块,提升后续内存分配的效率; -
无内存泄漏保障 :通过
owner标记和uvm_mem_region句柄跟踪,可在仿真结束后遍历已分配内存块,检查是否存在未释放的内存,避免验证环境中的 "逻辑内存泄漏"; -
与
uvm_mem的区别:-
uvm_mem_mam:专注于地址空间的分配与管理,不关心内存中的具体数据; -
uvm_mem:专注于内存数据的读写与存储 ,模拟内存的存储介质,可与uvm_mem_mam配合使用(uvm_mem_mam分配地址,uvm_mem操作该地址的数据);
-
-
仿真调试支持 :
uvm_mem_mam提供print_state()方法,可打印当前内存的使用状态(空闲块、已分配块),方便调试内存分配问题:systemverilog
mam.print_state(); // 打印内存管理状态,输出到仿真日志
适用场景总结
uvm_mem_mam主要适用于需要动态管理内存地址的验证场景,典型包括:
- DMA 控制器验证(分配源 / 目的缓冲区地址,避免地址冲突);
- 操作系统内核仿真(模拟内存页分配、释放);
- 多外设共享内存验证(多个外设同时访问内存,确保地址不重叠);
- 环形缓冲区(FIFO)验证(支持地址环绕配置,管理环形内存空间)。
uvm_mem_mam缺点:
不是派生于uvm_object
不支持设备对内存地址的访问和检查
内存初始化不够灵活
地址对齐方式不够灵活(1B/4B/8B/16B等对齐方式)
线性搜索地址区域检查重叠,效率低