一种覆盖率标记文件更新方法、装置、设备及存储介质与流程

未命名 09-18 阅读:327 评论:0


1.本技术涉及软件测试技术领域,尤其涉及一种覆盖率标记文件更新方法、装置、设备及存储介质。


背景技术:

2.在集成电路功能设计过程中,覆盖率是芯片验证方法学中衡量当前验证方案是否完备的重要指标,而覆盖率标记文件是设计或验证人员进行覆盖率分析时,对设计或验证环境源文件及其覆盖点进行标记、标注的途径。
3.在进行代码覆盖率分析时,往往会出现随着设计文件的修改,旧代码的覆盖率标记文件无法完全映射到新的设计或验证文件上的现象,尤其是一处修改就可能影响所有覆盖率标记文件的重新标记。在这类问题出现时,往往需要设计或验证人员手动修改大量的标记文件,不仅费时费力,还会导致代码覆盖率迭代频率和迭代效率低下,同时考虑到覆盖率对于芯片功能正确性和鲁棒性具有的决定性意义,代码覆盖率迭代频率和迭代效率低下还会间接降低芯片的功能鲁棒性。因此,现有技术中存在更新覆盖率标记文件的方法费时费力、导致代码覆盖率迭代频率和迭代效率低下、芯片的功能鲁棒性低下的问题。


技术实现要素:

