【芯片前端】Filelist -f/-F的文件解析方式探究

简介: 【芯片前端】Filelist -f/-F的文件解析方式探究

前言

测试所用的文件目录(列举关键文件):

1. /home/xiaotu/my_work/uvm_demo
2. -cfg/
3. -ctl/
4. -rtl/
5. -sim/
6.     -Makefile
7. -tc/
8. -th/
9. -ver/

-f/-F影响后跟filelist文件内的解析方式,不影响后跟文件的解析方式

典型的场景,就是makefile里用-f还是-F来后缀路径都是一样的(仅仅对于解析这个list) ,绝对路径就按绝对路径解析,相对路径就相对makefile所在目录进行解析。

而../cfg/tb.f中的所有路径都受到到前面的-f或-F影响,如上图的解析方式时,../cfg/tb.f中无论以下哪种写法,都是按-f来解析文件路径的:

1. -F ../ctl/ctl.f
2. -f ../rtl/dut.f
3. ../rtl/a.v

-f解析filelist内的路径时,与当前filelist所在路径无关

-f ../cfg/tb.f,

当tb.f内路径为相对路径时,则相对makefile所在路径进行解析;

当tb.f内路径为绝对路径时,则直接按照绝对路径进行解析;

进一步讲,-f path/file.f中path不会以任何形式影响file.f中的文件路径解析;

-F解析filelist内的路径时,与当前filelist所在路径有关

-F ../cfg/tb.f

当tb.f内路径为相对路径时,则会前缀filelist所在路径进行解析;

1. ../cfg/cfg.f中的写法:
2. ../th/harness.sv
3. 
4. cmp.log中解析的路径:
5. Parsing design file '../cfg/../th/harness.sv'

当tb.f内路径为绝对路径时,则不会前缀任何路径,直接解析绝对路径;

1. ../cfg/cfg.f中的写法:
2. /home/xiaotu/my_work/uvm_demo/ver/my_env.sv
3. 
4. cmp.log中解析的路径:
5. Parsing design file '/home/xiaotu/my_work/uvm_demo/ver/my_env.sv'

当tb.f内路为-y加载的库文件时,则直接视为相对路径,前缀filelist所在路径进行解析;

1. ../cfg/cfg.f中的写法:
2. -y /home/xiaotu/my_work/uvm_demo/rtl
3. 
4. cmp.log中解析的路径:
5. Warning-[LFCOR] Library file or dir cannot be opened
6.   Library directory '../cfg//home/xiaotu/my_work/uvm_demo/rtl' cannot be 
7.   opened for reading due to 'No such file or directory', will skip it.
8.   The library was specified from command line through -y or -v.

当tb.f内路为-f+filelist时,则直接视为相对路径,前缀-F的filelist所在路径进行解析;

1. Makefile中:
2. -F ../cfg/tb.f
3. 
4. ../cfg/tb.f中:
5. -f /home/xiaotu/my_work/uvm_demo/cfg/dut.f
6.

编译报错:

1. Error-[P1ARGS-CANTOPN-F] Cannot open file
2.   Unable to open '../cfg//home/xiaotu/my_work/uvm_demo/cfg/dut.f' due to 'No 
3.   such file or directory'.
4.   Please fix the reason mentioned above and continue.

嵌套的场景

1. ../cfg/cfg.f内的路径:
2. -f/-F ../cfg/dut.f(层次A)
3. 
4. 
5. ../cfg/dut.f内的路径为:
6. -f/-F ../ctl/ctl.f(层次B)
7. 
8. ../ctl/ctl.f内文件为:
9. ../ctl/my_interface.sv

-f(层次A)嵌套-f(层次B),两次解析均按照绝对路径,或相对Makefile的相对路径进行解析;

-f(层次A)嵌套-F(层次B),层次B以-f的方式解析,层次B内的文件绝对路径正常解析,相对路径则相对层次B(即../ctl/)进行解析;

Parsing design file '../cfg/../ctl/my_interface.sv'

-F(层次A)嵌套-f(层次B),-f后面负责的相对路径都相对的是-F后跟文件所在目录的相对路径

太绕了,举个具体点的例子:

1. Makefile中:
2. -F ../cfg/tb.f
3. 
4. ../cfg/tb.f中:
5. -f ./dut.f
6. 
7. ./dut.f中(dut.f在cfg目录):
8. ../rtl/mul_trans.v
9. -f ../ctl/ctl.f
10. 
11. ../ctl/ctl.f中:
12. ../ctl/my_interface.sv

