HNU-2023电路与电子学-CPU综合设计

news2025/1/16 22:02:36

写在前面:

本次实验是课程的最后一次实验,要求按照指导书的说明将之前的板块整合成一个完整的CPU,建议大家每连接一个板块都进行一次仿真验证,保证能正常运行且功能正常,如果等到CPU组装好再调试工作量较大并且有些错误难以发现。

关于验收:

当CPU综合设计完成后,课程组的老师会统一安排助教进行验收,时间通常在结课前一两周(距离考试周很近,时间会比较赶),以2022级为例,验收过程首先助教会先询问你是否将程序下载到单片机上(建议所有同学都下板,验收分数会高一个level,而且操作不复杂),完成程序的演示后,助教会挑选CPU中的部分组件来询问你相应的设计原理(所以需要在验收前需要好好复习每个模块的相应内容,保证原理都能理解并且讲清楚),最后就是抽题,可以选择抽难题和简单题,并且难题如果答不上来还有一次换简单题的机会,我感觉难题方差挺大,有比较难的也有难度很小的,难题中考的比较多的是设计类问题比如:如果要在我们的CPU加一个XX功能,那哪些组成部分需要修改呢?(从信号角度考虑,如果需要产生新的信号,那么consignal、insdecode是必须要考虑到的),还有在AU运算模块中加一个新模块(通常是往年有但当年没有的运算)代码逻辑应该怎么写等等,这里附上2021级学长的经验供大家参考:http://t.csdnimg.cn/vMZbY

预祝大家都能在这门课中学有所成,并且取得一个好成绩!

一、设计目的

完整、连贯地运用《电路与电子学》所学到的电路、模电和数电知识,熟练掌握现代 EDA工具基本使用方法,为后续课程学习和今后从事相关工作打下良好的基础或做下一些铺垫。

二、设计内容

① 设计一个由传感器(电桥)、放大器、滤波器、模数转换器构成的模拟通道;

② 按照给定的数据通路、数据格式和指令系统,使用 EDA 工具设计一台用硬连线逻辑控制的简易计算机;

③ 用所设计的计算机控制模拟通道对外界模拟输入信号进行采样、离散和处理,并显示在数码显示管上;

④ 整理出设计报告。

三、详细设计

3.1 模型机的设计思路

1.首先根据自上到下的原则,了解模型机整体的设计思路原理,再根据整体原理去设计下层的结构和功能;

2.利用好分块设计,使用 Verilog 语言对每个模块进行设计,依次分析和检查每个模块的功能和仿真波形是否正确;

3.再根据从下到上的原则,依据整体架构对封装好的各板块进行连接,每连接一个板块进行一次仿真验证,确保无误后再进行下一个组建的连接,直到整个模型机设计完毕。

3.2 模型机的整体架构

在这里插入图片描述

3.3 各模块的具体实现

(此部分必须各模块功能、接口设计以及功能实现)

3.2.1 控制信号产生逻辑

在这里插入图片描述

接口设计:模块的输入端口是来自指令译码器的 12 个指令信号:mova、movb、movc、movd、movi、 add、sub、jmp、jg、in1、out1、halt,以及控制取址和执行周期的 sm 信号,还有指令码的直接输入ir[7…0],以及 g 状态位的输入,输出端口为各个模块的使能信号或控制信号:sm_en、pc_ld、pc_in、reg_sr[1:0]、 reg_dr[1:0]、reg_we、s[1:0]、au_en、au_ac[3:0]、gf_en、in_en、out_en、mux_s。

功能实现:控制信号产生逻辑接收指令译码器的输出,在 sm、ir[7:0]以及状态位 g 的配合下产生每个模块所需要的控制信号。

Verilog 语言

