news 2026/3/28 15:44:30

Cadence AXI VIP(1)——使用示例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Cadence AXI VIP(1)——使用示例

环境准备

Cadence的所有VIP均整合在VIPCAT中,不需要安装。正常流程应该继续使用C家xrun继续仿真,但是这里使用vcs+verdi实现,需要额外做些修改。VIPCAT使用版本11.30.106,vcs版本2022。尝试过老版本VIPCAT,可能遇到问题是不兼容64位vcs(可能也能兼容,问题太多放弃了)。

环境变量

使用前添加环境变量,在~/.bashrc中添加如下变量,注意这里是我的VIPCAT路径,需要按实际修改。

export CDN_VIP_ROOT=/usr/Cadence/vipcat/vipcat_11_30_106 export DENALI=${CDN_VIP_ROOT}/tools.lnx86/denali_64bit

示例类型

AXI相关共包含3个示例环境,分别为常规配置、soma配置和soma模块,然后环境下包含AXI3、AXI4和ACE等子示例。

/usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/using_config_object /usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/legacy_examples/using_soma_interface/ /usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/legacy_examples/using_soma_module/

常规配置示例

运行示例

这里执行AXI4常规配置示例脚本,后续再介绍soma。直接在端口执行示例路径下vcs后缀脚本即可,端口打开的地方就是环境生成的地方。建议把using_config_object拷贝到其他地方再按新路径执行,这样可以随意改验证环境同时不改动VIPCAT文件。

/usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/using_config_object/axi4/example_setup_vcs.csh

环境生成

执行脚本会在路径下自动生成环境变量脚本和仿真脚本,然后自动调用这两个脚本进行仿真。期间在log中看到vcs编译和仿真,最后打印结果完成5次写传输和7次读传输。

Verdi修改

由于希望用verdi打开,所以要做一些修改,首先打开“using_config_object/axi4/axi4UvmUserTb.sv”,里面有叫testbench的module,这个是tb的顶层,在module最后加上fsdbdump的代码。

initial begin $fsdbDumpfile("wave.fsdb"); $fsdbDumpSVA; $fsdbDumpvars(0,testbench); end

然后需要改compile指令,比较尴尬的是新版本VIPCAT在example_setup_vcs.csh里调用的不是脚本而是可执行文件,还不好改,所以只能改新生成出来的cdn_vip_run_vcs_sv_uvm_64.csh,找到vcs编译部分指令,在最后添加"-debug_access \"。

-XVpiCbAutoRelease=libcdnsv.so \ -P ${DENALI}/verilog/cdnsv.tab \ -LDFLAGS '-rdynamic ${DENALI}/lib/libviputil.so' \ -top testbench \ -debug_access \

因为已经改了生成文件,所以不能用再用example_setup_vcs.csh了,直接顺序执行路径下2个脚本即可(服务器默认bash的话要切csh),然后可以看到重新进行编译仿真,最后多了fsdb文件。

csh source cdn_vip_env_vcs_sv_uvm_64.csh ./cdn_vip_run_vcs_sv_uvm_64.csh

参照编译log手写一个verdi Makefile,注意修改VIPCAT路径。

CDN_VIP_COMMON_SRC := "/usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv" CDN_VIP_AXI_SRC:= "/usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi" EXAMPLE_DIR:= "/usr/Cadence/vipcat/vipcat_11_30_106/vipcat_11_30_106/tools.lnx86/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/using_config_object/axi4/" verdi: verdi \ +v2k \ -sverilog \ +define+DENALI_UVM +define+VCS \ -ntb_opts uvm-ieee \ +incdir+${CDN_VIP_COMMON_SRC} \ ${CDN_VIP_COMMON_SRC}/denaliMem.sv \ ${CDN_VIP_COMMON_SRC}/denaliCdn_axi.sv \ +incdir+${CDN_VIP_AXI_SRC} \ ${CDN_VIP_AXI_SRC}/cdnAxiUvmTop.sv \ -timescale=1ns/10ps +define+UVM_NO_DEPRECATED \ +incdir+${EXAMPLE_DIR} \ +incdir+${EXAMPLE_DIR}/.. \ ${EXAMPLE_DIR}/../hdl_interfaces/cb_interfaces/cdnAxi4Interface.sv \ ${EXAMPLE_DIR}/axi4UvmUserTop.sv \ ${EXAMPLE_DIR}/axi4UvmUserTb.sv \ ${CDN_VIP_COMMON_SRC}/denaliMemSvIf.c \ ${CDN_VIP_COMMON_SRC}/denaliCdn_axiSvIf.c \ -ssf wave.fsdb \ -nologo \ -sswr ./signals.rc &

