第一范文网 - 专业文章范例文档资料分享平台

北邮电子院专业实验报告

来源:用户分享 时间:2025/5/15 18:04:37 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

LAB 5:存储器电路的设计

一、 二、

实验目的 实验原理

设计和测试存储器电路。

本实验中,设计一个模块名为mem的存储器仿真模型,该存储器具有双线数据总线及异步处理功能。由于数据是双向的,所以要注意,对memory的读写在时序上要错开。

三、 源代码

自行添加的代码

assign data= (read)?memory[addr]:8'hZ;

always @(posedge write) begin

memory[addr]<=data[7:0]; end

四、 仿真结果与波形

LAB 6:设计时序逻辑时采用阻塞赋值与非阻塞赋值的区别

一、

实验目的

明确掌握阻塞赋值与非阻塞赋值的概念和区别; 了解阻塞赋值的使用情况。

二、 实验原理

在always块中,阻塞赋值可以理解为赋值语句是顺序执行的,而非阻塞赋值可以理解为并发执行的。实际时序逻辑设计中,一般情况下非阻塞赋值语句被更多的使用,有时为了在同一周期实现相互关联的操作,也使用阻塞赋值语句。

三、 源代码

blocking.v

`timescale 1 ns/ 100 ps

module blocking(clk,a,b,c); output[3:0]b,c; input [3:0]a; input clk; reg [3:0]b,c;

always@(posedge clk) begin b =a; c =b;

$display(\ end endmodule

non_blocking.v

`timescale 1 ns/ 100 ps

module non_blocking(clk,a,b,c);

output[3:0] b,c; input[3:0] a; input clk; reg [3:0]b,c;

always @(posedge clk) begin b<=a; c<=b;

$display(\ end

endmodule

compareTop.v

`timescale 1 ns/ 100 ps

module compareTop; wire [3:0] b1,c1,b2,c2; reg[3:0]a; reg clk; initial begin clk=0;

forever #50 clk=~clk; end initial

$dumpvars (2,compareTop); initial begin a=4'h3;

$display(\# 100 a =4'h7;

$display(\# 100 a =4'hf;

$display(\# 100 a =4'ha;

$display(\# 100 a =4'h2;

$display(\

# 100 $display(\$finish; end

non_blocking nonblocking(clk,a,b2,c2); blocking blocking(clk,a,b1,c1); endmodule

四、 仿真结果与波形

搜索更多关于: 北邮电子院专业实验报告 的文档
北邮电子院专业实验报告.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c9gb7m3vkzb79c974hv1j_4.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top