module con_signal(mova,movb,movd,movc,add,sub,jmp,jg,g,in1,out1,movi,halt,ir,sm,sm_en,ir_ld,ram_re,ram_wr,pc_ld,pc_in,reg_sr,reg_dr,reg_we,s,au_en,au_ac,gf_en,in_en,out_en,mux_s);
input mova,movb,movc,movd,add,sub,jmp,sm,jg,g,in1,out1,movi,halt;
input [7:0]ir;
output reg sm_en,ram_re,ir_ld,pc_in,ram_wr,pc_ld,reg_we,gf_en,in_en,out_en,mux_s,au_en;
output reg [1:0]reg_sr,reg_dr,s;
output reg [3:0]au_ac;
always @(*)
	begin
	au_en=mova | movb | add | out1 | sub;
	sm_en=~halt;
	ir_ld=~sm;
	ram_re=(~sm) | movc | movi;
	ram_wr=movb;
	gf_en=sub;
	pc_ld=jmp | (jg & g);
	pc_in=movi | (~sm);
	reg_we=movi | mova | movc | movd | sub | add | in1;
	in_en=in1;
	reg_dr=ir[3:2];
	out_en=out1;
	reg_sr=ir[1:0];
	if(movb) s=2'b10;
	else if(movc) s=2'b01;
	au_ac=ir[7:4];
	mux_s=mova | movb |movi | add | sub | in1;
	end
endmodule
	



3.2.2 指令译码器

在这里插入图片描述

接口设计:模块输入为译码器使能信号 en 和指令寄存器传来的机器码 ir[3:0],输出为十二条指令信号 mova、movb、movc、movd、add、sub、jmp、jg、in1、out1、movi、halt,将会接到控制信号发生逻辑上。

功能实现:当译码器使能信号en 为 0 时使能禁止,各个输出端口均输出 0;当 en=1 时,根据传入的机器码 ir 进行指令判断,对应的指令端口输出 1,其余为 0。

Verilog 语言

