学的内容多了,好多指令和用法都容易遗忘和混淆,出现这种情况就需要勤记笔记,忘记了多翻阅几次,基本上就能完全记住了。

[`timescale 1ns/1ps]前一个1ns表示时延时间,后一个1ps表示时延精度。

写的一个Testbench示例

`timescale  ps/  ps
module SendTest_vlg_tst();
// constants
// general purpose registers
reg eachvec;
// test vector input registers
reg [:] RcvWrAddr;
reg [:] RcvWrData;
reg RcvWrEn;
reg Test;
reg clk;
reg rst;
// wires
wire ARPBit;
wire [:] AppData;
wire AppDataFlag;
wire [:] ClientCMD;
wire ICMPBit;
wire [:] RCAckNum;
wire [:] RCWinSize;
wire RcvDone;
wire [:] ReSend;
wire [:] SSeqNum;
wire SendBusy;
wire [:] SendLength;
wire SendRdClk;
wire SendStart;
wire TCPBit;
wire [:] TCPCount;
wire [:] TCPState;
wire [:] TEncoderState;
wire [:] TRAMDATAIN;
wire [:] TRAMDATAOUT;
wire [:] TRcvDecoderStatus;
wire [:] TTestStatus1;
wire UDPBit;
wire [:] Value; // assign statements (if any)
SendTest i1 (
// port map - connection between master ports and signals/registers
.ARPBit(ARPBit),
.AppData(AppData),
.AppDataFlag(AppDataFlag),
.ClientCMD(ClientCMD),
.ICMPBit(ICMPBit),
.RCAckNum(RCAckNum),
.RCWinSize(RCWinSize),
.RcvDone(RcvDone),
.RcvWrAddr(RcvWrAddr),
.RcvWrData(RcvWrData),
.RcvWrEn(RcvWrEn),
.ReSend(ReSend),
.SSeqNum(SSeqNum),
.SendBusy(SendBusy),
.SendLength(SendLength),
.SendRdClk(SendRdClk),
.SendStart(SendStart),
.TCPBit(TCPBit),
.TCPCount(TCPCount),
.TCPState(TCPState),
.TEncoderState(TEncoderState),
.TRAMDATAIN(TRAMDATAIN),
.TRAMDATAOUT(TRAMDATAOUT),
.TRcvDecoderStatus(TRcvDecoderStatus),
.TTestStatus1(TTestStatus1),
.Test(Test),
.UDPBit(UDPBit),
.Value(Value),
.clk(clk),
.rst(rst)
);
parameter CLKTIME=;
parameter RSTTIME=;
initial clk=;
initial forever #(CLKTIME/) clk=~clk;
initial rst=;
initial #RSTTIME rst=; reg [:] CTCPFLAG;
reg [:] CSeqNum;
reg [:] CAckNum;
reg [:] CWinSize;
parameter ACK='b010000;
parameter SYN='b000010;
parameter FIN='b000001;
parameter PUSH='b001000; task SendTCP;
begin
@(negedge clk);//以太网目标MAC地址
RcvWrEn<='b1;
RcvWrAddr<='d0;
RcvWrData<='h00E0;
@(negedge clk); //
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3DF4;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hDDF7;
@(negedge clk); //以太网源MAC地址
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hF0DE;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hF1B5;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h5EF8;
@(negedge clk);//帧类型IP:0X0800
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0800;
@(negedge clk); //IP帧头
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4500;
@(negedge clk); //total length
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h40;
@(negedge clk); //Identification
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4006;
@(negedge clk); //check
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk); //以太网源IP
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3b45;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h40a9;
@(negedge clk); //以太网目的IP
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3b45;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4002;
@(negedge clk); //TCP帧头
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h001E;//src port 30
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h001e;//dest port
@(negedge clk); //seq
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CSeqNum[:];
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CSeqNum[:];
@(negedge clk); //ack
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CAckNum[:];
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CAckNum[:];
@(negedge clk); //
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<={'d5,6'd0,CTCPFLAG};
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CWinSize;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='d0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='d0;
@(negedge clk);
RcvWrEn<='b0;
RcvWrAddr<='d0;
RcvWrData<='d0;
@(negedge RcvDone);
end
endtask task SendT;
begin
//客户机发送'T'//////////////////////////////////////////////////////////////////
@(negedge clk);//以太网目标MAC地址
RcvWrEn<='b1;
RcvWrAddr<='d0;
RcvWrData<='h00E0;
@(negedge clk); //
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3DF4;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hDDF7;
@(negedge clk); //以太网源MAC地址
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hF0DE;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='hF1B5;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h5EF8;
@(negedge clk);//帧类型IP:0X0800
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0800;
@(negedge clk); //IP帧头
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4500;
@(negedge clk); //total length
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h29;//16'd41
@(negedge clk); //Identification
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4006;
@(negedge clk); //check
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h0;
@(negedge clk); //以太网源IP
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3b45;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h40a9;
@(negedge clk); //以太网目的IP
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h3b45;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h4002;
@(negedge clk); //TCP帧头
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h001E;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h001E;
@(negedge clk); //seq
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CSeqNum[:];
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CSeqNum[:];
@(negedge clk); //ack
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CAckNum[:];
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CAckNum[:];
@(negedge clk); //
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<={'d5,6'd0,CTCPFLAG};
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<=CWinSize;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='d0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='d0;
@(negedge clk);
RcvWrAddr<=RcvWrAddr+'b1;
RcvWrData<='h5400;//'T'
@(negedge clk);
RcvWrEn<='b0;
RcvWrAddr<='d0;
RcvWrData<='d0;
@(negedge RcvDone);
end
endtask initial
begin
RcvWrEn<='b0;
RcvWrAddr<='d0;
RcvWrData<='d0;
//写SYN请求//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d0;
CAckNum<='d0;
CTCPFLAG<=SYN;
CWinSize<='d65535;
SendTCP();
wait(SendBusy==);
wait(SendBusy==);
//回应SYN+ACK//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK1//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK2//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK3//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK4//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK5//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
//发送ACK6//////////////////////////////////////////////////////////////////
repeat()@(negedge clk);
CSeqNum<='d1;
CAckNum<='d1;
CTCPFLAG<=ACK;
CWinSize<='d65535;
SendTCP();
end endmodule

