news 2026/4/18 6:57:29

计算机系统要素:测试文件解读

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
计算机系统要素:测试文件解读
// 加载16位与门的硬件描述文件 load And16.hdl, // 指定测试输出文件 output-file And16.out, // 指定对比的标准答案文件 compare-to And16.cmp, // 定义输出格式:a(二进制16位)、b(二进制16位)、out(二进制16位) output-list a%B1.16.1 b%B1.16.1 out%B1.16.1; // 测试用例1:全0 & 全0 → 全0 set a %B0000000000000000, set b %B0000000000000000, eval, // 执行运算 output; // 输出结果 // 测试用例2:全0 & 全1 → 全0 set a %B0000000000000000, set b %B1111111111111111, eval, output; // 测试用例3:全1 & 全1 → 全1 set a %B1111111111111111, set b %B1111111111111111, eval, output; // 测试用例4:交替位 & 反交替位 → 全0 set a %B1010101010101010, set b %B0101010101010101, eval, output; // 测试用例5:部分重叠位 & 部分重叠位 → 重叠位保留 set a %B0011110011000011, set b %B0000111111110000, eval, output; // 测试用例6:随机位组合 → 逐位与运算 set a %B0001001000110100, set b %B1001100001110110, eval, output;

关键知识点解析:

一、指令作用

  • load:加载待测试的硬件描述文件(And16.hdl);
  • output-file:指定测试结果输出文件;
  • compare-to:指定标准答案文件,用于自动比对测试结果;
  • output-list:定义输出格式(二进制 16 位,显示 a、b、out);
  • set:设置输入信号 a/b 的值;
  • eval:执行硬件逻辑运算;
  • output:输出运算结果。

二、a%B1.16.1语法完全解析

在 Hack 硬件测试脚本(.tst)的output-list指令中,a%B1.16.1输出格式控制符,用于定义信号a的显示规则,拆解如下:

组成部分含义
a待显示的信号名(此处指 16 位输入信号 a,可替换为 b/out 等其他信号);
%格式符分隔符,标识后续为格式定义;
B数值显示进制:B= 二进制(Binary),其他可选值:D= 十进制、H= 十六进制;
1「位数对齐规则」:1表示高位在前(大端显示),若为0则低位在前;
.16「固定显示位数」:强制显示 16 位,不足补 0(核心!保证 16 位信号完整显示);
.1「分组间隔」:1表示无分组(连续显示),若为4则每 4 位分隔(如1111_0000);

核心作用

a%B1.16.1最终效果:将 16 位信号 a 以「高位在前、无分组、补 0 至 16 位」的二进制形式完整显示

举例说明

假设信号a的实际值是二进制1010(仅 4 位),不同格式符的显示效果对比:

格式符显示结果说明
a%B1.16.10000000000001010补 0 至 16 位,高位在前
a%B0.16.11010000000000000补 0 至 16 位,低位在前
a%B1.8.100001010补 0 至 8 位,高位在前
a%B1.16.40000_0000_0000_101016 位、每 4 位分组显示
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 18:08:12

APA与TOGAF、VE和RVP

作者简介: 李海峰:安托公司首席业务方案架构师,清华大学精密仪器系博士,在PLM领域深耕20年。 俞戍远:安托公司CTO,副总经理,有丰富的复杂产品研制数字化转型和复杂解决方案架构设计经验。 摘要…

作者头像 李华
网站建设 2026/4/16 22:35:11

[HNCTF 2022 Week1]ret2shellcode

第一次打CTF——PWN篇学习笔记17int __fastcall main(int argc, const char **argv, const char **envp) {char s[256]; // [rsp0h] [rbp-100h] BYREF ​setbuf(stdin, 0);setbuf(stderr, 0);setbuf(stdout, 0);mprotect((void *)((unsigned __int64)&stdout & 0xFFFFF…

作者头像 李华
网站建设 2026/4/18 4:21:41

RK3568芯片复位电路避坑指南:上下电时序引发的外设异常探秘

RK3568 芯片简介与应用场景 RK3568 是瑞芯微推出的一款面向智能终端、工业控制、边缘计算、网络通信等领域的中高端通用型处理器芯片 ,采用 22nm 制程工艺,具备出色的性能与丰富的功能。其四核 ARM Cortex-A55 处理器,主频最高可达 2.0GHz,搭配 ARM Mali-G52 2EE GPU,为设…

作者头像 李华
网站建设 2026/4/16 11:48:10

RK3588+Linux+QT+AI推理实战:解锁AI摄像头完整方案

引言 在人工智能与物联网飞速发展的当下,AI 摄像头作为智能感知的前沿设备,正广泛应用于安防监控、工业检测、智能交通等众多领域。将 RK3588、Linux、QT 和 AI 推理融合,为打造高性能、智能化且具备友好交互界面的 AI 摄像头系统提供了卓越方案。RK3588 凭借其强大的算力,…

作者头像 李华
网站建设 2026/4/11 21:21:06

《Effective Java》第25条:限制源文件为单个顶级类

说明: 关于本博客使用的书籍,源代码Gitee仓库 和 其他的相关问题,请查看本专栏置顶文章:《Effective Java》第0条:写在前面,用一年时间来深度解读《Effective Java》这本书 正文: Java允许我…

作者头像 李华