模型机设计(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
...

         

  • 8
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值