Test Bench基础知识笔记的更多相关文章

  1. JS基础知识笔记

    2020-04-15 JS基础知识笔记 // new Boolean()传入的值与if判断一样 var test=new Boolean(); console.log(test); // false ...

  2. Java多线程基础知识笔记(持续更新)

    多线程基础知识笔记 一.线程 1.基本概念 程序(program):是为完成特定任务.用某种语言编写的一组指令的集合.即指一段静态的代码,静态对象. 进程(process):是程序的一次执行过程,或是 ...

  3. javascript基础知识笔记-自用

    笔记内容根据个人基础知识不足不明白之处做的记录.主要看的:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript 1.变量,变量的名字又叫标识符 ...

  4. Mysql之基础知识笔记

    Mysql数据库基础知识个人笔记 连接本地数据库: mysql -h localhost -u root -p 回车输入数据库密码 数据库的基础操作: 查看当前所有的数据库:show database ...

  5. java基础知识-笔记整理

    1.查看已安装jdk文件路径 CMD输入java -verbose.   2.java学习提升路线 java学习视屏地址: http://www.icoolxue.com/album/show/38 ...

  6. JavaScript基础知识笔记

    做前端几年了,一直疏于整理归纳,所以这两天把基础看了一遍,加上使用经验,整理了基础知识中关键技术,旨在系统性的学习和备忘.如果发现错误,请留言提示,谢谢! 重要说明:本文只列举基础知识点,中级和高级内 ...

  7. Javascript 基础知识笔记

    标签(空格分隔): 廖老师学习笔记 javascript 基本入门 根据廖雪峰老师官网,自己看后的简单笔记 第一小节 基本知识 <script type="text/javascrip ...

  8. 初学MySQL基础知识笔记--01

    本人初入博客园,第一次写博客,在今后的时间里会一点点的提高自己博客的水平,以及博客的排版等. 在今天,我学习了一下MySQL数据库的基本知识,相信关于MySQL的资料网上会有很多,所以我就不在这里复制 ...

  9. mysql基础知识笔记

    Mysql基础笔记 环境配置 基本概念 mysql命令行 进入 use show 查询 select order by where like 数据过滤regexp concat 文本函数 日期函数 数 ...

随机推荐

  1. GRUB引导——menu.lst的写法

    转自menu.lst的写法.menu.lst的写法 1.menu.lst的写法之一 首先我们看一下我的Fedora 4.0 中的/boot/grub/menu.lst 的内容: default=0  ...

  2. 【网络流24题】No.1 搭配飞行员(飞行员配对方案问题)

    [问题描述]     飞行大队有若干个来自各地的驾驶员,专门驾驶一种型号的飞机,这种飞机每架有两个驾驶员,需一个正驾驶员和一个副驾驶员.由于种种原因,例如相互配合的问题,有些驾驶员不能在同一架飞机上飞 ...

  3. OA学习笔记-005-Spring2.5与struts2.1整合

    一.单独测试strust 1.action package cn.itcast.oa.test; import org.springframework.context.annotation.Scope ...

  4. 如何在win下编译thunderbird

    最近突然想研究一下thunderbird的实现,于是在WIN2K3下对其进行了系列的编译,特将编译的一些心得与大家共享.其实编译过程已经非常简单了,本文以VC8 ( VISUAL STUDIO 200 ...

  5. JAVA 内存泄漏与内存溢出

    一.Java内存回收机制 不论哪种语言的内存分配方式,都需要返回所分配内存的真实地址,也就是返回一个指针到内存块的首地址.Java中对象是采用new或者反射或者clone或者反序列化的方法创建的, 这 ...

  6. USACO3.32Shopping Offers(DP)

    五维DP,听着挺多的,貌似就是挺裸的dp, 最近貌似做简单的DP挺顺手..1A dp[i][j][e][o][g] = min(dp[i][j][e][o][g],dp[i-i1][j-i2][e-i ...

  7. BZOJ_1497_[NOI2006]_最大获利_(最大流+最大权闭合图)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1497 共n个站点,给出建立每个站点所需要的花费.现在有m个客户需要开通服务,每个客户需要有两个 ...

  8. Beta Round #9 (酱油杯noi考后欢乐赛)乌鸦喝水

    题目:http://www.contesthunter.org/contest/Beta%20Round%20%EF%BC%839%20%28%E9%85%B1%E6%B2%B9%E6%9D%AFno ...

  9. Node.js权威指南 (12) - Node.js中的其他模块

    12.1 使用dns模块解析域名 / 313 12.1.1 使用resolve方法将域名解析为DNS记录 / 313 12.1.2 使用lookup方法查询IP地址 / 315 12.1.3 使用re ...

  10. qt容器在并发时需要注意的地方

    最近用tbb和qt写了一个延时摄影后期控制镜头的工具,主要就是扫描目录下所有图片,按照给定参数截取图片中某区域并另存,模拟镜头摆动. 扫描后的图片路径保存在qlist内,作为只读数据,交由tbb的pa ...