4.本技术提供了一种覆盖率标记文件更新方法、装置、设备及存储介质,能够提升代码覆盖率迭代频率和迭代效率,从而间接提升了芯片的功能鲁棒性。
5.第一方面,本技术实施例提供了一种覆盖率标记文件更新方法,该方法包括:
6.步骤s1,获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项;
7.步骤s2,根据新程序文件对覆盖项进行更新;
8.步骤s3,对原始覆盖率标记文件重复执行步骤s1-s2,直至遍历完原始覆盖率标记文件中的所有覆盖项,得到新程序文件对应的目标覆盖率标记文件。
9.进一步的,覆盖项包括标记项字典序号、标记项序号、逻辑表达式、文件行号和文件序号。
10.上述实施例中覆盖项所包括的标记信息,能够帮助设计或验证人员根据这些标记信息对芯片的代码覆盖率进行快速、高效的分析。
11.进一步的,上述根据新程序文件对覆盖项进行更新,包括:将覆盖项的逻辑表达式和文件行号与新程序文件进行对比,得到对比结果;根据对比结果对覆盖项进行更新。
12.上述实施例通过覆盖项的逻辑表达式和文件行号与新程序文件进行对比,能够快速准确地判断出该覆盖项对应的代码是否出现修改、该覆盖项是否需要更新。
13.进一步的,上述根据对比结果对覆盖项进行更新,包括:
14.若新程序文件中不存在覆盖项的逻辑表达式,则删除覆盖项。
15.上述实施例实现了当原始程序文档中代码出现删除操作时,覆盖项在新程序文件中的映射。
16.进一步的,上述根据对比结果对覆盖项进行更新,包括:
17.根据对比结果判断覆盖项的逻辑表达式或文件行号在新程序文件中是否发生了变化;
18.若是,则综合逻辑表达式,得到综合逻辑关系,并基于综合逻辑关系和新程序文件的综合数据库对覆盖项进行更新;若否,则保留覆盖项。
19.上述实施例利用了左值变量的定位是唯一确定的性质,基于综合逻辑关系和综合数据库对覆盖项进行更新,从而保证该逻辑表达式对应的覆盖项更新的准确性。
20.进一步的,上述基于综合逻辑关系和新程序文件的综合数据库对覆盖项进行更新,包括:
21.判断综合逻辑关系在综合数据库中是否有匹配;
22.若是,则根据对比结果获取逻辑表达式在新程序文件中的目标文件行号,将覆盖项中的文件行号更新为目标文件行号;若否,则判断逻辑表达式的左值在综合数据库中是否存在;
23.若存在,则根据对比结果获取新程序文件中左值对应的目标表达式,将覆盖项中的逻辑表达式更新为目标表达式;否则删除覆盖项。
24.上述实施例通过对综合数据库中综合逻辑关系的匹配和左值的检测,实现了对发生增加、分离和合并修改操作的代码的覆盖项的快速更新,避免了人为手动操作导致的效率低下。
25.进一步的,该方法还包括:在遍历完原始覆盖率标记文件中的所有覆盖项后,基于目标文件行号对各覆盖项进行排序,得到目标覆盖率标记文件。
26.上述实施例解决了当逻辑表达式的左值在新程序文件中的行号位置发生变化时导致更新后的所有覆盖项排序错误的问题,保证了目标覆盖率标记文件的准确性。
27.进一步的,该方法还包括:
28.在删除覆盖项后,生成覆盖项对应的删除警告信息。
29.上述实施例避免了本技术的删除覆盖项的操作有误的情况,通过在删除后发送删除警告信息提醒用户,使用户确认删掉的覆盖项是否正确,保证了目标覆盖率标记文件的准确性。
30.进一步的,该方法还包括:
31.在将覆盖项中的文件行号更新为目标文件行号后,或者将覆盖项中的逻辑表达式更新为目标表达式后,生成该覆盖项对应的标记警告信息。
32.上述实施例通过提醒用户覆盖项更新的位置,方便用户确认本技术更新的覆盖项是否正确,从而保证了目标覆盖率标记文件的准确性。
33.第二方面,本技术实施例提供了一种覆盖率标记文件更新装置,该装置包括:
34.覆盖项获取模块,用于获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项;
35.更新模块,用于根据新程序文件对覆盖项进行更新;
36.遍历模块,用于对原始覆盖率标记文件重复执行覆盖项获取模块和更新模块,直至遍历完原始覆盖率标记文件中的所有覆盖项,得到新程序文件对应的目标覆盖率标记文件。
37.第三方面,本技术实施例提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,处理器执行计算机程序时执行如上述任一实施例的一种覆盖率标记文件更新方法的步骤。
38.第四方面,本技术实施例提供了一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现如上述任一实施例的一种覆盖率标记文件更新方法的步骤。
39.综上,与现有技术相比,本技术实施例提供的技术方案带来的有益效果至少包括:
40.本技术实施例提供的一种覆盖率标记文件更新方法,根据新程序文件,逐项更新原始程序文件对应的原始覆盖率标记文件中的覆盖项,从而实现了对原始覆盖率标记文件的更新,使得到的目标覆盖率标记文件能够映射到新程序文件;上述方法相比较现有技术的手动更新,大幅减少了设计或验证人员的重复操作,从一处代码的修改就可能影响所有覆盖率文件的重新标记,变为任意修改代码但可以自动识别旧标记并将其更新到新代码的映射中,在既定人力规模下,提升了代码覆盖率迭代频率和迭代效率,从而间接提升了芯片的功能鲁棒性。
附图说明
41.图1为本技术一个示例性实施例提供的一种覆盖率标记文件更新方法的流程图。
42.图2为本技术一个示例性实施例提供的原始程序文件覆盖项的示意图。
43.图3为本技术又一个示例性实施例提供的一种覆盖率标记文件更新方法的流程图。
44.图4为本技术一个示例性实施例提供的一种覆盖率标记文件更新装置的结构图。
具体实施方式
45.下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本技术一部分实施例,而不是全部的实施例。基于本技术中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本技术保护的范围。
46.请参见图1,本技术实施例提供了一种覆盖率标记文件更新方法,该方法包括:
47.步骤s1,获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项。
48.步骤s2,根据新程序文件对覆盖项进行更新。
49.步骤s3,对原始覆盖率标记文件重复执行步骤s1-s2,直至遍历完原始覆盖率标记文件中的所有覆盖项,得到新程序文件对应的目标覆盖率标记文件。
50.其中,原始程序文件即旧的程序文件,新程序文件即对原始程序文件修改后的程序文件。
51.上述实施例提供的一种覆盖率标记文件更新方法,根据新程序文件,逐项更新原始程序文件对应的原始覆盖率标记文件中的覆盖项,从而实现了对原始覆盖率标记文件的更新,使得到的目标覆盖率标记文件能够映射到新程序文件;上述方法相比较现有技术的手动更新,大幅减少了设计或验证人员的重复操作,从一处代码的修改就可能影响所有覆盖率文件的重新标记,变为任意修改代码但可以自动识别旧标记并将其更新到新代码的映
射中,在既定人力规模下,提升了代码覆盖率迭代频率和迭代效率,从而间接提升了芯片的功能鲁棒性。
52.请参见图2,在一些实施例中,覆盖项具体可以包括标记项字典序号、标记项序号、逻辑表达式、文件行号和文件序号。
53.具体地,以cadence的imc/vmanager工具为例:
54.vmanager的标记文件vrefine的覆盖项列表中除了时间等辅助信息外,主要会存储标记项字典序号(comment),标记项序号(entityname),文件序号(file),文件行号(line)和逻辑表达式(text)。标记项字典中会存储字典序号(comment)和对应的标记内容(value)。
55.上述实施例中覆盖项所包括的标记信息,能够帮助设计或验证人员根据这些标记信息对芯片的代码覆盖率进行快速、高效的分析。
56.在一些实施例中,上述根据新程序文件对覆盖项进行更新,包括:
57.将覆盖项的逻辑表达式和文件行号与新程序文件进行对比,得到对比结果。
58.根据对比结果对覆盖项进行更新。
59.具体地,由于收集代码覆盖率、存储标记文件的时间段往往在设计结构较为稳定,是设计文件不会出现大规模改动的时期,此时设计人员更新代码时,往往是对部分代码进行修改,而其余大部分代码是维持不变的。因此本技术中新程序文件相对于原始程序文件的改动中,会对代码覆盖标记造成影响的类型作如下分类:
60.1.增加,体现在代码覆盖项列表有增加,且增加的项目为之前没有出现过的变量。
61.2.分离,体现在代码覆盖项的某个子逻辑分支变化。
62.3.合并,体现在代码覆盖项的某项与其他项合并。
63.4.删除,体现在代码覆盖项的某项被移除。
64.而将覆盖项的逻辑表达式和文件行号与新程序文件进行对比,就是看源程序文件中的代码是否出现了上述的4种修改操作,并根据其发生的修改类型对覆盖项进行更新。
65.上述实施例通过覆盖项的逻辑表达式和文件行号与新程序文件进行对比,能够快速准确地判断出该覆盖项对应的代码是否出现修改、该覆盖项是否需要更新。
66.在一些实施例中,上述根据对比结果对覆盖项进行更新,包括:
67.若新程序文件中不存在覆盖项的逻辑表达式,则删除覆盖项。
68.具体地,若对比结果显示新程序文件中不存在该覆盖项的逻辑表达式,说明在新程序文件中,该覆盖项对应的代码发生了删除操作。
69.上述实施例实现了当原始程序文档中代码出现删除操作时,覆盖项在新程序文件中的映射。
70.请参见图3,在一些实施例中,上述根据对比结果对覆盖项进行更新,包括:
71.根据对比结果判断覆盖项的逻辑表达式或文件行号在新程序文件中是否发生了变化。
72.若是,则综合逻辑表达式,得到综合逻辑关系,并基于综合逻辑关系和新程序文件的综合数据库对覆盖项进行更新;若否,则保留覆盖项。
73.其中,综合过程即对逻辑表达式的布尔运算、数学运算关系进行记录,如果是触发器、锁存器等会额外记录触发来源,新程序文件的综合数据库包含该模块内所有组合逻辑、
时序逻辑(触发器、锁存器)单元的结构及互相之间的连接关系的数据库。
74.这里也可以用网表的概念来替代综合数据库。
75.具体地,如果出现覆盖项需要更新的情况,会对单个逻辑表达式本身进行综合(这也包括了仅修改空格,换行等,这类修改在上述流程中同样会发生异常,但是需要用户手动逐个确认),同时对新程序文件进行综合,得到综合数据库,然后更新当前的覆盖项。
76.由于可综合文件不会存在multidrive的现象,因此对于逻辑表达式左值变量的定位是唯一确定的(无论是时序逻辑还是组合逻辑)。
77.上述实施例利用了左值变量的定位是唯一确定的性质,基于综合逻辑关系和综合数据库对覆盖项进行更新,从而保证该逻辑表达式对应的覆盖项更新的准确性。
78.请参见图3,在一些实施例中,上述基于综合逻辑关系和新程序文件的综合数据库对覆盖项进行更新,具体可以包括:
79.判断综合逻辑关系在综合数据库中是否有匹配。
80.若是,则根据对比结果获取逻辑表达式在新程序文件中的目标文件行号,将覆盖项中的文件行号更新为目标文件行号;若否,则判断逻辑表达式的左值在综合数据库中是否存在。
81.若存在,则根据对比结果获取新程序文件中左值对应的目标表达式,将覆盖项中的逻辑表达式更新为目标表达式;否则删除覆盖项。
82.具体地,综合数据库中不包含模块内组合逻辑和时序逻辑在硬件描述文件中的位置,与程序文件本身相关的信息都是记录在覆盖率标记文件中的。目标文件行号即是逐行读取新程序文件时,看到一个变量表达式即可获得当前它的目标文件行号。
83.图3中的“创建新的覆盖项”是指将原始覆盖率标记文件中的覆盖项记录的逻辑表达式信息,更新为新的目标表达式。
84.在具体实施过程中,对于未进行修改的其他覆盖项,仍然可以通过综合数据库的比较,找到其在新程序文件中的对应逻辑表达式及所在目标文件行号,实现自动更新关联。
85.对于分离或合并的代码修改,会体现在某些覆盖项的逻辑右值发生变化,此时由于当前覆盖项的逻辑表达式的左值变量仍然存在,仍然可以通过比较新程序文件的综合数据库,定位到当前覆盖项在新程序文件中的目标文件行号及新的文件序号。
86.上述实施例通过对综合数据库中综合逻辑关系的匹配和左值的检测,实现了对发生增加、分离和合并修改操作的代码的覆盖项的快速更新,避免了人为手动操作导致的效率低下。
87.在一些实施例中,该方法还可以包括:
88.在遍历完原始覆盖率标记文件中的所有覆盖项后,根据目标文件行号对各覆盖项进行排序,得到目标覆盖率标记文件。
89.具体地,在比较和更新的过程中,可能会出现覆盖项逻辑表达式的左值在新程序文件中的行号位置发生了变化,因此需要根据更新的目标文件行号对处理完的所有覆盖项重新进行排序。
90.上述实施例解决了当逻辑表达式的左值在新程序文件中的行号位置发生变化时导致更新后的所有覆盖项排序错误的问题,保证了目标覆盖率标记文件的准确性。
91.在一些实施例中,该方法还可以包括:
92.在删除覆盖项后,生成覆盖项对应的删除警告信息。具体地,对于已删除的覆盖项或无法找到的左值,会通过发出删除警告信息提醒用户已自动删除该项目。
93.上述实施例避免了本技术的删除覆盖项的操作有误的情况,通过在删除后发送删除警告信息提醒用户,使用户确认删掉的覆盖项是否正确,保证了目标覆盖率标记文件的准确性。
94.在一些实施例中,该方法还可以包括:
95.在将覆盖项中的文件行号更新为目标文件行号后,或者将覆盖项中的逻辑表达式更新为目标表达式后,生成该覆盖项对应的标记警告信息。具体地,在对覆盖项进行更新后,通过发送标记警告信息,来提醒用户此处发生逻辑变化,需要用户重新确认。
96.上述实施例通过提醒用户覆盖项更新的位置,方便用户确认本技术更新的覆盖项是否正确,从而保证了目标覆盖率标记文件的准确性。
97.请参见图4,本技术另一实施例提供了一种覆盖率标记文件更新装置,该装置包括:
98.覆盖项获取模块101,用于获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项。
99.更新模块102,用于根据新程序文件对覆盖项进行更新。
100.遍历模块103,用于对原始覆盖率标记文件重复执行覆盖项获取模块和更新模块,直至遍历完原始覆盖率标记文件中的所有覆盖项,得到新程序文件对应的目标覆盖率标记文件。
101.上述实施例提供的一种覆盖率标记文件更新装置,根据新程序文件,逐项更新原始程序文件对应的原始覆盖率标记文件中的覆盖项,从而实现了对原始覆盖率标记文件的更新,使得到的目标覆盖率标记文件能够映射到新程序文件;上述装置相比较现有技术的手动更新,大幅减少了设计或验证人员的重复操作,从一处代码的修改就可能影响所有覆盖率文件的重新标记,变为任意修改代码但可以自动识别旧标记并将其更新到新代码的映射中,在既定人力规模下,提升了代码覆盖率迭代频率和迭代效率,从而间接提升了芯片的功能鲁棒性。
102.本实施例中提供的关于一种覆盖率标记文件装置的具体限定,可以参见上文中关于一种覆盖率标记文件更新方法的实施例,于此不再赘述。上述一种覆盖率标记文件更新装置中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
103.请参见图3,以一个具体的例子说明本技术的一种覆盖率标记文件更新方法的实现过程:
104.由于收集代码覆盖率,存储标记文件的时间段往往在设计结构较为稳定,设计文件不会出现大规模改动的时期,此时设计人员更新代码时,往往是对部分代码进行修改,而其余大部分代码是维持不变的。因此对设计文件的改动中,会对代码覆盖标记造成影响的类型作如下分类:
105.1.增加,体现在代码覆盖项列表有增加,且增加的项目为之前没有出现过的变量。
106.2.分离,体现在代码覆盖项的某个子逻辑分支变化。
107.3.合并,体现在代码覆盖项的某项与其他项合并。
108.4.删除,体现在代码覆盖项的某项被移除。
109.在新程序文件中应用原始覆盖率标记文件时,对于发生上述代码修改后影响的其它标记项部分,本技术用以下方法进行自动更新关联。
110.在标记文件中存储标记信息时,会存储该逻辑在当前覆盖率中的序号、在对应文件中的行号、当前的逻辑表达式、以及对应的标记注释或标记操作,具体请参见图2。
111.对于增加或删除的代码修改,会体现在后续覆盖项的序号变化,这也是其它工具无法自动映射的原因。在本技术映射过程中,如果出现覆盖项更新,会对单个逻辑表达式本身进行综合(这也包括了仅修改空格,换行等,这类修改在上述vmanager流程中同样会发生异常,但是需要用户手动逐个确认),同时对新程序文件进行综合,然后重新定位当前覆盖项所在的行号。
112.由于可综合文件不会存在multidrive的现象,因此对于逻辑表达式左值变量的定位是唯一确定的(无论是时序逻辑还是组合逻辑)。对于未进行修改的其他覆盖项,仍然可以通过综合数据库的比较,找到其在新程序文件中的对应逻辑表达式及所在行号,实现自动更新关联。对于已删除的标记项或无法找到的左值,会通过删除警告信息提醒用户已自动删除该项目。
113.对于分离或合并的代码修改,会体现在某些覆盖项的逻辑右值发生变化,此时由于当前逻辑表达式的左值变量仍然存在,仍然可以通过比较新程序文件的综合数据库,定位到当前覆盖项所在的文件行号及新的覆盖项序号,并通过生成标记警告信息,来提醒用户此处发生逻辑变化,需要用户重新确认。本技术的流程如下:
114.1.从原始覆盖率标记文件中获得一个覆盖项。
115.2.判断覆盖项的逻辑表达式或文件行号是否发生变化,如果发生变化,则对逻辑表达式进行综合,并与新程序文件综合数据库进行比较。
116.3.如果有匹配,则更新新行号。如果没有匹配且左值不存在,则删除该覆盖项。如果没有匹配但是左值在综合数据库中存在,则创建为新的覆盖项(本技术不考虑用户主动新增的覆盖项,仅考虑更新之前已创建的覆盖项)。
117.4.如果覆盖项的逻辑表达式和文件行号都没有发生变化,则表明覆盖向内容保持不变,可以略去后续综合及匹配的流程。
118.5.处理完所有覆盖项后,整理所有覆盖项,根据其在文件中出现的先后进行排序,最终生成新的覆盖率标记文件。
119.本技术实施例提供了一种计算机设备,该计算机设备可以包括通过系统总线连接的处理器、存储器、网络接口和数据库。其中,该计算机设备的处理器用于提供计算和控制能力。该计算机设备的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作系统、计算机程序和数据库。该内存储器为非易失性存储介质中的操作系统和计算机程序的运行提供环境。该计算机设备的网络接口用于与外部的终端通过网络连接通信。处计算机程序被处理器执行时,使得处理器执行如上述任一实施例的一种覆盖率标记文件更新方法的步骤。
120.本实施例提供的计算机设备的工作过程、工作细节和技术效果,可以参见上文中关于一种覆盖率标记文件更新方法的实施例,于此不再赘述。
121.本技术实施例提供了一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现如上述任一实施例的一种覆盖率标记文件更新方法的步骤。其中,所述计算机可读存储介质是指存储数据的载体,可以但不限于包括软盘、光盘、硬盘、闪存、优盘和/或记忆棒(memory stick)等,所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。本实施例提供的计算机可读存储介质的工作过程、工作细节和技术效果,可以参见上文中关于一种覆盖率标记文件更新方法的实施例,于此不再赘述。
122.本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本技术所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(rom)、可编程rom(prom)、电可编程rom(eprom)、电可擦除可编程rom(eeprom)或闪存。易失性存储器可包括随机存取存储器(ram)或者外部高速缓冲存储器。作为说明而非局限,ram以多种形式可得,诸如静态ram(sram)、动态ram(dram)、同步dram(sdram)、双数据率sdram(ddrsdram)、增强型sdram(esdram)、同步链路(synchlink)dram(sldram)、存储器总线(rambus)直接ram(rdram)、直接存储器总线动态ram(drdram)、以及存储器总线动态ram(rdram)。
123.以上实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
124.以上所述实施例仅表达了本技术的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本技术构思的前提下,还可以做出若干变形和改进,这些都属于本技术的保护范围。因此,本技术专利的保护范围应以所附权利要求为准。

技术特征:
1.一种覆盖率标记文件更新方法,其特征在于,所述方法包括:步骤s1,获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项;步骤s2,根据新程序文件对所述覆盖项进行更新;步骤s3,对所述原始覆盖率标记文件重复执行步骤s1-s2,直至遍历完所述原始覆盖率标记文件中的所有所述覆盖项,得到所述新程序文件对应的目标覆盖率标记文件。2.根据权利要求1所述的方法,其特征在于,所述覆盖项包括标记项字典序号、标记项序号、逻辑表达式、文件行号和文件序号。3.根据权利要求2所述的方法,其特征在于,所述根据新程序文件对所述覆盖项进行更新,包括:将所述覆盖项的所述逻辑表达式和所述文件行号与所述新程序文件进行对比,得到对比结果;根据所述对比结果对所述覆盖项进行更新。4.根据权利要求3所述的方法,其特征在于,所述根据所述对比结果对所述覆盖项进行更新,包括:若所述新程序文件中不存在所述覆盖项的所述逻辑表达式,则删除所述覆盖项。5.根据权利要求4所述的方法,其特征在于,所述根据所述对比结果对所述覆盖项进行更新,包括:根据所述对比结果判断所述覆盖项的所述逻辑表达式或所述文件行号在所述新程序文件中是否发生了变化;若是,则综合所述逻辑表达式,得到综合逻辑关系,并基于所述综合逻辑关系和所述新程序文件的综合数据库对所述覆盖项进行更新;若否,则保留所述覆盖项。6.根据权利要求5所述的方法,其特征在于,所述基于所述综合逻辑关系和所述新程序文件的综合数据库对所述覆盖项进行更新,包括:判断所述综合逻辑关系在所述综合数据库中是否有匹配;若是,则根据所述对比结果获取所述逻辑表达式在所述新程序文件中的目标文件行号,将所述覆盖项中的所述文件行号更新为所述目标文件行号;若否,则判断所述逻辑表达式的左值在所述综合数据库中是否存在;若存在,则根据所述对比结果获取所述新程序文件中所述左值对应的目标表达式,将所述覆盖项中的所述逻辑表达式更新为所述目标表达式;否则删除所述覆盖项。7.根据权利要求6所述的方法,其特征在于,所述方法还包括:在遍历完所述原始覆盖率标记文件中的所有所述覆盖项后,基于所述目标文件行号对各所述覆盖项进行排序,得到所述目标覆盖率标记文件。8.根据权利要求6所述的方法,其特征在于,所述方法还包括:在删除所述覆盖项后,生成所述覆盖项对应的删除警告信息。9.根据权利要求5所述的方法,其特征在于,所述方法还包括:在将所述覆盖项中的所述文件行号更新为所述目标文件行号后,或者将所述覆盖项中的所述逻辑表达式更新为所述目标表达式后,生成所述覆盖项对应的标记警告信息。10.一种覆盖率标记文件更新装置,其特征在于,所述装置包括:覆盖项获取模块,用于获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项;更新模块,用于根据新程序文件对所述覆盖项进行更新;
遍历模块,用于对所述原始覆盖率标记文件重复执行所述覆盖项获取模块和所述更新模块,直至遍历完所述原始覆盖率标记文件中的所有所述覆盖项,得到所述新程序文件对应的目标覆盖率标记文件。11.一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至9中任一项所述方法的步骤。12.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至9中任一项所述方法的步骤。

