CN117331775A - 一种参考模型调用方法、装置、设备及存储介质 - Google Patents
一种参考模型调用方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN117331775A CN117331775A CN202311265667.XA CN202311265667A CN117331775A CN 117331775 A CN117331775 A CN 117331775A CN 202311265667 A CN202311265667 A CN 202311265667A CN 117331775 A CN117331775 A CN 117331775A
- Authority
- CN
- China
- Prior art keywords
- transaction
- module
- tested
- reference model
- subsystem
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 47
- 238000012360 testing method Methods 0.000 claims abstract description 161
- 238000004088 simulation Methods 0.000 claims abstract description 62
- 238000012795 verification Methods 0.000 claims abstract description 44
- 238000004590 computer program Methods 0.000 claims description 16
- 238000006243 chemical reaction Methods 0.000 description 11
- 238000010586 diagram Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 6
- 230000005540 biological transmission Effects 0.000 description 5
- 238000004891 communication Methods 0.000 description 5
- 238000013461 design Methods 0.000 description 5
- 230000003139 buffering effect Effects 0.000 description 3
- 230000000712 assembly Effects 0.000 description 1
- 238000000429 assembly Methods 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 238000012827 research and development Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/22—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
- G06F11/26—Functional testing
- G06F11/261—Functional testing by simulating additional hardware, e.g. fault simulation
Abstract
本发明公开了一种参考模型调用方法、装置、设备及存储介质,涉及计算机技术领域,包括:从待测子系统的输入端获取初始事务,将初始事务进行解析处理以确定待调用的模块级参考模型;将初始事务传输至待调用的模块级参考模型以便待调用的模块级参考模型利用初始事务进行模拟测试得到模拟测试后事务,将模拟测试后事务发送至计分板;从待测子系统的输出端获取待测子系统利用初始事务进行测试得到的实际测试后事务,将实际测试后事务发送至计分板以便计分板基于模拟测试后事务和实际测试后事务判断当前测试是否满足测试预期。本发明通过调用验证完成的模块级参考模型,避免重新编写子系统级参考模型,节省时间和人力成本,提高了芯片的验证效率。
Description
技术领域
本发明涉及计算机技术领域,特别涉及一种参考模型调用方法、装置、设备及存储介质。
背景技术
芯片验证,就是结合应用需求校验芯片的设计是否达到了规范要求的功能和时序,保证芯片设计的正确性。芯片验证在芯片的研发过程中至关重要,从模块级到布局布线,都需要投入大量的时间和人力成本来进行细致全面的模拟和纠错,进而保证芯片流片后不会存在致命的设计缺陷。
当前芯片验证通常采用自下向上的系统级验证方案,能够缩短查错纠错的时间,并加快芯片的验证进度。首先对各基础模块进行全面的功能性验证,在此阶段,模块级验证的难度相对较低,便于定位和纠正芯片设计存在的错误。在进行系统级验证之前,通常会将芯片的整体架构根据功能分成多个部分,即子系统,子系统中的模块的功能通常是较为接近或类似的。在子系统级验证过程中,主要是测试各模块之间的接口命令、信号是否与预期一致,各模块的功能能否正常实现。与模块级验证类似,子系统级验证需要重新搭建验证平台,开发相关验证组件,编写测试用例和参考模型,在计分板中将实际输出数据与参考模型给出的理论输出数据进行对比,判断是否达到了测试预期。在完成芯片模块级验证的基础上,子系统级验证时需要重新开发验证环境和组件,尤其是参考模型,往往需要花费大量的时间重新编写参考模型,用于模拟待测子系统的各种功能。模块级验证时开发的参考模型只具有子系统的部分功能,如果将各模块级验证的参考模型进行调用,就可以节省大量的时间和人力成本,但由于子系统的输入、输出接口采用的总线和各模块的输入、输出接口采用的总线通常是不一致的,比如子系统采用的是AXI(即Advanced eXtensible Interface,高性能扩展总线接口)、AHB(即Advanced High-performance Bus,高级高性能总线)、APB(即Advanced Peripheral Bus,高级外设总线)等标准总线协议,而各模块采用的是非标准总线协议,这种情况是经常出现的,而这时调用各模块级验证的参考模型是非常困难。
发明内容
有鉴于此,本发明的目的在于提供一种参考模型调用方法、装置、设备及存储介质,能够节省子系统级验证时编写参考模型所需的时间和人力成本。其具体方案如下:
第一方面,本发明公开了一种参考模型调用方法,包括:
在芯片子系统级验证中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型;
将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,并将所述模拟测试后事务发送至计分板;
从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务,并将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
可选的,所述的参考模型调用方法,还包括:
获取所述待测子系统和所述待测子系统中各模块的基本信息,并基于所述基本信息生成相应的配置文件;
其中,所述基本信息包括所述待测子系统的模块组成架构、各所述模块的输入端口和输出端口的总线类型、各所述模块的绝对地址信息、各所述模块在所述待测子系统中的相对地址信息以及数据位宽。
可选的,所述基于所述基本信息生成相应的配置文件,包括:
读取目标表格中的表信息,并将所述表信息转化为宏数据以生成相应的配置文件;所述目标表格为将所述基本信息保存至预先建立的空白表格得到的表格。
可选的,所述将所述初始事务进行解析处理以确定出待调用的模块级参考模型,包括:
对所述初始事务进行解析以确定出目标模块的绝对地址,并根据所述目标模块的绝对地址和所述配置文件确定出待调用的模块级参考模型。
可选的,所述将所述初始事务传输至所述待调用的模块级参考模型之前,还包括:
根据所述配置文件将所述目标模块的绝对地址转换为所述目标模块在所述待测子系统中的相对地址;
基于所述配置文件确定所述目标模块的输入端口的总线协议,并判断所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议是否一致得到相应的第一判断结果;
相应的,所述将所述初始事务传输至所述待调用的模块级参考模型,包括:
如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议一致,则直接将所述初始事务传输至所述待调用的模块级参考模型;
如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议不一致,则将所述初始事务转换为所述目标模块的输入端口的总线所需的事务结构,并将转换后的所述初始事务发送至所述待调用的模块级参考模型。
可选的,所述将所述模拟测试后事务发送至计分板之前,还包括:
根据所述配置文件将所述目标模块在所述待测子系统中的所述相对地址转换为所述目标模块的所述绝对地址;
基于所述配置文件确定所述待测子系统的输出端口的总线协议,并判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到相应的第二判断结果;
相应的,所述将所述模拟测试后事务发送至计分板,包括:
如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议一致,则直接将所述模拟测试后事务发送至计分板;
如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议不一致,则将所述模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,并将转换后的所述模拟测试后事务发送至计分板。
可选的,所述将所述模拟测试后事务发送至计分板之前,还包括:
增加所述模拟测试后事务的来源信息;所述来源信息为表明所述模拟测试后事务来源于所述待调用的模块级参考模型的信息。
可选的,所述基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期,包括:
将所述模拟测试后事务中的待比较理论测试数据与所述实际测试后事务中的待比较实际测试数据进行对比,并基于所述对比结果判断当前测试是否满足测试预期。
第二方面,本发明公开了一种参考模型调用装置,包括:
第一获取模块,用于在芯片子系统级验证中,从待测子系统的输入端获取初始事务;
参考模型确定模块,用于将所述初始事务进行解析处理以确定出待调用的模块级参考模型;
模拟测试模块,用于将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务;
第一发送模块,用于将所述模拟测试后事务发送至计分板;
第二获取模块,用于从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务;
第二发送模块,用于将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
第三方面,本发明公开了一种电子设备,包括:
存储器,用于保存计算机程序;
处理器,用于执行所述计算机程序,以实现前述公开的参考模型调用方法的步骤。
第四方面,本发明公开了一种计算机可读存储介质,用于存储计算机程序;其中,所述计算机程序被处理器执行时实现前述公开的参考模型调用方法的步骤。
可见,本发明提供了一种参考模型调用方法,包括:在芯片子系统级验证中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型;将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,并将所述模拟测试后事务发送至计分板;从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务,并将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。由此可知,本发明通过调用已经验证完成的模块级参考模型,避免重新编写子系统级的参考模型,操作简单,通用性强,节省在芯片子系统级验证时编写参考模型所需的时间和人力成本,提高了芯片的验证效率。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本发明公开的一种参考模型调用方法流程图;
图2为本发明公开的一种具体的芯片子系统结构示意图;
图3为本发明公开的一种具体的芯片子系统级验证的参考模型调用方法流程图;
图4为本发明公开的一种具体的芯片子系统级验证的参考模型调用系统框架示意图;
图5为本发明公开的一种具体的芯片子系统级验证的参考模型调用系统的连接示意图;
图6为本发明公开的一种参考模型调用装置结构示意图;
图7为本发明公开的一种电子设备结构图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
当前,在完成芯片模块级验证的基础上,子系统级验证时需要重新开发验证环境和组件,尤其是参考模型,往往需要花费大量的时间重新编写参考模型,用于模拟待测子系统的各种功能。为此,本发明提供了一种参考模型调用方案,能够节省子系统验证时编写参考模型所需的时间和人力成本。
本发明实施例公开了一种参考模型调用方法,参见图1所示,该方法包括:
步骤S11:在芯片子系统级验证中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型。
本实施例中,在芯片子系统级验证中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型。例如,可以通过输入监视器从待测子系统的输入端获取初始事务,其中,输入监视器的输入端口与待测子系统的输入端口相连。芯片子系统结构参见图2所示,桥接模块A和桥接模块B主要是进行地址路由,桥接模块A根据接收到的事务中的地址决定将数据发送至哪个功能模块,桥接模块B根据各功能模块发送过来的事务中地址,将数据传输至其它的子系统,同时对各模块的事务优先级进行仲裁,其中,功能模块C1、功能模块C2、功能模块C3、功能模块C4的功能是相近或者相似的。
本实施例中,还包括:获取所述待测子系统和所述待测子系统中各模块的基本信息,并基于所述基本信息生成相应的配置文件;其中,所述基本信息包括所述待测子系统的模块组成架构、各所述模块的输入端口和输出端口的总线类型、各所述模块的绝对地址信息、各所述模块在所述待测子系统中的相对地址信息以及数据位宽。其中,所述基于所述基本信息生成相应的配置文件,具体可以包括:读取目标表格中的表信息,并将所述表信息转化为宏数据以生成相应的配置文件;所述目标表格为将所述基本信息保存至预先建立的空白表格得到的表格。可以理解的是,根据设计规范获取待测子系统的模块组成架构、各模块输入、输出接口的总线类型、各模块的绝对地址信息和各模块在待测子系统中的相对地址信息、数据位宽,填入预先制好的模板表格中,然后利用编写的python脚本读取表格信息以生成配置文件,也即将获取到的表格信息转换为验证描述语言可以识别的宏数据以生成相应的配置文件,该配置文件的格式可以为.svh格式,
本实施中,所述将所述初始事务进行解析处理以确定出待调用的模块级参考模型,具体可以包括:对所述初始事务进行解析以确定出目标模块的绝对地址,并根据所述目标模块的绝对地址和所述配置文件确定出待调用的模块级参考模型。可以理解的是,对初始事务进行解析,获得绝对地址、数据等信息,然后根据配置文件和解析初始事务得到的绝对地址确定需要使用哪个模块的参考模型,即根据所述目标模块的绝对地址和所述配置文件确定出待调用的模块级参考模型。例如,输入端监视器将从待测子系统的输入端获取到初始事务传输至输入适配器,通过输入适配器对将所述初始事务进行解析处理以确定出待调用的模块级参考模型,其中,所述输入适配器的输入端口与所述输入端监视器的输出端口相连。
步骤S12:将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,并将所述模拟测试后事务发送至计分板。
本实施例中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型之后,将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务。可以理解的是,通过调用已经验证完成的模块级参考模型利用所述初始事务进行模拟测试,从而能够避免重新编写子系统级的参考模型,操作简单,通用性强,节省了大量的时间和人工成本,提高了芯片的验证效率。例如,通过输入适配器对将所述初始事务进行解析处理以确定出待调用的模块级参考模型,同时通过输入适配器将所述初始事务相应的传输至待调用的模块级参考中以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,其中,所述输入适配器的输出端口与模块级参考模型的输入端口相连。
本实施例中,所述将所述初始事务传输至所述待调用的模块级参考模型之前,还可以包括:根据所述配置文件将所述目标模块的绝对地址转换为所述目标模块在所述待测子系统中的相对地址;基于所述配置文件确定所述目标模块的输入端口的总线协议,并判断所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议是否一致得到相应的第一判断结果;如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议一致,则直接将所述初始事务传输至所述待调用的模块级参考模型;如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议不一致,则将所述初始事务转换为所述目标模块的输入端口的总线所需的事务结构,并将转换后的所述初始事务发送至所述待调用的模块级参考模型。可以理解的是,将从待测子系统的输入端获取到的初始事务传输至待调用的模块级参考模型之前,判断模块级参考模型对应目标模块的输入端口的总线协议与待测子系统的输入端口的总线协议是否一致,如果一致,则可以直接将获取到的初始事务传输至待调用的模块级参考模型,如果不一致,则需要将获取到初始事务转化为所述目标模块的输入端口的总线所需的事务结构。例如,通过输入适配器对将所述初始事务进行解析处理以确定出待调用的模块级参考模型之后,还可以通过输入适配器根据所述配置文件将所述目标模块的绝对地址转换为所述目标模块在所述待测子系统中的相对地址,并判断模块级参考模型对应目标模块的输入端口的总线协议与待测子系统的输入端口的总线协议是否一致,如果一致,则可以直接将获取到的初始事务传输至待调用的模块级参考模型,如果不一致,则需要将获取到初始事务转化为所述目标模块的输入端口的总线所需的事务结构,也就是说,通过输入适配器根据目标模块的输入端口所需的事务结构对输入端监视器传输进来的初始事务的数据、ID(Identity,身份标识号码)、读写类型等信息进行处理,进而将处理后的初始事务发送给模块级参考模型。其中,所述输入适配器包含第一解析单元和第一转换单元,其中,在第一解析单元中,接收输入端监视器传输进来的初始事务,并对初始事务进行解析处理,然后根据解析信息中的绝对地址判断需要接下来需要将所述初始事务发送给哪个模块的参考模型,在第一转换单元中,将绝对地址转换为模块的相对地址,并基于判断模块级参考模型对应目标模块的输入端口的总线协议与待测子系统的输入端口的总线协议是否一致的第一判断结果确定是否将获取到初始事务转化为所述目标模块的输入端口的总线所需的事务结构,也即基于第一判断结果确定是否根据目标模块的事务结构对初始事务的数据、ID、读写类型等信息进行处理进而发送给模块级参考模型。也就是说,输入适配器主要负责接受输入端监视器发送过来的初始事务,进行对该初始事务解析、转换后发送给指定的模块级参考模型。
本实施例中,所述将所述模拟测试后事务发送至计分板之前,还包括:根据所述配置文件将所述目标模块在所述待测子系统中的所述相对地址转换为所述目标模块的所述绝对地址;基于所述配置文件确定所述待测子系统的输出端口的总线协议,并判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到相应的第二判断结果;如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议一致,则直接将所述模拟测试后事务发送至计分板;如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议不一致,则将所述模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,并将转换后的所述模拟测试后事务发送至计分板。可以理解的是,所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,将所述模拟测试后事务发送至计分板之前,需要判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致,如果一致,则可以直接将模块级参考模型输出的模拟测试后事务发送至计分板,如果不一致,则需要将该模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构。
并且,所述将所述模拟测试后事务发送至计分板之前,还可以包括:增加所述模拟测试后事务的来源信息;所述来源信息为表明所述模拟测试后事务来源于所述待调用的模块级参考模型的信息。
例如,待调用的模块级参考模型将利用所述初始事务进行模拟测试得到相应的模拟测试后事务至输出适配器,通过输出适配器根据所述配置文件将所述目标模块在所述待测子系统中的所述相对地址转换为所述目标模块的所述绝对地址,并判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致,如果一致,则可以直接将模块级参考模型输出的模拟测试后事务发送至计分板,如果不一致,则需要将该模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,也就是说,通过输出适配器根据待测子系统的输出端口的总线所需的事务结构对模块级参考模型传输过来的模拟测试后事务的数据、ID、读写类型等信息进行处理例如,例如事务的数据位宽不匹配时,需要对数据进行拆分或者合并,进而将处理后的模拟测试后事务发送给计分板。其中,待调用的模块级参考模型的输出端口与所述输出适配器的输入端口相连。其中,所述输出适配器包含第二解析单元和第二转换单元,其中,在第一解析单元中,接收待调用的模块级参考模型传输过来的模拟测试后事务,为模拟测试后事务增加补充信息,表明这笔事务来源于哪个参考模型,在第二转换单元中,将相对地址转换为绝对地址,并基于判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到的第二判断结果确定是否将该模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,也即基于第二判断结果确定是否根据待测子系统的输出端口的总线事务结构对参考模型传输过来的模拟测试后事务的数据、ID、读写类型等信息进行处理,例如,例如事务的数据位宽不匹配时,需要对数据进行拆分或者合并,进而发送给计分板的输入端口以在计分板中进行数据的比较。也就是说,输出适配器主要负责接受各模块级参考模型传输过来的模拟测试后事务,进行解析、转换后发送给计分板。
步骤S13:从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务,并将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
本实施例中,将初始事务从待测子系统的输入端口输入至待测子系统中,待测子系统利用该初始事务进行测试得到相应的实际测试后事务,然后将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。例如,通过输出端监视器从所述待测子系统输出端抓取待测子系统输出的所述实际测试后事务,同时通过所述输出监视器将所述实际测试后事务传输至计分板中,其中,所述输出端监视器的输入端与所述待测子系统的输出端口相连。并且,在所述计分板中,具体将所述模拟测试后事务中的待比较理论测试数据与所述实际测试后事务中的待比较实际测试数据进行对比,并基于所述对比结果判断当前测试是否满足测试预期。
可见,本发明实施例中,通过调用已经验证完成的模块级参考模型,避免重新编写子系统级的参考模型,操作简单,通用性强,节省在芯片子系统级验证时编写参考模型所需的时间和人力成本,提高了芯片的验证效率。
例如,参见图3所示,提取待测子系统及模块的基本信息,将这些基本填入预先制好的模板表格中,然后利用编写的python脚本读取模板表格中的表格信息以生成配置文件,将参考模型的调用系统移植至在验证环境中,输入适配器接收、转换,输入端监视器传输过来的初始事务,然后将初始事务发送中模块级参考模型,输出适配器接收、转换模块级参考模型传输的模拟测试后事务,并发送至计分板,在计分板中基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期;其中所述实际测试后事务为输出端监视器从待测子系统输出端抓取到的待测子系统利用所述初始事务进行测试得到的实际测试后事务,同时通过输出端监视器将该实际测试事务发送至计分板。也即,在输入适配器中,接收输入端监视器传输过来的初始事务,该初始事务为所述输入端监视器从待测子系统的输入端抓取到的事务,然后通过输入适配器将事务进行解析,获得绝对地址、数据等信息,根据绝对地址和配置文件判断需要使用哪个目标模块的参考模型以及数据输出端口,并在模块级参考模型对应目标模块的输入端口的总线协议与待测子系统的输入端口的总线协议不一致时,根据总线类型将初始事务转换成目标模块所需的事务结构,一致时无需转换,直接将初始事务传输至对应的数据输出端口以通过所述适配器的数据输出端口将初始事件传输至判断出的模块级参考模型。在输出适配器中,根据模块级参考模型通过输出适配器不同输入端口传输过来的模拟测试后事务,进行解析和转换,在所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议不一致时,将该模拟测试后事务转换成待测子系统的输出端口的总线需要的事务结构,进而发送至计分板,在计分板中将待测子系统输出的实际输出数据与参考模型给出的理论输出数据进行对比,判断是否达到了测试预期。
其中,所述参考模型的调用系统参见图4所示,该调用系统中利用编写的python脚本读取模板表格中的表格信息以生成配置文件,其中,所述输入适配器包含第一解析单元和第一转换单元,其中,在第一解析单元中,接收输入端监视器传输进来的初始事务,并对初始事务进行解析处理,然后根据解析信息中的绝对地址判断需要接下来需要将所述初始事务发送给哪个模块的参考模型,在第一转换单元中,将绝对地址转换为模块的相对地址,并基于判断模块级参考模型对应目标模块的输入端口的总线协议与待测子系统的输入端口的总线协议是否一致的第一判断结果确定是否将获取到初始事务转化为所述目标模块的输入端口的总线所需的事务结构,也即基于第一判断结果确定是否根据目标模块的事务结构对初始事务的数据、ID、读写类型等信息进行处理进而发送给模块级参考模型。也就是说,输入适配器主要负责接受输入端监视器发送过来的初始事务,进行对该初始事务解析、转换后发送给指定的模块级参考模型。所述输出适配器包含第二解析单元和第二转换单元,其中,在第一解析单元中,接收待调用的模块级参考模型传输过来的模拟测试后事务,为模拟测试后事务增加补充信息,表明这笔事务来源于哪个参考模型,在第二转换单元中,将相对地址转换为绝对地址,并基于判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到的第二判断结果确定是否将该模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,也即基于第二判断结果确定是否根据待测子系统的输出端口的总线事务结构对参考模型传输过来的模拟测试后事务的数据、ID、读写类型等信息进行处理进而发送给计分板的输入端口以在计分板中进行数据的比较。也就是说,输出适配器主要负责接受各模块级参考模型传输过来的模拟测试后事务,进行解析、转换后发送给计分板。
并且,输入端监视器、输入适配器、各模块级验证的参考模型、输出适配器、计分板、输出端监视器、待测子系统之间的连接,参见图5所示,输入监视器的输入端口与待测子系统的输入端口相连所述输入适配器的输入端口与所述输入端监视器的输出端口相连,并增加FIFO(First In,First Out)队列用于缓存,所述输入适配器的输出端口与模块级参考模型的输入端口相连,并增加FIFO用于缓存,待调用的模块级参考模型的输出端口与所述输出适配器的输入端口相连,并增加FIFO用于缓存,所述输出适配器的输出端口与计分板的输入端口相连,并增加FIFO用于缓存,所述输出端监视器的输入端与所述待测子系统的输出端口相连,所述输出端监视器的输出端也与计分板的输入端口相连。
相应的,本发明实施例还公开了一种参考模型调用装置,参见图6所示,该装置包括:
第一获取模块11,用于在芯片子系统级验证中,从待测子系统的输入端获取初始事务;
参考模型确定模块12,用于将所述初始事务进行解析处理以确定出待调用的模块级参考模型;
模拟测试模块13,用于将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务;
第一发送模块14,用于将所述模拟测试后事务发送至计分板;
第二获取模块15,用于从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务;
第二发送模块16,用于将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
由上可见,本发明实施例中通过调用已经验证完成的模块级参考模型,避免重新编写子系统级的参考模型,操作简单,通用性强,节省在芯片子系统级验证时编写参考模型所需的时间和人力成本,提高了芯片的验证效率。
在一些具体的实施例中,所述参考模型调用装置,具体还可以包括:
基本信息获取模块,用于获取所述待测子系统和所述待测子系统中各模块的基本信息;
配置文件生成模块,用于基于所述基本信息生成相应的配置文件;
其中,所述基本信息包括所述待测子系统的模块组成架构、各所述模块的输入端口和输出端口的总线类型、各所述模块的绝对地址信息、各所述模块在所述待测子系统中的相对地址信息以及数据位宽。
在一些具体的实施例中,所述配置文件生成模块,具体可以包括:
表信息读取单元,用于读取目标表格中的表信息;
表信息转换单元,用于将所述表信息转化为宏数据以生成相应的配置文件;所述目标表格为将所述基本信息保存至预先建立的空白表格得到的表格。
在一些具体的实施例中,所述参考模型确定模块12,具体可以包括:
绝对地址确定单元,用于对所述初始事务进行解析以确定出目标模块的绝对地址;
参考模型确定单元,用于根据所述目标模块的绝对地址和所述配置文件确定出待调用的模块级参考模型。
在一些具体的实施例中,所述参考模型调用装置,具体还可以包括:
第一地址转换模块,用于根据所述配置文件将所述目标模块的绝对地址转换为所述目标模块在所述待测子系统中的相对地址;
第一总线协议确定模块,用于基于所述配置文件确定所述目标模块的输入端口的总线协议;
第一判断模块,用于判断所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议是否一致得到相应的第一判断结果;
在一些具体的实施例中,所述模拟测试模块13,具体可以包括:
第一传输单元,用于在所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议一致时,则直接将所述初始事务传输至所述待调用的模块级参考模型;
第二传输单元,用于在所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议不一致时,则将所述初始事务转换为所述目标模块的输入端口的总线所需的事务结构,并将转换后的所述初始事务发送至所述待调用的模块级参考模型。
在一些具体的实施例中,所述参考模型调用装置,具体还可以包括:
第二地址转换模块,用于根据所述配置文件将所述目标模块在所述待测子系统中的所述相对地址转换为所述目标模块的所述绝对地址;
第二总线协议确定模块,用于基于所述配置文件确定所述待测子系统的输出端口的总线协议;
第二判断模块,用于判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到相应的第二判断结果;
在一些具体的实施例中,所述第一发送模块14,具体可以包括:
第三传输单元,用于在所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议一致时,则直接将所述模拟测试后事务发送至计分板;
第四传输单元,用于在所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议不一致时,则将所述模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,并将转换后的所述模拟测试后事务发送至计分板。
在一些具体的实施例中,所述参考模型调用装置,具体还可以包括:
信息增加模块,用于增加所述模拟测试后事务的来源信息;所述来源信息为表明所述模拟测试后事务来源于所述待调用的模块级参考模型的信息。
在一些具体的实施例中,所述第二发送模块16,具体还可以包括:
数据对比单元,用于将所述模拟测试后事务中的待比较理论测试数据与所述实际测试后事务中的待比较实际测试数据进行对比,并基于所述对比结果判断当前测试是否满足测试预期。
进一步的,本发明实施例还提供了一种电子设备。图7是根据一示例性实施例示出的电子设备20结构图,图中的内容不能认为是对本发明的使用范围的任何限制。
图7为本发明实施例提供的一种电子设备20的结构示意图。该电子设备20,具体可以包括:至少一个处理器21、至少一个存储器22、电源23、通信接口24、输入输出接口25和通信总线26。其中,所述存储器22用于存储计算机程序,所述计算机程序由所述处理器21加载并执行,以实现前述任一实施例公开的参考模型调用方法中的相关步骤。另外,本实施例中的电子设备20具体可以为电子计算机。
本实施例中,电源23用于为电子设备20上的各硬件设备提供工作电压;通信接口24能够为电子设备20创建与外界设备之间的数据传输通道,其所遵循的通信协议是能够适用于本发明技术方案的任意通信协议,在此不对其进行具体限定;输入输出接口25,用于获取外界输入数据或向外界输出数据,其具体的接口类型可以根据具体应用需要进行选取,在此不进行具体限定。
另外,存储器22作为资源存储的载体,可以是只读存储器、随机存储器、磁盘或者光盘等,其上所存储的资源可以包括操作系统221、计算机程序222等,存储方式可以是短暂存储或者永久存储。
其中,操作系统221用于管理与控制电子设备20上的各硬件设备以及计算机程序222,其可以是Windows Server、Netware、Unix、Linux等。计算机程序222除了包括能够用于完成前述任一实施例公开的由电子设备20执行的参考模型调用方法的计算机程序之外,还可以进一步包括能够用于完成其他特定工作的计算机程序。
进一步的,本发明实施例还公开了一种计算机可读存储介质,所述计算机可读存储介质中存储有计算机程序,所述计算机程序被处理器加载并执行时,实现前述任一实施例公开的参考模型调用方法步骤。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上对本发明所提供的一种参考模型调用方法、装置、设备及存储介质进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (11)
1.一种参考模型调用方法,其特征在于,包括:
在芯片子系统级验证中,从待测子系统的输入端获取初始事务,并将所述初始事务进行解析处理以确定出待调用的模块级参考模型;
将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务,并将所述模拟测试后事务发送至计分板;
从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务,并将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
2.根据权利要求1所述的参考模型调用方法,其特征在于,还包括:
获取所述待测子系统和所述待测子系统中各模块的基本信息,并基于所述基本信息生成相应的配置文件;
其中,所述基本信息包括所述待测子系统的模块组成架构、各所述模块的输入端口和输出端口的总线类型、各所述模块的绝对地址信息、各所述模块在所述待测子系统中的相对地址信息以及数据位宽。
3.根据权利要求2所述的参考模型调用方法,其特征在于,所述基于所述基本信息生成相应的配置文件,包括:
读取目标表格中的表信息,并将所述表信息转化为宏数据以生成相应的配置文件;所述目标表格为将所述基本信息保存至预先建立的空白表格得到的表格。
4.根据权利要求3所述的参考模型调用方法,其特征在于,所述将所述初始事务进行解析处理以确定出待调用的模块级参考模型,包括:
对所述初始事务进行解析以确定出目标模块的绝对地址,并根据所述目标模块的绝对地址和所述配置文件确定出待调用的模块级参考模型。
5.根据权利要求4所述的参考模型调用方法,其特征在于,所述将所述初始事务传输至所述待调用的模块级参考模型之前,还包括:
根据所述配置文件将所述目标模块的绝对地址转换为所述目标模块在所述待测子系统中的相对地址;
基于所述配置文件确定所述目标模块的输入端口的总线协议,并判断所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议是否一致得到相应的第一判断结果;
相应的,所述将所述初始事务传输至所述待调用的模块级参考模型,包括:
如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议一致,则直接将所述初始事务传输至所述待调用的模块级参考模型;
如果所述第一判断结果表明所述目标模块的输入端口的总线协议与所述待测子系统的输入端口的总线协议不一致,则将所述初始事务转换为所述目标模块的输入端口的总线所需的事务结构,并将转换后的所述初始事务发送至所述待调用的模块级参考模型。
6.根据权利要求5所述的参考模型调用方法,其特征在于,所述将所述模拟测试后事务发送至计分板之前,还包括:
根据所述配置文件将所述目标模块在所述待测子系统中的所述相对地址转换为所述目标模块的所述绝对地址;
基于所述配置文件确定所述待测子系统的输出端口的总线协议,并判断所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议是否一致得到相应的第二判断结果;
相应的,所述将所述模拟测试后事务发送至计分板,包括:
如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议一致,则直接将所述模拟测试后事务发送至计分板;
如果所述第二判断结果表明所述目标模块的输出端口的总线协议与所述待测子系统的输出端口的总线协议不一致,则将所述模拟测试后事务转换为所述待测子系统的输出端口的总线所需的事务结构,并将转换后的所述模拟测试后事务发送至计分板。
7.根据权利要求1至6任一项所述的参考模型调用方法,其特征在于,所述将所述模拟测试后事务发送至计分板之前,还包括:
增加所述模拟测试后事务的来源信息;所述来源信息为表明所述模拟测试后事务来源于所述待调用的模块级参考模型的信息。
8.根据权利要求7所述的参考模型调用方法,其特征在于,所述基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期,包括:
将所述模拟测试后事务中的待比较理论测试数据与所述实际测试后事务中的待比较实际测试数据进行对比,并基于所述对比结果判断当前测试是否满足测试预期。
9.一种参考模型调用装置,其特征在于,包括:
第一获取模块,用于在芯片子系统级验证中,从待测子系统的输入端获取初始事务;
参考模型确定模块,用于将所述初始事务进行解析处理以确定出待调用的模块级参考模型;
模拟测试模块,用于将所述初始事务传输至所述待调用的模块级参考模型以便所述待调用的模块级参考模型利用所述初始事务进行模拟测试得到相应的模拟测试后事务;
第一发送模块,用于将所述模拟测试后事务发送至计分板;
第二获取模块,用于从所述待测子系统的输出端获取所述待测子系统利用所述初始事务进行测试得到相应的实际测试后事务;
第二发送模块,用于将所述实际测试后事务发送至所述计分板以便所述计分板基于所述模拟测试后事务和所述实际测试后事务判断当前测试是否满足测试预期。
10.一种电子设备,其特征在于,包括:
存储器,用于保存计算机程序;
处理器,用于执行所述计算机程序,以实现如权利要求1至8任一项所述的参考模型调用方法的步骤。
11.一种计算机可读存储介质,其特征在于,用于存储计算机程序;其中,所述计算机程序被处理器执行时实现如权利要求1至8任一项所述的参考模型调用方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202311265667.XA CN117331775A (zh) | 2023-09-27 | 2023-09-27 | 一种参考模型调用方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202311265667.XA CN117331775A (zh) | 2023-09-27 | 2023-09-27 | 一种参考模型调用方法、装置、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN117331775A true CN117331775A (zh) | 2024-01-02 |
Family
ID=89282332
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202311265667.XA Pending CN117331775A (zh) | 2023-09-27 | 2023-09-27 | 一种参考模型调用方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN117331775A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117555741A (zh) * | 2024-01-10 | 2024-02-13 | 深流微智能科技(深圳)有限公司 | 基于uvm的原子指令模块验证系统、方法、设备及介质 |
-
2023
- 2023-09-27 CN CN202311265667.XA patent/CN117331775A/zh active Pending
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117555741A (zh) * | 2024-01-10 | 2024-02-13 | 深流微智能科技(深圳)有限公司 | 基于uvm的原子指令模块验证系统、方法、设备及介质 |
CN117555741B (zh) * | 2024-01-10 | 2024-04-26 | 深流微智能科技(深圳)有限公司 | 基于uvm的原子指令模块验证系统、方法、设备及介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11893331B2 (en) | Device verification method, UVM verification platform, electronic apparatus and storage medium | |
CN117331775A (zh) | 一种参考模型调用方法、装置、设备及存储介质 | |
CN108874665A (zh) | 一种测试结果校验方法、装置、设备和介质 | |
US7310798B1 (en) | Simulator tool for testing software in development process | |
CN113485881B (zh) | 一种临时限速服务器的测试方法、装置、电子设备及介质 | |
CN112417798A (zh) | 一种时序测试方法、装置、电子设备及存储介质 | |
CN112559273A (zh) | 一种基于uvm的qspi验证系统及方法 | |
CN113572658A (zh) | 车辆控制信号的测试方法、装置、电子设备及存储介质 | |
CN102681525B (zh) | 一种转换控制器的验证方法及系统 | |
CN116821001A (zh) | 输入输出子系统的验证方法、装置、电子设备及介质 | |
CN108776723B (zh) | 测试系统自检适配器连线生成方法、装置、设备及存储介质 | |
CN115688686B (zh) | 一种lvc资源接入校验方法及设备 | |
CN116663490A (zh) | 一种异步存储芯片的验证方法、平台、装置及介质 | |
CN116306479A (zh) | 基于uvm的以太网phy通用验证平台及验证方法 | |
CN115546927A (zh) | 一种基于autosar标准的uds诊断自动化测试系统 | |
CN115391181A (zh) | 一种soc芯片的验证方法 | |
CN115062571A (zh) | 应用于集成电路器件的数据区域动态选取方法、系统、设备和计算机可读存储介质 | |
US20230035673A1 (en) | Information processing system, information processing apparatus, use method of information processing apparatus, user terminal, and program therefor | |
CN111510483B (zh) | 芯片测试中不同网络域之间的配置同步系统、方法及装置 | |
CN114328045A (zh) | 一种bmc的i2c调试方法、系统、装置及计算机可读存储介质 | |
CN112528577A (zh) | 时钟复位电路的管理方法、装置和计算机存储介质 | |
AU2023201696B2 (en) | Method and device for determining coverage in HIL testing, and storage medium | |
CN116541270B (zh) | 一种操作系统的适配验证测试方法及装置 | |
CN116909935B (zh) | 基于单一处理模块接口的芯片联合仿真方法、设备和介质 | |
CN112710945B (zh) | 一种通用校时测试设备及方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |