- 1、本文档共42页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
VHDL与数字电路设计PPT课件-第六章 时序逻辑电路的设计
上升沿翻转的8分频器 下降沿翻转的8分频器 LIBRARY IEEE; USE IEEE.std_logic_1164.all; ENTITY FreDevider IS PORT(clkin: IN std_logic; clkout: OUT std_logic); END FreDevider; ARCHITECTURE rtl OF FreDevider IS SIGNAL counter: integer RANGE 0 TO 2; SIGNAL tmp1,tmp2: std_logic; BEGIN PROCESS(clkin) BEGIN IF rising_edge(clkin) THEN IF counter=2 THEN counter = 0; tmp1 = NOT tmp1; ELSE counter = counter+1; END IF; END IF; IF falling_edge(clkin) THEN IF counter=1 THEN tmp2 = NOT tmp2; END IF; END IF; END PROCESS; clkout = tmp1 XOR tmp2; END; 奇数倍分频电路(3分频) 6、存储器 256X8 ROM g1 g2 addr7~addr0 data_out7~data_out0 容量为256X8的ROM 当g1=‘1’且g2=‘1’时,存储器将把根据地址线选中的存储单元中的数据送到输出数据线上;否则输出数据线呈现高阻状态。 LIBRARY IEEE; USE IEEE.std_logic_1164.all; Use IEEE.std_logic_unsigned.all; ENTITY rom256_8 IS PORT(addr: IN std_logic_vector(7 DOWNTO 0); g1, g2: IN std_logic; data_out: OUT std_logic_vector(7 DOWNTO 0)); END rom256_8; ARCHITECTURE rtl OF rom256_8 IS SUBTYPE word IS std_logic_vector (7 DOWNTO 0); TYPE memory IS ARRAY (0 TO 255) OF WORD; SIGNAL rom : memory := (--初始化数据,省略); SIGANL addr_in: integer RANGE 0 TO 255; BEGIN PROCESS(g1,g2,addr) BEGIN addr_in = conv_integer(addr); IF(g1=‘1’ AND g2=‘1’) THEN data_out = rom(addr_in) ELSE data_out = (OTHERS = ‘Z’); END IF; END PROCESS; END rtl; 256X8 RAM cs wr addr7~addr0 data_out7~data_out0 容量为256X8的RAM 当… rd data_in7~data_in0 LIBRARY IEEE; USE IEEE.std_logic_1164.all; Use IEEE.std_logic_unsigned.all; ENTITY ram256_8 IS PORT(addr: IN std_logic_vector(7 DOWNTO 0); data_in: IN std_logic_vector(7 DOWNTO 0); wr,rd,cs: IN std_logic; data_out: OUT std_logic_vector(7 DOWNTO 0)); END ram256_8; ARCHITECTURE rtl OF ram256_8 IS SUBTYPE word IS std_logic_vector (7 DOWNTO 0); TYPE memory IS ARRAY (0 TO 255) OF WORD; SIGNAL sram : memory; SIGANL addr_in: integer RANGE 0 TO 255; BEGIN addr_in = conv_integer(addr); PROCESS(wr) BEGIN IF(wr’event AND wr=‘1’) THEN IF
文档评论(0)