技术总结
本申请属于软件测试技术领域,公开了一种覆盖率标记文件更新方法、装置、设备及存储介质,该方法包括:步骤S1,获取原始程序文件对应的原始覆盖率标记文件中的一个覆盖项;步骤S2,根据新程序文件对覆盖项进行更新;步骤S3,对原始覆盖率标记文件重复执行步骤S1-S2,直至遍历完原始覆盖率标记文件中的所有覆盖项,得到新程序文件对应的目标覆盖率标记文件。本申请可以达到减少设计或验证人员的重复操作、提升代码覆盖率迭代频率和迭代效率,从而间接提升芯片的功能鲁棒性的效果。提升芯片的功能鲁棒性的效果。提升芯片的功能鲁棒性的效果。


技术研发人员:陆泳 施葹 苟鹏飞 刘扬帆 徐越 王贺
受保护的技术使用者:北京市合芯数字科技有限公司
技术研发日:2023.05.10
技术公布日:2023/9/7
版权声明

本文仅代表作者观点,不代表航空之家立场。
本文系作者授权航家号发表,未经原创作者书面授权,任何单位或个人不得引用、复制、转载、摘编、链接或以其他任何方式复制发表。任何单位或个人在获得书面授权使用航空之家内容时,须注明作者及来源 “航空之家”。如非法使用航空之家的部分或全部内容的,航空之家将依法追究其法律责任。(航空之家官方QQ:2926969996)

飞行汽车 https://www.autovtol.com/

分享:

扫一扫在手机阅读、分享本文

相关推荐