IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 模型机设计(VERILOG)-控制信号发生器 -> 正文阅读

[嵌入式]模型机设计(VERILOG)-控制信号发生器

控制信号发生器

1.功能

????????控制信号发生器的功能为根据特定的指令,发出对应的控制信号,使各组件配合完成指令的执行。

2.控制信号

????????控制信号如下表:
????????

3.端口设计

????????共20个输入端口,除16个指令信号外,还有z,c两个状态信号(通过状态寄存器传入),ir为指令编码(这里仍然需要指令编码是因为ALU的sel控制信号是指令编码前4位),sm信号的作用是控制指令执行的时间。
??????? 共19个输出端口,18个控制信号如上表,多出的一个sm_en信号是执行HALT指令所需要的。sm控制指令执行的周期,sm=1时执行指令,sm=0时读取指令,当sm_en=1时,sm在0和1之间翻转,重复读取指令执行指令的过程。HALT指令执行后,不再执行之后的指令,因此需要使sm_en=0,让sm不再翻转,保持为1,即一直执行HALT指令。

4.各指令与对应的控制信号情况

??????? 只需要关注控制信号在哪些指令有效即可,无效不需要关注,使用always语句赋值,考虑信号为1的情况。
??????? 寄存器组共有三个寄存器,分别为A,B,C。
MOVA
???????
MOVA指令的功能为将源寄存器的数据移送至目的寄存器,关注通用寄存器组,ALU和移位逻辑构成的通路。
??????? 通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:不需要运算,m,cf_en,zf_en都无效为0
??????? 移位逻辑:不需要移位,flbus,frbus无效为0,数据直接通过,fbus=1
???????
指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,DL,XL都无效为0
??????? 指令计数器无操作,选择器值不影响指令执行

MOVB
???????
MOVB指令的功能为将源寄存器的数据移送至RAM,数据在RAM中的地址为寄存器C中的数据。
??????? 通用寄存器组:不需要写入数据,we无效为1(低电平有效)
??????? ALU:不需要运算,m,cf_en,zf_en都无效为0
??????? 移位逻辑:不需要移位,flbus,frbus无效为0,数据直接通过,fbus=1
???????
指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:需要写,DL无效为0,
XL=1
??????? 指令计数器无操作
??????? 选择器要接收寄存器C的数据作为一个存储器地址,从总线上取得的寄存器数据要存放在这个地址,因此MADD=10,接收D口传输的数据

MOVC

??????? MOVC指令的功能为将RAM的数据移送至目的寄存器,数据在RAM中的地址为寄存器C中的数据。
??????? 通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:不需要运算,m,cf_en,zf_en都无效为0
??????? 移位逻辑:不需要移位,也不需要且不能有数据通过(总线上只能有RAM传输的数据,不能冲突),flbus,frbus,fbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:需要读,XL无效为0,
DL=1
??????? 指令计数器无操作
??????? 选择器要接收寄存器C的数据作为一个存储器地址,要读出RAM这个地址的数据传给寄存器,因此MADD=01,接收S口传输的数据

ADD

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en=1,zf_en=1
??????? 移位逻辑:不需要移位,flbus,frbus,无效为0,fbus=1
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

SUB

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en=1,zf_en=1
??????? 移位逻辑:不需要移位,flbus,frbus,无效为0,fbus=1
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

AND

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en无效为0,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,frbus,无效为0,fbus=1
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

NOT

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en无效为0,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,frbus,无效为0,fbus=1
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

RSR

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en=1,zf_en无效为0
??????? 移位逻辑:需要移位,frbus=1,fbus,flbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

RSL

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:运算,m=1,cf_en=1,zf_en无效为0
??????? 移位逻辑:需要移位,flbus=1,fbus,frbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行

JMP

????????通用寄存器组:不需要写入数据,we=1(低电平有效)
??????? ALU:不运算,m,cf_en,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,fbus,frbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:需要读,XL无效为0,
DL=1
??????? 指令计数器:读取总线上的指令地址,pc_ld=1,pc_in无效为0
??????? 选择器选择PC的数据:
MADD=00

JZ/JC(Z=1/C=1时如下执行,否则不执行)

????????通用寄存器组:不需要写入数据,we=1(低电平有效)
??????? ALU:不运算,m,cf_en,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,fbus,frbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:需要读,XL无效为0,
DL=1
??????? 指令计数器:读取总线上的指令地址,pc_ld=1,pc_in无效为0
??????? 选择器选择PC的数据:
MADD=00

IN

????????通用寄存器组:需要写入数据,we=0(低电平有效)
??????? ALU:不运算,m,cf_en,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,fbus,frbus无效为0
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行
???????
in_en=1

OUT

????????通用寄存器组:不需要写入数据,we=1(低电平有效)
??????? ALU:不运算,m,cf_en,zf_en无效为0
??????? 移位逻辑:不需要移位,flbus,frbus无效为0,fbus=1
??????? 指令寄存器:不需要读指令,ir_ld无效为0
??????? RAM:不需要读写,XL,DL无效为0

??????? 指令计数器无操作,选择器值不影响指令执行
???????
out_en=1

NOP:暂停指令执行,无控制信号

HALT:停止sm翻转,sm_en=0

读取指令:sm=0时读取指令,pc_in=1,ir_ld=1

5.过程赋值代码

??????? 整理每个控制信号有效的指令,进行赋值

...
always@(mova,movb,movc,add,sub,and1,not1,rsr,rsl,jmp,jz,z,jc,c,in1,out1,nop,halt,sm,ir)
	begin
		sm_en<=!halt;
		//ALU
		alu_m<=add||sub||and1||not1||rsr||rsl||out1;
		cf_en<=add||sub||rsr||rsl;
		zf_en<=add||sub;
		alu_s[3:0]<=ir[7:4];
		//移位逻辑
		shi_fbus<=mova||movb||add||sub||and1||not1||out1;
		shi_frbus<=rsr;
		shi_flbus<=rsl;
		//RAM
		ram_dl<=movc||jmp||(jz&&z)||(jc&&c)||!sm;
		ram_xl<=movb;
		//指令寄存器
		ir_ld<=!sm;
		//寄存器组
		reg_we<=!(mova||movc||add||sub||and1||not1||rsl||rsr||in1)||!sm;
		reg_wa<=ir[3:2];
		reg_ra[1:0]<=ir[1:0];
		//计数器PC
		pc_ld<=jmp||(jz&&z)||(jc&&c);
		pc_in<=(jz&&!z)||(jc&&!c)||!sm;
		//选择器MADD
		if(movb&&sm) madd<=2'b10;
		else if(movc&&sm) madd<=2'b01;	
		else if(!sm) madd<=2'b00;
		else madd<=2'b00;
		//输入输出设备
		in_en<=in1;
		out_en<=out1;
 	end
...

?????????

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-02-05 21:53:26  更:2022-02-05 21:54:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 10:28:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码