最后执行make verdi,在波形中可以看到12次AXI传输。

soma配置示例

运行示例

流程和前示例相似,区别在选择SOMA接口示例。

/usr/Cadence/vipcat/vipcat_11_30_106/tools/denali_64bit/ddvapi/sv/uvm/cdn_axi/examples/legacy_examples/using_soma_interface/axi4/example_setup_vcs.csh

环境生成

生成环境和前示例相似,主要看区别。
首先测试用例换成了modifyTransactionTest,大致上就是通过回调修改AXI延时的case。
此外VCS编译指令中加了CDN_AXI_USING_SOMA_INTERFACE宏定义,在verdi中搜索使用宏定义文件,发现只有接口parameter会用到,如果宏定义有效,则通过soma文件配置接口,否则通过常量配置。

soma配置

在testbench中,可以看到soma文件路径,分别是1主1从和1无效主。

通过执行pureview,打开配置界面,在界面中通过Open an existing file打开已有soma文件。

/usr/Cadence/vipcat/vipcat_11_30_106/tools/bin/pureview

这里打开activemaster.soma,可以看到各种配置,例如有效、主设备、AXI协议版本4。所以实际上soma是VIP配置文件,通过图形界面可以直观对环境配置进行修改。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/19 15:36:17

从2509到2511升级全记录,Qwen-Image-Edit变化实测

从2509到2511升级全记录,Qwen-Image-Edit变化实测 最近在批量处理工业产品图时,我注意到一个明显现象:用老版本Qwen-Image-Edit-2509修改机械零件表面纹理后,边缘常出现轻微色偏;而同事用新镜像跑同样指令&#xff0c…

作者头像 李华
网站建设 2026/3/13 3:06:12

YOLOv13推理速度实测:比v12更快更准!

YOLOv13推理速度实测:比v12更快更准! 你有没有遇到过这样的场景:模型精度刚调到满意,一跑推理——延迟飙到20ms,实时视频流直接卡成幻灯片?或者换了个新模型,AP涨了0.5,但部署时发现…

作者头像 李华
网站建设 2026/3/27 14:58:26

YOLOv10n模型下载慢?这个镜像帮你提速百倍

YOLOv10n模型下载慢?这个镜像帮你提速百倍 你有没有在深夜调试目标检测代码时,盯着终端里那个卡在“Downloading weights: 5%”的进度条,一边刷新网页查Hugging Face状态,一边怀疑人生? 你是不是刚在新服务器上执行 y…

作者头像 李华
网站建设 2026/3/23 13:41:24

信号发生器CAN总线接口配置核心要点

以下是对您提供的技术博文进行 深度润色与工程化重构后的版本 。全文已彻底去除AI生成痕迹,强化了真实工程师视角下的经验沉淀、故障推演与系统思维;结构上打破传统“模块堆砌”,以 问题驱动—原理穿透—配置落地—实战验证 为主线自然延…

作者头像 李华
网站建设 2026/3/28 8:11:51

开源大模型选型指南:Qwen2.5多语言支持优势详解

开源大模型选型指南:Qwen2.5多语言支持优势详解 1. 为什么多语言能力正在成为大模型的“硬门槛” 你有没有遇到过这样的情况: 用英文提示词生成的内容逻辑清晰、细节丰富,但换成中文就容易跑题?给海外团队部署一个客服助手&…

作者头像 李华
网站建设 2026/3/15 4:57:05

从0开始学AI修图:Qwen-Image-2512-ComfyUI保姆级入门指南

从0开始学AI修图:Qwen-Image-2512-ComfyUI保姆级入门指南 你是不是也经历过这些时刻: 刚收到一批商品图,每张右下角都带着刺眼的供应商水印; 客户临时要改一张海报的背景,可PS里抠图半小时还毛边; 想给老照…

作者头像 李华