module ins_decode(en,ir,mova,movb,movc,movd,add,sub,jmp,jg,in1,out1,movi,halt);
input en;
input [3:0] ir;
output mova,movb,movc,movd,add,sub,jmp,jg,in1,out1,movi,halt;
reg [11:0]HappyNewYear;
always @ (en,ir)
begin
	if(en==0)
		begin HappyNewYear<=12'b000000000000; end
	else
		begin
		if(ir==4'b0100)
			begin HappyNewYear<=12'b100000000000; end
		else if(ir==4'b0101)
			begin HappyNewYear<=12'b010000000000; end
		else if(ir==4'b0110)
			begin HappyNewYear<=12'b001000000000; end
		else if(ir==4'b0111)
			begin HappyNewYear<=12'b000100000000; end
		else if(ir==4'b1000)
			begin HappyNewYear<=12'b000010000000; end
		else if(ir==4'b1001)
			begin HappyNewYear<=12'b000001000000; end
		else if(ir==4'b1010)
			begin HappyNewYear<=12'b000000100000; end
		else if(ir==4'b1011)
			begin HappyNewYear<=12'b000000010000; end
		else if(ir==4'b1100)
			begin HappyNewYear<=12'b000000001000; end
		else if(ir==8'b1101)
			begin HappyNewYear<=12'b000000000100; end
		else if(ir==8'b1110)
			begin HappyNewYear<=12'b000000000010; end
		else if(ir==8'b1111)
			begin HappyNewYear<=12'b000000000001; end
		else 
		begin HappyNewYear<=12'b000000000000; end
		end
end
assign {mova,movb,movc,movd,add,sub,jmp,jg,in1,out1,movi,halt}=HappyNewYear;
endmodule 

3.2.3 算术单元 AU

在这里插入图片描述

接口设计:函数发生器模块共有 4 个输入端口,包括来自通用寄存器的数据来源 a[7:0]、b[7:0],以及来自控制信号发生逻辑的 a[3:0]指令码和使能信号au_en 信号。输出端口包括连接总线的数据 t 以及 gf标志。

功能实现:要实现:算术运算、直接经过两种功能。对于每种功能都要从 a,b 选择适当的端口获取数据,并且在要考虑加减法运算对 gf 标志的影响,要利用好补码的运算以及大小比较。

Verilog 语言

module au(au_en,ac,a,b,t,gf);
input au_en;
input [3:0] ac;
input [7:0] a;
input [7:0] b;
output reg [7:0] t;
output reg gf;
always @(au_en,ac,a,b)
	begin
	gf=1'b0; 
	t=8'b00000000;
	if(au_en==1'b0)
		begin
		t=8'hZZ;
		end
	else if(au_en==1'b1)
		begin
		if(ac==4'b1000)
			begin
			t=a+b;
			end
		else if(ac==4'b1001)
			begin
			t=b+(~a)+8'b00000001;
			if(t[7]==0)gf=1;
			else if(t[7]==1)gf=0;
			end
		else if(ac==4'b0100 || ac==4'b0101 || ac==4'b1101)
			begin t=a; end
		else
			begin t=8'hZZ; end
		end
	end
endmodule


3.2.4 8 重 3-1 多路复用器

在这里插入图片描述

接口设计:8 重 3-1 多路复用器有 3 个八位输入 a[7:0]、b[7:0]、c[7:0],1 个输出 y[7:0],称之为 8重,s[1:0]选择将哪个输入传至输出。

功能实现:当控制信号s 为 00 时,输出 y=a,当控制信号 s 为 01 时输出 y=b,当控制信号 s=10 时,输出 y=c,控制信号 s=11 时,输出y=a。

Verilog 语言

module mux3_1(a,b,c,s,y);
input [7:0]a,b,c;
input [1:0]s;
output reg[7:0]y;
always @(*)
begin
if(s==2'b01) y<=b;
else if(s==2'b10) y<=c;
else y<=a;
end
endmodule


3.2.5 8 重 2-1 多路复用器

在这里插入图片描述

接口设计:8 重 2-1 多路复用器有 2 个八位输入 a[7:0]、b[7:0],1 个输出 y[7:0],称之为 8 重,s 选择将哪个输入传至输出。

功能实现:当控制信号s 为 0 时,输出y=a,当控制信号 s 为 1 时输出 y=b。

Verilog 语言

module mux2_1(a,b,s,y);
input [7:0]a,b;
input s;
output reg[7:0] y;
always @(*)
begin
if(s==1'b0)y<=a;
else if(s==1'b1)y<=b;
end
endmodule


3.2.6 SM

在这里插入图片描述

**接口设计:**输入端口包括时钟信号clk 和使能信号 sm_en,输出为 sm 用于指示当前是取指周期还是执行指令周期。

**功能实现:**在时钟的下降沿对 sm 取反。SM 为 0 是取指令周期;SM 为 1 是执行指令周期。

Verilog 语言

module sm(sm_en,sm,clk); 
input sm_en,clk;
output sm;
reg t=1'b0;
always @(negedge clk)
begin
if(sm_en==1'b1) t<=~t;
end
assign  sm=t;
endmodule


3.2.7 指令寄存器 IR

在这里插入图片描述

接口设计:输入端口有时钟信号 clk,控制读入信号 ld_ir,来自总线的信号a[7:0],输出为 x

功能实现:当控制信号 ir_ld 为 1 时,指令寄存器在时钟信号 CLK 的下降沿将总线传输的指令写入寄存器。

Verilog 语言

module ir(clk,ld_ir,a,x);
input clk,ld_ir;
input [7:0]a;
output reg [7:0]x=8'b00000000;
always @(negedge clk)
begin
if(ld_ir==1'b1)
	x<=a;
end
endmodule

3.2.8 状态寄存器 PSW

在这里插入图片描述

接口设计:输入端口包括时钟信号 clk,使能信号 g_en 和移位逻辑传输过来的g 信号。输出为 gf 信号。

功能实现:PSW 用来存放 SUB 指令执行结果的状态标志,结果是否为零。当 g_en 为 1 时,在时钟下降沿将 g 写入 gf。

Verilog 语言

module psw(g_en,gf,g,clk);
input g,clk,g_en;
output reg gf=1'b0;
always @(negedge clk)
begin
if(g_en==1'b1)
	gf<=g;
end
endmodule

3.2.9 指令计数器 PC

在这里插入图片描述

接口设计:模块的输入端有来自总线上的数据a[7:0],以及来自控制信号发生逻辑的加载信号 ld_pc,自加信号 in_pc,时钟信号 clk。输出端口为 c[7:0],通向选择器的地址输出ADDR。

功能实现:in_pc 为 1,ld_pc 为 0,执行地址加 1 操作;in_pc 为 0,ld_pc 为 1,执行写入操作,将输入 a[7:0]写入到输出c[7:0]中。

Verilog 语言

module pc(ld_pc,in_pc,clk,a,c);
input in_pc,clk,ld_pc;
input [7:0]a;
output reg [7:0]c=8'b00000000;
always @(negedge clk)
begin
if(in_pc==1'b1 && ld_pc==1'b0)
	c<=c+8'b00000001;
else if(in_pc==1'b0 && ld_pc==1'b1)
	c<=a;
end
endmodule

3.2.10 通用寄存器组

在这里插入图片描述

接口设计:通用寄存器组模块的输入端口包括来自控制信号发生单元的写使能信号 we、源寄存器地址 sr[1:0],目的寄存器地址 dr[1:0],来自总线上的数据输入 i[7:0] 和系统时钟信号 clk。输出包括s[7:0]和 d[7:0]。

功能实现:该寄存器组有读和写两种功能,对于读操作:根据 sr 和 dr 的值分别为 00、01、10、11 分别选择 r0、r1、r2、r3 的值从对应的 s/d 口输出;对于写操作,当 we 为 1 时,在时钟下降沿根据 dr 的值为 00、01、10、11 分别将 i 的值读入 r0、r1、r2、r3。

Verilog 语言

module reg_group(we,clk,sr,dr,i,s,d);
input we,clk;
input [1:0]sr,dr;
input [7:0]i;
output reg[7:0]s,d;
reg [7:0]r0=8'b00000001,r1=8'b00000001,r2=8'b00000001,r3=8'b00000001;
always @(*)
begin
if(sr==2'b00)
	s=r0;
else if(sr==2'b01)
	s=r1;
else if(sr==2'b10)
	s=r2;
else 
	s=r3;
if(dr==2'b00)
	d=r0;
else if(dr==2'b01)
	d=r1;
else if(dr==2'b10)
	d=r2;
else 
	d=r3;
end
always @(negedge clk)
begin
if(we==1'b1)
begin
case(dr)
2'b00:r0<=i;
2'b01:r1<=i;
2'b10:r2<=i;
2'b11:r3<=i;
endcase
end
end
endmodule


3.2.11 RAM

在这里插入图片描述

接口设计:RAM 的端口包括 mux_3 选择器传来的地址 address、时钟信号 inclock、写入寄存器的信号 we、以及读取寄存器中的值的信号 outenab 和端口 dio

功能实现:当 we 和 outenab 均为 0 时,在时钟信号的上升沿输出高阻态 Z,当 we 为 0,outenab 为 1 时,进行写操作,在时钟信号的上升沿将 dio 中的数据写入地址address 对应的储存单元中,当 we 为 1,outenab为 0 时,执行读操作,将地址 address 对应储存单元中的值从 dio 输出。

四、系统测试

4.1 测试环境:

开发软件:Quartus ll version 9.0 Build 184 04/29/2009 S.J web Edition

操作系统:Windows11 家庭版

FPGA 学习板芯片信号:Cyclone II EP2C5T144C8

4.2 测试代码:

(使用模型机实现的指令编写一至两个程序测试模型机的正确性。)

R3 初始值为 00000111,R1 初始值为 00000001

在这里插入图片描述

ram.mif 文件:

在这里插入图片描述

4.3 测试结果

下板代码功能仿真:

在这里插入图片描述

在这里插入图片描述

下板代码时序仿真:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

下板图示:

在这里插入图片描述

在这里插入图片描述

仿真代码功能仿真:

在这里插入图片描述

在这里插入图片描述

仿真代码时序仿真:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4.4 模型机性能分析

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

分析:此程序占用资源数为 165(4%),时钟周期为 22.414ns,warning13 条,性能较好,占用资源较少,符合实验要求。

五、实验总结、必得体会及建议

5.1 从需要掌握的理论、遇到的困难、解决的办法以及经验教训等方面进行总结。

答:对于本次实验,需要学会如何使用 Quartus 编写具有对应功能的模块与元件、掌握如何组装并设计简易的模型机,同时需要了解如何使用在 FPGA 实验板上验证功能是否正确。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2121305.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何恢复最近删除的文件[Windows Mac]

可以通过多种方式删除文件。因此&#xff0c;用户需要恢复他们不小心删除的文件的情况并不少见。 好消息是&#xff0c;用户至少通常可以在删除最近删除的文件后几天或几周内恢复它们。 回收站是 Windows 中的文件删除保护措施&#xff0c;可以轻松恢复文件。 除非另有配置&…

第二证券:科创板股票交易规则,科创板新手可以买吗?

科创板是独立于现有主板商场的特别板块&#xff0c;面向的是国际科技前沿、经济主战场、国家严峻需求&#xff0c;首要服务于契合国家战略、打破要害核心技术、商场认可度高的科技立异企业。 科创板是独立于现有主板商场的特别板块&#xff0c;面向的是国际科技前沿、经济主战…

二叉树 - 验证二叉搜索树

98. 验证二叉搜索树 方法一&#xff1a;辅助数组 /*** Definition for a binary tree node.* function TreeNode(val, left, right) {* this.val (valundefined ? 0 : val)* this.left (leftundefined ? null : left)* this.right (rightundefined ? null :…

WPF中创建横向的ListView

在WPF中&#xff0c;要创建横向的ListView&#xff0c;您可以通过设置ItemsControl的ItemsPanel来改变其项的排列方向。以下是一个简单的示例&#xff0c;展示了如何将ListView的项横向排列&#xff1a; 在这个例子中&#xff0c;WrapPanel用于横向排列其子元素&#xff0c;而…

本地Linux服务器使用docker搭建DashDot并实现公网实时监测服务器信息

文章目录 前言1. 本地环境检查1.1 安装docker1.2 下载Dashdot镜像 2. 部署DashDot应用3. 本地访问DashDot服务4. 安装cpolar内网穿透5. 固定DashDot公网地址 前言 本篇文章我们将使用Docker在本地部署DashDot服务器仪表盘&#xff0c;并且结合cpolar内网穿透工具可以实现公网实…

C语言 ——— 学习并使用条件编译指令

目录 何为条件编译指令 常见的条件编译指令 学习条件编译指令 使用条件编译指令 在程序预编译阶段&#xff0c;条件编译指令的代码转换 多分支的条件编译指令 何为条件编译指令 在编译一个程序的时候&#xff0c;如果要将一条语句&#xff08;一组语句&#xff09;选择编…

Redis学习Day2——Redis基础使用

扩展阅读推荐: Redis 教程 | 菜鸟教程 (runoob.com) 黑马程序员Redis入门到实战教程_哔哩哔哩_bilibili 细说 Redis 九种数据类型和应用场景_redis数据类型及应用场景-CSDN博客 一、命令篇 1.1 Redis的命令分类 Redis是典型的K-V型数据库,key标识字符串,而value包含了很…

React Native 0.76版本发布

关于 React Native 的 New Architecture 概念&#xff0c;最早应该是从 2018 年 RN 团队决定重写大量底层实现开始&#xff0c;因为那时候 React Native 面临各种结构问题和性能瓶颈&#xff0c;最终迫使 RN 团队开始进行重构。 而从 React Native 0.68 开始&#xff0c;New A…

在B端管理系统中,复杂或者DIY功能,都依赖哪些编辑器/设计器

一、引言 在当今的商业环境中&#xff0c;B 端管理系统扮演着至关重要的角色。这些系统不仅需要满足企业日常的运营管理需求&#xff0c;还需要具备足够的灵活性和可扩展性&#xff0c;以适应不断变化的业务需求。而在实现复杂或可 DIY 的功能方面&#xff0c;各种编辑器和设计…

C++VTK鼠标框选局部删除三维网格

程序示例精选 CVTK鼠标框选局部删除三维网格 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对《CVTK鼠标框选局部删除三维网格》编写代码&#xff0c;代码整洁&#xff0c;规则&#xff0c;易…

暗星·Java实战之进阶旅游网

简介 暗星旅游网&#xff0c;是一个分为管理员端和用户端的项目&#xff0c;有权限分离认证&#xff0c;管理员端&#xff08;后台&#xff09;进行旅游产品的维护&#xff0c;主要功能有&#xff1a;管理员管理&#xff0c;角色管理&#xff0c;权限管理&#xff0c;认证和授…

Python怎么发送邮件:基础步骤与详细教程?

Python怎么发送邮件带附件&#xff1f;怎么使用Python发送邮件&#xff1f; 无论是工作中的通知、报告&#xff0c;还是生活中的问候、邀请&#xff0c;电子邮件都扮演着不可或缺的角色。那么&#xff0c;Python怎么发送邮件呢&#xff1f;AokSend将详细介绍Python发送邮件的基…

三、排序算法

文章目录 一、排序算法的介绍二、算法的时间复杂度2.1 基本介绍2.2 时间频度2.3 时间复杂度的表示2.4 算法的平均时间复杂度和最坏时间复杂度 三、算法的空间复杂度四、排序算法4.1 交换排序4.1.1 冒泡排序4.1.2 快速排序 4.2 选择排序4.2.1 简单选择排序4.2.2 堆排序 4.3 插入…

基于Llama 3的最强开源医疗AI模型发布,刷新榜单

转自&#xff1a;火星AIGC 一家名为Saama AI Labs发布了他们基于Llama 3 微调的开源医疗AI大模型OpenBioLLM-Llama3-70B 和 OpenBioLLM-Llama3-8B&#xff0c;刷新抱抱脸上的医疗大模型榜单&#xff0c;并占据榜首。其在生物医学领域的测试性能超越 GPT-4、Gemini、Meditron-7…

浙大数据结构:04-树6 Complete Binary Search Tree

这道题利用了完全二叉树的性质&#xff0c;我也参考了一些代码写的。 &#xff08;自己一开始写了别的方法&#xff0c;但一直过不了最后一个测试点&#xff0c;红温了&#xff09; 机翻&#xff1a; 1、条件准备 用vector存输入的数据&#xff0c;另一个数组存输出的结果&a…

文心一言 VS 讯飞星火 VS chatgpt (344)-- 算法导论23.2 3题

三、对于稀疏图 G ( V &#xff0c; E ) G(V&#xff0c;E) G(V&#xff0c;E)&#xff0c;这里 ∣ E ∣ Θ ( V ) |E|Θ(V) ∣E∣Θ(V)&#xff0c;使用斐波那契堆实现的Prim算法是否比使用二叉堆实现的算法更快&#xff1f;对于稠密图又如何呢&#xff1f; ∣ E ∣ |E| ∣E…

FPGA技术赋能云数据中心:提高性能与效率

随着现代科技的迅猛发展和大数据时代的推动&#xff0c;云数据中心已成为众多企业的核心基础设施。然而&#xff0c;伴随数据处理需求的不断增长&#xff0c;传统硬件架构在性能、功耗和灵活性方面面临诸多挑战。为了解决这些问题&#xff0c;FPGA&#xff08;现场可编程门阵列…

辽宁汇聚公益慈善力量,绿葆网络助力辽宁绿色生态建设,彰显企业大爱

9月5日&#xff0c;于辽宁省沈阳市隆重举行的“中华慈善日”主题宣传活动暨“山海有情 天辽地宁”即开型福利彩票发行、“生态公益林”项目启动仪式上&#xff0c;广州绿葆网络发展有限公司作为受邀企业之一&#xff0c;积极履行社会责任&#xff0c;向辽宁省慈善联合总会捐赠了…

坐牢第三十六天(QT)

自定义QQ界面 wedget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QDebug> //qt中信息调试类 #include <QIcon> //图标类 #include <QPushButton>//按钮类 #include <QLabel> //标签类 #include <QMovie> //动图类…

【C++】—— vector 的模拟实现

【C】—— vector 的模拟实现 0 前言1 vector 的成员变量1.1 stl 库中的 vector 成员变量1.2 模拟实现 vector 成员变量 2 迭代器3 size、capacity、empty4 opreator[ ]5 reserve5.1 初版 reserve5.2 _finish 的处理5.3 深拷贝5.4 终版 6 push_back 与 pop_back7 打印函数7.1 初…