ALU模块设计文档.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ALU模块设计文档

版本信息 版本 日期 描述 作者 1.0 20/03/2015 ALU模块设计文档 刘有耀 封面版本信息必须与本页最后版本保持一致。 ALU模块设计方案 算术逻辑运算器(ALU)是数字计算机中执行加、减等算术运算,执行与、或等逻辑运算,以及执行比较、移位、传送等操作的功能部件,本模块实现32位的ALU。本文描述MIPS单周期处理器的ALU模块的功能、接口、时序及其实现。 1 功能 ALU主要完成: 有符号数的加减运算 无符号数的加减运算 与、或逻辑运算 算术右移 逻辑左移、右移 有符号小于置1运算 无符号小于置1运算 2 接口说明 表1 ALU接口信号定义 信号名称 方向 含义 ALU_DA[31:0] IN ALU第一个输入数据端口,32位宽度 ALU_DB[31:0] IN ALU第二个输入数据端口,32位宽度 ALU_CLT[3:0] IN ALU运算功能编码,12种指令需要4位编码 ALU_SHIFT[4:0] IN ALU移位次数 ALU_ZERO OUT 运算结果全零标志 ALU_OverFlow OUT 有符号运算溢出标志 ALU_DC[31:0] OUT ALU运算结果 3 时序说明 4 实现方案 算术逻辑运算器(ALU)的具体实现方案如图1。分析图1的功能,并按功能要求将图1补充完整(即与逻辑和移位功能的实现)。 图1 ALU实现方案 表1 ALU控制信号 SUBctr = ALUctr2(作为加减控制信号,同时作为与或控制信号) ANDctr = ALUctr0 OVctr = !ALUctr1ALUctr0 SIGctr = ALUctr0 OPctr1 = ALUctr2 ALUctr1 OPctr0 = (!ALUctr2 ALUctr1 !ALUctr0)| ALUctr3 根据(Opctr=2’b11时作为移位输出选择)、ALUctr3:0==4’b10000逻辑左移,ALUctr3:0==4’b10001逻辑右移,ALUctr3:0==4’b10010算术右移等要求修改补充表1。 5 电路设计描述 module (ALU_DA,ALU_DB,ALU_CLT,ALU_SHIFT,ALU_ZERO,ALU_OverFlow,ALU_DC) input [31:0] ALU_DA; input [31:0] ALU_DB; input [3:0] ALU_CLT; input [4:0] ALU_SHIFT; output ALU_ZERO; output ALU_OverFlow; output [31:0] ALU_DC; reg [31:0] ALU_DC; wire [1:0] OPctr; wire SUBctr; wire ANDctr; wire OVctr; wire SIGctr; reg [31:0] SLL_M,SRL_M,SRA_M; assign SUBctr = ALUctr[2]; assign ANDctr = ALUctr[0]; assign OVctr = !ALUctr[1]ALUctr[0]; assign SIGctr = ALUctr[0]; assign OPctr1 = ALUctr[2] ALUctr[1]; assign OPctr0 = ?!ALUctr[2] ALUctr[1] !ALUctr[0]?| ALUctr[3]; always //SRL begin case(ALU_SHIFT) 5b00000:SRL_M[31:0]=ALU_DA[31:0]; 5b00001:SRL_M[31:0]={1b0,ALU_DA[31:1]}; 5b00010:SRL_M[31:0]={2b0,ALU_DA[31:2]}; //..... 5b11111:SRL_M[31:0]={31b0,ALU_DA[31]}; default: SRL_M[31:0]=ALU_DA[31:0]; endcase end always //SLL begin case(ALU_SHIFT) 5b00000:SLL_M[31:0]=ALU_DA[31:0]; 5b00001:SLL_M[31:0]={ALU_DA[30:0],1b0}; 5b00010:SLL_M[31:0]={A

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档