📄 shift_reg.vhd
字号:
LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
ENTITY dff IS
PORT (d : IN std_logic;
clk : IN std_logic;
q : OUT std_logic);
END dff;
ARCHITECTURE rtl OF dff IS
BEGIN
PROCESS (clk)
BEGIN
IF (clk'event AND clk = '1') THEN
q <= d;
END IF;
END PROCESS;
END rtl;
LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
--USE WORK.example.ALL;
ENTITY shift_reg IS
PORT (d1 : IN std_logic;
cp : IN std_logic;
q : OUT std_logic_vector(3 DOWNTO 0));
END shift_reg;
ARCHITECTURE structure_arc OF shift_reg IS
COMPONENT dff
PORT (d : IN std_logic;
clk : IN std_logic;
q : OUT std_logic);
END COMPONENT;
SIGNAL q_temp : std_logic_vector(4 DOWNTO 1);
BEGIN
G1:FOR i IN 0 TO 3 GENERATE
P1:IF (i = 0) GENERATE
dffx: dff PORT MAP (d1,cp,q_temp(i+1));
END GENERATE P1;
P2:IF (i /= 0) GENERATE
dffx: dff PORT MAP (q_temp(i),cp,q_temp (i+1));
END GENERATE P2;
END GENERATE G1;
q <= q_temp(4 DOWNTO 1);
END structure_arc;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -