多功能ALU的设计和实现
更新时间:2023-11-15 03:25:01 阅读量: 教育文库 文档下载
多功能ALU的设计和实现——附VHDL源码(中) 2010年01月20日 星期三 12:13 转载请注明出处:
http://hi.http://www.wodefanwen.com//ouwennuan/blog/item/79943c32afdcbc48ad4b5fed.html alu74181.vhd(74181ALU芯片) library ieee;
use ieee.std_logic_1164.all; entity alu74181 is
port( );
--m为控制端,cn为最低位的进位输入 m,cn : in std_logic;
--s0~s3为控制参数,a0~a3、b0~b3为输入信号 s,a,b : in std_logic_vector(3 downto 0);
--g为进位发生输出,p为进位传送输出,co为本片的最后进位输出 g,p,co : out std_logic; --f0~f3为输出信号
f : out std_logic_vector(3 downto 0)
end alu74181;
architecture s_alu74181 of alu74181 is
--+++++++++++++++++++++++++++++++++++++++ --fmp函数发生器定义 component fpm is
port(s,a,b : in std_logic_vector(3 downto 0);
x,y : out std_logic_vector(3 downto 0));
end component;
--+++++++++++++++++++++++++++++++++++++++ --中间信号变量
--x0~x3,y0~y3为函数发生器输出信号 signal x,y: std_logic_vector(3 downto 0);
--sg,sp分别为临时存放进位发生输出和进位传送输出结果
--notm为对控制信号m取反 signal sg,sp,notm: std_logic; begin
--调用函数发生器
cmd : fpm port map(s,a,b,x,y); --求得输出信号f0~f3 notm <= not m;
f(0) <= x(0) xor y(0) xor ( not(notm and cn) ); f(1) <= x(1) xor y(1) xor
( not(
(notm and y(0))
or (notm and x(0) and cn)
) );
f(2) <= x(2) xor y(2) xor
( not(
(notm and y(1))
or (notm and x(1) and y(0)) or (notm and x(0) and x(1) and cn)
) );
f(3) <= x(3) xor y(3) xor
( not(
(notm and y(2))
or (notm and x(2) and y(1))
or (notm and x(0) and x(1) and x(2) and cn) or (notm and x(1) and x(2) and y(0))
) );
--求得进位发生输出g和进位传送输出p
sg <= y(3) or (y(2) and x(3)) or (y(1) and x(2) and x(3))
or (y(0) and x(1) and x(2) and x(3));
g <= sg;
sp <= x(0) and x(1) and x(2) and x(3); p <= sp;
--求得本片的最后进位输出co co <= not (
);
(sg and sp) or (sg and (not cn))
end s_alu74181;
cla74182.vhd(74182CLA芯片) library ieee;
use ieee.std_logic_1164.all; entity cla74182 is
port( );
--cn为最低位的进位输入 cn : in std_logic;
--ALU74181产生的进位发生输出g0~g3和进位传送输出p0~p3 g,p : in std_logic_vector(3 downto 0); --cx,cy,cz存放输出的组与组间的进位输出
--gg,pp存放输出的成组进位输出和成组进位传送输出 cx,cy,cz,gg,pp : out std_logic
end cla74182;
architecture s_cla74182 of cla74182 is
--存放cx,cy的中间信号变量 signal cxt,cyt : std_logic; begin
cxt <= g(0) or (p(0) and cn); cx <= cxt;
cyt <= g(1) or (p(1) and cxt); cy <= cyt;
cz <= g(2) or (p(2) and cyt);
gg <= g(3) or (g(2) and p(3)) or (g(1) and p(2) and p(3))
or (g(0) and p(1) and p(2) and p(3));
pp <= p(0) and p(1) and p(2) and p(3);
end s_cla74182;
alu16.vhd(16位的全先行进位的ALU) library ieee;
use ieee.std_logic_1164.all; entity alu16 is
port( );
--m为控制端,cn为最低位的进位输入 m,cn : in std_logic; --s0~s3为控制参数
s : in std_logic_vector(3 downto 0); --a0~a15、b0~b15为输入信号
a,b : in std_logic_vector(15 downto 0); --co为最后进位输出 co : out std_logic; --f0~f15为输出信号
f : out std_logic_vector(15 downto 0)
end alu16;
--alu74181元件函数定义
component alu74181 is
port( );
m,cn : in std_logic;
s,a,b : in std_logic_vector(3 downto 0); g,p,co : out std_logic;
f : out std_logic_vector(3 downto 0)
end component;
--+++++++++++++++++++++++++++++++++++++++ --cla74182元件函数定义 component cla74182 is
port( );
cn : in std_logic;
g,p : in std_logic_vector(3 downto 0); cx,cy,cz,gg,pp : out std_logic
end component; --fmp函数发生器定义 component fpm is
port(s,a,b : in std_logic_vector(3 downto 0);
x,y : out std_logic_vector(3 downto 0));
end component;
--+++++++++++++++++++++++++++++++++++++++ --中间信号变量 signal
--sa1~sa4存放输入信号a0~a15
sa1,sa2,sa3,sa4,
--sx1~sx4存放输入信号a0~a15经函数发生器处理后的结果
sx1,sx2,sx3,sx4,
--sb1~sb4存放输入信号b0~b15
sb1,sb2,sb3,sb4,
--sx1~sx4存放输入信号b0~b15经函数发生器处理后的结果
sy1,sy2,sy3,sy4,
--sf1~sf4存放输出信号f0~f15
sf1,sf2,sf3,sf4,
--存放由4片ALU74181产生的进位发生输出sg0~sg3和进位传送输出sp0~sp3
sg,sp,sg1,sp1 : std_logic_vector(3 downto 0);
signal
正在阅读:
多功能ALU的设计和实现11-15
初一语文测试题11-06
数据库(ER图)08-10
《数据库原理与应用》试卷10-16
离退休人员返聘协议范本04-16
特定买方保险条款 出口信用保险 中国出口信用保险公司06-02
市级2016小课题结题报告 - 图文12-25
广州商业地产市场2012年年度市场分析05-13
七年级英语新目标下册第八单元测试题05-18
小学生二年级北京一日游作文06-13
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 多功能
- 实现
- 设计
- ALU