那么mul_trans.v的编译路径为:

Parsing design file '../cfg/../rtl/mul_trans.v'

../cfg —— -F ../cfg/tb.f使得tb.f内的相对路径解析都要加上前缀../cfg;

../cfg/../rtl/mul_trans.v —— -f ./dut.f因此解析dut.f内相对路径的文件时相对的是当前../cfg的路径(上一层-F的作用);

还有my_interface.sv的解析路径:

Parsing design file '../cfg/../ctl/my_interface.sv'

其形式是-F嵌套-f再嵌套-f,可以看到后面两个-f都是相对../cfg进行解析,两个-f间没有路径叠加(如上文,-f path/file.f中path不会以任何形式影响file.f中的文件路径解析);

-F(层次A)嵌套-f(层次B),-f后跟filelist内(如果该filelist被找到)的绝对路径则会编译为绝对路径

1. Makefile中:
2. -F ../cfg/tb.f
3. 
4. ../cfg/tb.f中:
5. -f ../cfg/dut.f
6. 
7. ../cfg/dut.f中:
8. /home/xiaotu/my_work/uvm_demo/rtl/mul_trans.v

编译结果(这一点与我之前记忆有偏差,我再查一下,目前实测的结果确实是这样的):

Parsing design file '/home/xiaotu/my_work/uvm_demo/rtl/mul_trans.v'

综合看,-F嵌套-f会影响-f对其后filelist内相对路径的解析,使用起来要异常谨慎;

-F(层次A)嵌套-F(层次B)

遵循-F层层递进的规律,略

总结

因为-F对其后递进拆解filelist的影响更大,因此个人认为还是以-f+绝对路径的方式来组织filelist是最为合理安全的。


相关文章
|
存储 前端开发 安全
前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
本文全面解析前端三种数据存储方式:Cookie、LocalStorage与SessionStorage。涵盖其定义、使用方法、生命周期、优缺点及典型应用场景,帮助开发者根据登录状态、用户偏好、会话控制等需求,选择合适的存储方案,提升Web应用的性能与安全性。(238字)
1026 0
|
10月前
|
Web App开发 前端开发 JavaScript
前端性能优化利器:图片懒加载实战解析
前端性能优化利器:图片懒加载实战解析
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
503 2
|
存储 前端开发 JavaScript
调用DeepSeek API增强版纯前端实现方案,支持文件上传和内容解析功能
本方案基于DeepSeek API增强版,提供纯前端实现的文件上传与内容解析功能。通过HTML和JavaScript,用户可选择文件并调用API完成上传及解析操作。方案支持多种文件格式(如PDF、TXT、DOCX),具备简化架构、提高响应速度和增强安全性等优势。示例代码展示了文件上传、内容解析及结果展示的完整流程,适合快速构建高效Web应用。开发者可根据需求扩展功能,满足多样化场景要求。
3657 64
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
514 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
11月前
|
存储 前端开发 JavaScript
|
9月前
|
人工智能 JSON 前端开发
如何解决后端Agent和前端UI之间的交互问题?——解析AG-UI协议的神奇作用
三桥君指出AG-UI协议通过SSE技术实现智能体与前端UI的标准化交互,解决流式传输、实时进度显示、数据同步等开发痛点。其核心功能包括结构化事件流、多Agent任务交接和用户中断处理,具有"一次开发到处兼容"、"UI灵活可扩展"等优势。智能体专家三桥君认为协议将AI应用从聊天工具升级为实用软件,适用于代码生成、多步骤工作流等场景,显著提升开发效率和用户体验。
2211 0
|
10月前
|
JSON 前端开发 安全
前端开发中常用的鉴权方式解析与实践要点
本文深入探讨了前端开发中常用的鉴权方式,包括HTTP基本鉴权、Session-Cookie鉴权、Token验证、JWT(JSON Web Tokens)、单点登录(SSO)和OAuth等。文章首先明确了认证、授权、鉴权和权限控制的概念及关系,随后详细解析每种鉴权方式的工作原理、优缺点及适用场景。例如,HTTP基本鉴权简单但安全性低,适合内部网络;Session-Cookie鉴权易受CSRF攻击,适用于同域Web应用;Token和JWT无状态且扩展性好,适合分布式系统;SSO提升用户体验,适用于多系统统一登录;OAuth安全方便,适合第三方授权接入。
1131 2
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
3626 65
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
前端开发 Cloud Native Java
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现

推荐镜像

更多
  • DNS
  • 下一篇
    开通oss服务