Загрузка данных
library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
entity calculator_top is
port (
clk : in std_logic;
key : in std_logic_vector(2 downto 0);
dig : out std_logic_vector(3 downto 0);
seg : out std_logic_vector(7 downto 0)
);
end calculator_top;
architecture structural of calculator_top is
signal clk_fast : std_logic;
signal pll_locked : std_logic;
signal a_val : std_logic_vector(7 downto 0);
signal b_val : std_logic_vector(7 downto 0);
signal state : std_logic_vector(1 downto 0);
signal mult_en : std_logic;
signal save_en : std_logic;
signal disp_en : std_logic;
signal mode : std_logic; -- '0' = logic, '1' = dsp
signal mux_a_out : std_logic_vector(7 downto 0);
signal mux_b_out : std_logic_vector(7 downto 0);
signal reg_a_out : std_logic_vector(7 downto 0);
signal reg_b_out : std_logic_vector(7 downto 0);
signal dsp_result : std_logic_vector(15 downto 0);
signal logic_result : std_logic_vector(15 downto 0);
signal selected_result : std_logic_vector(15 downto 0);
--signal result_reg_out : std_logic_vector(15 downto 0);
--signal disp_reg_out : std_logic_vector(15 downto 0);
signal res_reg1: std_logic_vector(15 downto 0);
signal res_reg2: std_logic_vector(15 downto 0);
signal save_en_delayed: std_logic;
signal display_data : std_logic_vector(31 downto 0);
signal display_mode : std_logic_vector(7 downto 0);
begin
U_PLL: entity work.pll_5
port map (
areset=>'0',
inclk0=>clk,
c0=>clk_fast,
locked=>pll_locked
);
U_OPERAND_INT: entity work.operand_init
port map (
clk=>clk_fast,
a_val=>a_val,
b_val=>b_val
);
U_MODE_SELECT: entity work.mode_select
port map (
clk=>clk,
key=> key,
mode=>mode
);
U_MODE_DSIP: entity work.mode_display
port map (
clk=>clk,
mode=>mode,
mode_seg=>display_mode
);
U_CONTROL: entity work.mult_control
port map (
clk => clk_fast,
reset => key(0),
mult_en => mult_en,
save_en => save_en,
disp_en => disp_en,
state_out => state
);
U_MULT_DSP: entity work.mult_5
port map (
dataa => reg_a_out,
datab => reg_b_out,
result => dsp_result
);
U_MULT_LOGIC: entity work.logic
port map (
a => reg_a_out,
b => reg_b_out,
result => logic_result
);
-- Мультиплексор + регистр для A
U_MUX_REG_A: entity work.mux_register
port map (
clk => clk_fast,
sel => mult_en,
data_a => a_val,
data_b => (others => '0'),
mux_out => mux_a_out,
q => reg_a_out
);
-- Мультиплексор + регистр для B
U_MUX_REG_B: entity work.mux_register
port map (
clk => clk_fast,
sel => mult_en,
data_a => b_val,
data_b => (others => '0'),
mux_out => mux_b_out,
q => reg_b_out
);
-- Мультиплексор выбора результата
U_RESULT_MUX: entity work.result_mux
port map (
mode => mode,
logic_res => logic_result,
dsp_res => dsp_result,
result_out => selected_result
);
U_RES_REG1: entity work.res_reg
generic map (HOLD_VALUE=>false)
port map (
clk=>clk_fast,
slow=>save_en,
clear=>key(0),
value_in=>selected_result,
value_out=>res_reg1
);
process(clk_fast)
begin
if rising_edge(clk_fast) then
save_en_delayed<=save_en;
end if;
end process;
U_RES_REG2: entity work.res_reg
generic map (HOLD_VALUE=>true)
port map (
clk=>clk_fast,
slow=>save_en_delayed,
clear=>key(0),
value_in=>res_reg1,
value_out=>res_reg2
);
-- Регистр результата
--U_RESULT_REG: entity work.result_register
--port map (
--clk => clk_fast,
--load => save_en,
--clear => mult_en,
--data_in => selected_result,
--data_out => result_reg_out
--);
--U_DISP_REG: entity work.display_register
--port map (
--clk=>clk,
--load=>disp_en,
--data_in=>result_reg_out,
-- data_out=>disp_reg_out
--);
U_BIN_TO_DISP: entity work.bin_to_display
port map (
bin_in => res_reg2,
seg_out => display_data
);
U_DISPLAY: entity work.display_scan
port map (
clk => clk,
seg_in => display_data,
mode_seg => display_mode,
dig => dig,
seg => seg
);
end structural;
library ieee;
use ieee.std_logic_1164.all;
entity mult_control is
port (
clk : in std_logic;
reset : in std_logic;
mult_en : out std_logic;
save_en : out std_logic;
disp_en : out std_logic;
state_out : out std_logic_vector(1 downto 0)
);
end mult_control;
architecture rtl of mult_control is
signal counter : integer range 0 to 249999999 := 0;
constant ONE_SEC : integer := 250000000;
type state_type is (IDLE, MULT, SAVE, DISP, HOLD);
signal state : state_type := IDLE;
begin
process(clk)
begin
if rising_edge(clk) then
if reset = '0' then
state <= IDLE;
counter <= 0;
else
case state is
when IDLE =>
mult_en <= '0';
save_en <= '0';
disp_en <= '0';
if counter >= ONE_SEC - 1 then
counter <= 0;
state <= MULT;
else
counter <= counter + 1;
end if;
when MULT =>
mult_en <= '1';
save_en <= '0';
disp_en <= '0';
state <= SAVE;
when SAVE =>
mult_en <= '0';
save_en <= '1';
disp_en <= '0';
state <= DISP;
when DISP =>
mult_en <= '0';
save_en <= '0';
disp_en <= '1';
state <= HOLD;
when HOLD =>
mult_en <= '0';
save_en <= '0';
disp_en <= '0';
if counter >= ONE_SEC - 1 then
counter <= 0;
state <= MULT;
else
counter <= counter + 1;
end if;
end case;
end if;
end if;
end process;
with state select
state_out <= "00" when IDLE,
"01" when MULT,
"10" when SAVE,
"11" when DISP,
"11" when HOLD;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity result_register is
port (
clk : in std_logic;
load : in std_logic;
clear : in std_logic;
data_in : in std_logic_vector(15 downto 0);
data_out : out std_logic_vector(15 downto 0)
);
end result_register;
architecture rtl of result_register is
signal reg_data : std_logic_vector(15 downto 0) := (others => '0');
begin
process(clk)
begin
if rising_edge(clk) then
if clear = '1' then
reg_data <= (others=>'0');
elsif load = '1' then
reg_data <= data_in;
end if;
end if;
end process;
data_out <= reg_data;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity display_register is
port (
clk : in std_logic;
load : in std_logic;
data_in : in std_logic_vector(15 downto 0);
data_out : out std_logic_vector(15 downto 0)
);
end display_register;
architecture rtl of display_register is
signal reg_data : std_logic_vector(15 downto 0) := (others => '0');
begin
process(clk)
begin
if rising_edge(clk) then
if load = '1' then
reg_data <= data_in;
end if;
end if;
end process;
data_out <= reg_data;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity mode_select is
port (
clk : in std_logic;
key : in std_logic_vector(2 downto 0);
mode : out std_logic
);
end mode_select;
architecture rtl of mode_select is
begin
process(clk)
begin
if rising_edge(clk) then
if key(0) = '0' then
mode <= '0'; -- По сбросу режим logic
elsif key(1) = '0' then
mode <= '0'; -- Режим logic
elsif key(2) = '0' then
mode <= '1'; -- Режим DSP
end if;
end if;
end process;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity mux_register is
port (
clk : in std_logic;
sel : in std_logic;
data_a : in std_logic_vector(7 downto 0);
data_b : in std_logic_vector(7 downto 0);
mux_out : out std_logic_vector(7 downto 0);
q : out std_logic_vector(7 downto 0)
);
end mux_register;
architecture rtl of mux_register is
signal mux_signal : std_logic_vector(7 downto 0);
signal reg_signal : std_logic_vector(7 downto 0) := (others => '0');
begin
mux_signal <= data_a when sel = '1' else data_b;
process(clk)
begin
if rising_edge(clk) then
reg_signal <= mux_signal;
end if;
end process;
mux_out <= mux_signal;
q <= reg_signal;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity result_mux is
port (
mode : in std_logic;
logic_res : in std_logic_vector(15 downto 0);
dsp_res : in std_logic_vector(15 downto 0);
result_out : out std_logic_vector(15 downto 0)
);
end result_mux;
architecture rtl of result_mux is
begin
result_out <= logic_res when mode = '0' else dsp_res;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity mode_display is
port (
clk : in std_logic;
mode : in std_logic;
mode_seg : out std_logic_vector(7 downto 0)
);
end mode_display;
architecture rtl of mode_display is
begin
process(clk)
begin
if rising_edge(clk) then
if mode = '0' then
mode_seg <= "11000111"; -- "L" для Logic
else
mode_seg <= "10100001"; -- "d" для DSP
end if;
end if;
end process;
end rtl;
library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
entity operand_init is
port (
clk : in std_logic;
a_val : out std_logic_vector(7 downto 0);
b_val : out std_logic_vector(7 downto 0)
);
end operand_init;
architecture rtl of operand_init is
begin
a_val <= "00001010";
b_val <= "00011001";
end rtl;
library ieee;
use ieee.std_logic_1164.all;
entity res_reg is
generic (
HOLD_VALUE : boolean := false
);
port (
clk : in std_logic;
slow : in std_logic;
clear : in std_logic;
value_in : in std_logic_vector(15 downto 0);
value_out : out std_logic_vector(15 downto 0) := (others => '0')
);
end res_reg;
architecture rtl of res_reg is
begin
process(clk)
begin
if rising_edge(clk) then
if clear = '0' then
value_out <= (others => '0');
else
if HOLD_VALUE = false then
value_out <= value_in;
else
if slow = '1' then
value_out <= value_in;
end if;
end if;
end if;
end if;
end process;
end rtl;