VHDL - my FSM does not advance when in a certain state - rsa
I'm trying to implement a circuit for a digital signature (RSA) on a FPGA Digilent Basys.
I ended to write down all the components and the top level entity. The Control Unit is formed by a Finit State Machine that controls the whole circuit.
But when I load it on my Basys, it seems to freeze in the State "V_wait_sign".
I can say that because how you can see in the FSM, in the state "V_wait_sign" I puts Leds out to "00100", so just the Led2 is On.
Below the code of the Top Level Entity and the FSM:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity FirmaDigitale is
Port ( Clock : in STD_LOGIC;
Buttons : in STD_LOGIC_VECTOR (3 downto 0);
Switches : in STD_LOGIC_VECTOR (7 downto 0);
Leds : out STD_LOGIC_VECTOR (7 downto 0);
Cathodes : out STD_LOGIC_VECTOR (7 downto 0);
Anodes : out STD_LOGIC_VECTOR (3 downto 0));
end FirmaDigitale;
architecture Structural of FirmaDigitale is
component Comparator32
Generic(width : Positive := 32);
Port ( a : in STD_LOGIC_VECTOR (width-1 downto 0);
b : in STD_LOGIC_VECTOR (width-1 downto 0);
Clock : in STD_LOGIC;
Comp_en : in STD_LOGIC; -- 1 attivo
equal : out STD_LOGIC;
Notequal : out STD_LOGIC);
end component;
component Decoder_2_4
Port ( i : in STD_LOGIC_VECTOR (1 downto 0);
o : out STD_LOGIC_VECTOR (3 downto 0));
end component;
component Decoder_Seven_segm
Port ( Ing : in STD_LOGIC_VECTOR (3 downto 0);
Cathodes : out STD_LOGIC_VECTOR (6 downto 0));
end component;
component FSM_RSA
Port (
Clock : in STD_LOGIC; -- Clock
--in
Start_sign : in STD_LOGIC; --start sign
Load : in STD_LOGIC; --load 8 bits
Verify : in STD_LOGIC; --start verify signature
Done : in STD_LOGIC; --end message
Exp_Done : in STD_LOGIC; --end exp operation
Count_hit :in STD_LOGIC; --signature load
Count_eq :in STD_LOGIC; --
Count_neq :in STD_LOGIC; --
--control
Enable_Hash : out STD_LOGIC; -- Enable hash '0' attivo (2colpi)
Enable_Exp : out STD_LOGIC; -- Enable exp '1' attivo
Enable_RegExp : out STD_LOGIC; -- Enable RegExp '0' attivo
Enable_sign_reg : out STD_LOGIC; -- Enable sign_reg '0' attivo
Enable_comp : out STD_LOGIC; -- Enable Comparator '1' attivo
Enable_Disp : out STD_LOGIC_VECTOR(3 downto 0); -- Enable 7segm '0' attivo
Leds_step : out STD_LOGIC_VECTOR(4 downto 0);
Mux_sel : out STD_LOGIC; -- 1 per verifica, 0 per firma
Mux_disp : out STD_LOGIC; -- 1 MSB, 0 LSB
Reset_State : out STD_LOGIC -- Reset '0' attivo
);
end component;
component HashFunction
Generic( width : integer := 32; width_reg : integer := 8);
Port ( CharacterByte : in STD_LOGIC_VECTOR(width_reg-1 downto 0);
Clock : in STD_LOGIC;
Reset : in STD_LOGIC; --0 attivo
Reg_en : in STD_LOGIC; --0 attivo
Digest : out STD_LOGIC_VECTOR(width-1 downto 0)
);
end component;
component Mux_2n_1n
Generic(width : integer := 8);
Port ( a : in STD_LOGIC_VECTOR(width-1 downto 0);
b : in STD_LOGIC_VECTOR(width-1 downto 0);
s : in STD_LOGIC;
o : out STD_LOGIC_VECTOR(width-1 downto 0));
end component;
component RAsync_2UpNCount_UpCounter
Generic (width : integer := 2);
Port ( clock : in STD_LOGIC; -- Clock
reset : in STD_LOGIC; -- Segnale di reset 0 attivo
en : in STD_LOGIC; -- Segnale di enable 1 attivo
count : out STD_LOGIC_VECTOR (width-1 downto 0) := (others => '0')); -- conteggio attuale
end component;
component SignReg
Generic( width : integer := 32; width_reg : integer := 8 );
Port ( SignatureByte : in STD_LOGIC_VECTOR (width_reg-1 downto 0);
Reset : in STD_LOGIC;
Count_En : in STD_LOGIC;
Clock : in STD_LOGIC;
hit : out STD_LOGIC;
Signature : out STD_LOGIC_VECTOR (width-1 downto 0));
end component;
component exponentiator
Generic (n : integer := 32);
Port (
x, y, m: in std_logic_vector(n-1 downto 0);
z: inout std_logic_vector(n-1 downto 0);
clk, reset, start: in std_logic;
done: out std_logic
);
end component;
component display_7_segments
Generic(
clock_frequency_in : integer := 50000000;
clock_frequency_out : integer := 50000000
);
Port ( clock : in STD_LOGIC;
reset_n : in STD_LOGIC;
digits : in STD_LOGIC_VECTOR (15 downto 0);
enable : in STD_LOGIC_VECTOR (3 downto 0);
dots : in STD_LOGIC_VECTOR (3 downto 0);
anodes : out STD_LOGIC_VECTOR (3 downto 0);
cathodes : out STD_LOGIC_VECTOR (7 downto 0));
end component;
component Debouncer_xilinx is
Port ( CLK : in STD_LOGIC;
Sig : in STD_LOGIC;
Deb_Sig : out STD_LOGIC);
end component;
signal temp_exp_done, temp_enable_exp, sel_muxTo_display, temp_count_hit, temp_sel_EncDec, temp_comp_en, temp_eq, temp_not_eq, temp_en_RegExp : STD_LOGIC := '0';
signal temp_reset_state, temp_enable_hash, temp_en_SignReg : STD_LOGIC := '1';
signal temp_digest, temp_exp_out, temp_key, temp_sign, Exp_mux_out, RegExp_out : STD_LOGIC_VECTOR(31 downto 0) := (others => '0');
signal temp_enable_disp : STD_LOGIC_VECTOR(3 downto 0) := (others => '0');
signal temp_digits, temp_digits_to_display, temp_fin_digits : STD_LOGIC_VECTOR(15 downto 0);
signal Start_temp, Load_temp, Verify_temp, Done_temp : STD_LOGIC;
begin
deb_0: Debouncer_xilinx
port map(
CLK => Clock,
Sig => Buttons(0),
Deb_Sig => Start_temp
);
deb_1: Debouncer_xilinx
port map(
CLK => Clock,
Sig => Buttons(1),
Deb_Sig => Load_temp
);
deb_2: Debouncer_xilinx
port map(
CLK => Clock,
Sig => Buttons(2),
Deb_Sig => Verify_temp
);
deb_3: Debouncer_xilinx
port map(
CLK => Clock,
Sig => Buttons(3),
Deb_Sig => Done_temp
);
FSM: FSM_RSA
Port map (
Clock => Clock,
Start_sign => Start_temp,
Load => Load_temp, --load 8 bits
Verify => Verify_temp,
Done => Done_temp,
Exp_Done => temp_exp_done,
Count_hit => temp_count_hit,
Count_eq => temp_eq,
Count_neq => temp_not_eq,
--control
Enable_Hash => temp_enable_hash,
Enable_Exp => temp_enable_exp,
Enable_RegExp => temp_en_RegExp,
Enable_sign_reg => temp_en_SignReg,
Enable_comp => temp_comp_en,
Enable_Disp => temp_enable_disp,
Leds_step => Leds(4 downto 0),
Mux_sel => temp_sel_EncDec,
Mux_disp => sel_muxTo_display,
Reset_State => temp_reset_state
);
RegExp : entity work.Generic_RAsync_Register
generic map (width => 32)
port map (
D=> temp_exp_out,
clock => Clock,
reset => temp_reset_state,
en => temp_en_RegExp,
Q => RegExp_out
);
EncriptDecript: exponentiator
Generic map(n => 32)
Port map( x => temp_key,
y => Exp_mux_out,
m => x"0000008F", --143, p=11, q=13; pq=143
z => temp_exp_out,
clk => Clock,
reset => not temp_reset_state,
start => temp_enable_exp,
done => temp_exp_done
);
Leds(7) <= temp_exp_done;
Mux_Enc_Dec: Mux_2n_1n
Generic map(width => 32)
Port map( a => x"00000071", --113, Chiave Privata
b => x"00000011", --17, Chiave Pubblica
s => temp_sel_EncDec,
o => temp_key
);
RegistroFirma: SignReg
Generic map( width => 32, width_reg => 8 )
Port map( SignatureByte => Switches,
Reset => temp_reset_state,
Count_En => temp_en_SignReg,
Clock => Clock,
hit => temp_count_hit,
Signature => temp_sign
);
Exp_mux : Mux_2n_1n generic map (width => 32)
port map(
a => temp_digest,
b => temp_sign,
s => temp_sel_EncDec,
o => Exp_mux_out
);
HASH: HashFunction
Generic map( width => 32, width_reg => 8)
Port map( CharacterByte => Switches,
Clock => Clock,
Reset => temp_reset_state,
Reg_en => temp_enable_hash,
Digest => temp_digest
);
Display: display_7_segments
Generic map( clock_frequency_in => 50000000, clock_frequency_out => 1000 )
Port map( clock => Clock,
reset_n => temp_reset_state,
digits => temp_digits,
enable => temp_enable_disp,
dots => "0000",
anodes => Anodes,
cathodes => Cathodes
);
Mux_MSB_LSB: Mux_2n_1n
Generic map(width => 16)
Port map( a => RegExp_out(15 downto 0),
b => RegExp_out(31 downto 16),
s => sel_muxTo_display,
o => temp_digits
);
Compare: Comparator32
Generic map( width => 32 )
Port map( a => RegExp_out,
b => temp_sign,
Clock => Clock,
Comp_en => temp_comp_en,
equal => temp_eq,
Notequal => temp_not_eq
);
Leds(6) <= temp_eq;
Leds(5) <= temp_not_eq;
end Structural;
this is the FSM instead:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity FSM_RSA is
Port (
Clock : in STD_LOGIC; -- Clock
--in
Start_sign : in STD_LOGIC; --start sign
Load : in STD_LOGIC; --load 8 bits
Verify : in STD_LOGIC; --start verify signature
Done : in STD_LOGIC; --end message
Exp_Done : in STD_LOGIC; --end exp operation
Count_hit :in STD_LOGIC; --signature load
Count_eq :in STD_LOGIC; --
Count_neq :in STD_LOGIC; --
--control
Enable_Hash : out STD_LOGIC; -- Enable hash '0' attivo (2colpi)
Enable_Exp : out STD_LOGIC; -- Enable exp '1' attivo
Enable_RegExp : out STD_LOGIC; -- Enable RegExp '0' attivo
Enable_sign_reg : out STD_LOGIC; -- Enable sign_reg '0' attivo
Enable_comp : out STD_LOGIC; -- Enable Comparator '1' attivo
Enable_Disp : out STD_LOGIC_VECTOR(3 downto 0); -- Enable 7segm '0' attivo
Leds_step : out STD_LOGIC_VECTOR(4 downto 0);
Mux_sel : out STD_LOGIC; -- 1 per verifica, 0 per firma
Mux_disp : out STD_LOGIC; -- 1 MSB, 0 LSB
Reset_State : out STD_LOGIC -- Reset '0' attivo
);
end FSM_RSA;
architecture Behavioral of FSM_RSA is
-- Definizione dell'insieme degli stati
type State is (Idle, V_wait8, S_wait8, V_Hash,V_waitReg, V_waitH, S_waitH, S_Hash, V_wait_sign, V_decrypt, V_comp, V_reg, S_encrypt, S_dispMSB, S_dispLSB);
-- Definizione dei segnali di "stato" e inizializzazione allo stato iniziale idle
signal Current_State, Next_State : State := Idle;
begin
-- Process per la gestione dell'evoluzione dello stato
state_management : process(Clock)
begin
if falling_edge(Clock) then
Current_State <= Next_State;
else
Current_State <= Current_State;
end if;
end process;
-- Process per la gestione della FSM
FSM : process(Current_State, Start_sign, Load, Verify, Done, Exp_Done, Count_eq, Count_neq, Count_hit)
begin
case Current_State is
--macchina in attesa di comandi. Tutti i registri disabilitati
when Idle =>
Enable_Hash <= '1';
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '0';
Mux_sel <= '0';
Mux_disp <= '0';
Leds_step <= "00000";
if (Verify = '1') then
Next_State <= V_wait8;
else
if ( Start_sign ='1') then
Next_state <= S_wait8;
else
Next_state <= Idle;
end if;
end if;
when S_encrypt =>
Enable_Hash <= '1';
Enable_Exp <= '1'; -- abilito
Enable_RegExp <= '0'; -- abilito
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0'; --decript M_h**d modn
Mux_disp <= '0';
Leds_step <= "00010";
if (Exp_Done = '1') then
Next_State <= S_dispMSB;
else
Next_state <= S_encrypt;
end if;
when S_dispLSB =>
Enable_Hash <= '1';
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "1111"; -- abilito
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0'; --LSB
if (Done = '1') then
Next_State <= Idle;
else
Next_state <=S_dispLSB;
end if;
when S_dispMSB =>
Enable_Hash <= '1';
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "1111"; -- abilito
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '1'; --MSB
if (Load = '1') then
Next_State <= S_dispLSB;
else
Next_state <=S_dispMSB;
end if;
when S_waitH =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
if( Load = '0') then
Next_State <= S_wait8;
else
Next_State <= S_waitH;
end if;
when S_Hash =>
Enable_Hash <= '0'; -- abilito
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
Next_State <= S_waitH;
when S_wait8 =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
Leds_step <= "00001";
if (Done = '1') then
Next_State <= S_encrypt;
else
if ( Load = '1') then
Next_state <= S_Hash;
else
Next_state <= S_wait8;
end if;
end if;
when V_comp =>
Enable_Hash <= '1';
Enable_Exp <= '0';
Enable_RegExp <= '0';
Enable_sign_reg <= '1';
Enable_comp <= '1'; -- abilito
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '1'; --decript M_h**e modn
Mux_disp <= '0';
Leds_step <= "10000";
if (Count_eq = '1' OR Count_neq ='1') then
if (Done = '1') then
Next_State <= Idle;
end if;
end if;
when V_decrypt =>
Enable_Hash <= '1';
Enable_Exp <= '1'; -- abilito
Enable_RegExp <= '0'; -- abilito
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '1'; --decript M_h**e modn
Mux_disp <= '0';
Leds_step <= "01000";
if (Exp_Done = '1') then
Next_State <= V_comp;
else
Next_state <= V_decrypt;
end if;
when V_Reg =>
Enable_Hash <= '1';
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '0'; -- abilito
Enable_comp <= '0';
Enable_Disp <= "1111";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
if( Count_hit = '1') then
Next_State <= V_decrypt;
else
Next_State <= V_waitReg;
end if;
when V_waitReg =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
if( Load = '0') then
Next_State <= V_wait_sign;
else
Next_State <= V_waitReg;
end if;
when V_wait8 =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
if (Done = '1') then
Next_State <= V_wait_sign;
else
if ( Load = '1') then
Next_state <= V_Hash;
else
Next_state <= V_wait8;
end if;
end if;
when V_Hash =>
Enable_Hash <= '0'; -- abilito
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Mux_disp <= '0';
Next_State <= V_waitH;
when V_waitH =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
if( Load = '0') then
Next_State <= V_wait8;
else
Next_State <= V_waitH;
end if;
when V_wait_sign =>
Enable_Hash <= '1'; --disabilito tutto
Enable_Exp <= '0';
Enable_RegExp <= '1';
Enable_sign_reg <= '1';
Enable_comp <= '0';
Enable_Disp <= "0000";
Reset_State <= '1';
Mux_sel <= '0';
Leds_step <= "00100";
if (Load = '1') then -- AND Count_hit = '0') then
Next_State <= V_reg;
-- else
-- if (Count_hit = '1') then
-- Next_state <= V_decrypt;
else
Next_state <= V_wait_sign;
--end if;
end if;
end case;
end process;
end Behavioral;
I can't understand what could be wrong. When I try the testbench, it seems to work.
But tjan on the FPGA it freezes on that state. It is as if he did not receive the signal "Count Hit" from the "SignReg". But I'm not sure about that
Related
(vhdl) expected type = current type type error
I keep getting an error that says: line 25: type error near num_values ; current type unsigned; expected type unsigned. It is already the type that is supposed to be, and I think it is same in bit length and declared alright, what am I doing wrong here? The code is about implementation of fifo queue structure. <Queue.vhd> library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity Queue is port ( -- clock clk: in std_logic; -- input push: in std_logic; push_data: in std_logic_vector(31 downto 0); pop: in std_logic; -- output pop_data: out std_logic_vector(31 downto 0); num_values: out unsigned(31 downto 0) ); end entity; architecture Behavioral of Queue is type items is array(0 to 31) of std_logic_vector(31 downto 0); signal manager : items := (others => (others => '0')); signal push_idx, pop_idx : integer := 0; begin process(clk) is variable howmany : integer := 0; begin if rising_edge(clk) then if (push = '1') then manager(push_idx) <= push_data; push_idx <= push_idx + 1; howmany := howmany + 1; end if; if (pop = '1') then if (howmany /= 0) then pop_data <= manager(pop_idx); pop_idx <= pop_idx + 1; howmany := howmany - 1; end if; else pop_data <= std_logic_vector(to_unsigned(0,pop_data'length)); end if; if (push_idx = 31) then push_idx <= 0; end if; if (pop_idx = 31) then pop_idx <= 0; end if; num_values <= to_unsigned(howmany,32); end if; end process; end architecture; <QueueTb.vhd> library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_arith.all; entity QueueTb is end entity; architecture sim of QueueTb is constant ClockFrequency : integer := 100e6; constant ClockPeriod : time := 1000ms / ClockFrequency; signal clk : std_logic := '0'; signal push, pop : std_logic := '0'; signal num_values : unsigned(31 downto 0); signal push_data, pop_data : std_logic_vector(31 downto 0) := (others =>'0'); begin UUT : entity work.Queue(Behavioral) port map( clk => clk, push => push, pop => pop, num_values => num_values, <=== this is where error occurs! push_data => push_data, pop_data => pop_data); clk <= not clk after ClockPeriod / 2; process is begin wait for 10 ns; push <= '1'; push_data <= conv_std_logic_vector(123,32); wait for 10 ns; push_data <= conv_std_logic_vector(456,32); wait for 10 ns; push <= '0'; push_data <= conv_std_logic_vector(0,32); pop <= '1'; wait for 10 ns; pop <= '0'; push <= '1'; push_data <= conv_std_logic_vector(789,32); wait for 10 ns; push <= '0'; pop <= '1'; wait for 80 ns; end process; end architecture; What am I doing wrong here??
In the Queue entity you are using ieee.numeric_std and in the QueueTB you are using ieee.std_logic_arith . Both define different unsigned types. Delete std_logic_arith from the testbench as it is not a standard VHDL library and use numeric_std instead.
SystemVerilog error: "already exists; must not be redefined as a named block"
I'm creating a state machine with implicit datapath and am getting three errors that I haven't been able to resolve. For the endcase error, I've made sure that all the begins have a corresponding end in the always block. For the Finish error, the state has only been defined once so I'm not sure about that. For the ; error, I have no idea why it doesn't want me to include countx and county statements. Any help would be appreciated! module fillscreen(input logic clk, input logic rst_n, input logic [2:0] colour, input logic start, output logic done, output logic [7:0] vga_x, output logic [6:0] vga_y, output logic [2:0] vga_colour, output logic vga_plot); enum logic [1:0] {Load = 2'b00, Increment = 2'b01, Out = 2'b10, Finish = 2'b11} state, next_state; logic [7:0] countx, county; always # (posedge clk) begin case(state) Load: if(rst_n == 0) next_state <= Load; else if (start == 1) next_state <= Increment; else begin next_state <= Load; end //initialize counter countx <= 0; county <= 0; Increment: if(rst_n == 0) next_state <= Load; else if (county < 119 && countx < 159) begin county <= county+1; next_state <= Increment; end else if (countx < 159) begin countx <= countx +1; next_state <= Increment; end else next_state <= Finish; //output vga_y <= county; vga_x <= countx; vga_colour <= countx % 8; vga_plot <= 1; Finish: done <= 1; if(rst_n == 0) next_state <= Load; else begin next_state = Finish; end Default: vga_y <= county; vga_x <= countx; done <= 0; vga_plot <= 0; endcase end endmodule Here are the errors I'm getting: ** Error: fillscreen.sv(22): near ";": syntax error, unexpected ';', expecting ':' ** Error: fillscreen.sv(54): near "endcase": syntax error, unexpected endcase ** Error: fillscreen.sv(25): 'Increment' already exists; must not be redefined as a named block ** Error fillscreen.sv(43): 'Finish' already exists; must not be redefined as a named block
For any case, you need to include begin..end if the code block for that case has multiple lines, just like if-statements or always blocks (see comments inline, there more than just missing begin..end): case(state) // <- Note, you never assign state, only next_state, might want to review your code for correctness Load: begin // <- This case has multiple lines if (rst_n == 0) begin // <- I do begin..end for EVERYTHING as I inevitably come back and add lines in the body which can lead to bugs if there is no begin..end, like {..} in C next_state <= Load; end else if (start == 1) begin next_state <= Increment; end else begin next_state <= Load; end //initialize counter countx <= 0; county <= 0; end Increment: begin if (rst_n == 0) begin next_state <= Load; end else if (county < 119 && countx < 159) begin county <= county+1; next_state <= Increment; end else if (countx < 159) begin countx <= countx +1; next_state <= Increment; end else begin next_state <= Finish; end //output vga_y <= county; vga_x <= countx; vga_colour <= countx % 8; vga_plot <= 1; end Finish: begin done <= 1; if (rst_n == 0) begin next_state <= Load; end else begin next_state <= Finish; // Should be non-blocking end end default: begin // <- Should be lower-case "default" vga_y <= county; vga_x <= countx; done <= 0; vga_plot <= 0; end endcase
Problems synthesizing MIG 7 series for arty board external DDR3 memory (VHDL)
I'm trying to use the DDR3 memory component on my Arty board (https://reference.digilentinc.com/reference/programmable-logic/arty/reference-manual?redirect=1), which have the MT41K128M16JT-125 memory part from Micron. The FPGA is an Artix-7 xc7a35ticsg324-1L. I've implemented my project in VHDL, and have been using the MIG IP to generate an example project, from which I have written my own "top_level.vhd"-file. In the "top_level.vhd"-file, the components UART_RX and UART_TX are for transmitting bytes of data using the UART, and the component mig_7series_o, have been generated by the MIG tool. I've split my question up into smaller segments: 1) As far as I have understood it, the MIG will generate the clock signals itself, and supply me with a clock signal ui_clk, which in my code is called clk. But when the code is synthesized, I suspect that the clock signal does not work as it should, and this leads my whole design to not work at all. Could anyone give me an idea on how to make the clock work as it should? 2) Furthermore I can't simulate my design, as I don't have a model for the RAM, but as far as I've understood it, my design would have to be in Verilog, in order to use Microns RAM simulation models, which it is not. This have lead me to the situation, that I have to synthesize the design in order to check if it works, which makes debugging it quite hard. 3) Or is there perhaps someone out there, who have a working interface on the arty board (Or a similar board), who would be so kind to share the module for interfacing with the DDR3 RAM? library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.NUMERIC_STD.ALL; -- Uncomment the following library declaration if using -- arithmetic functions with Signed or Unsigned values --use IEEE.NUMERIC_STD.ALL; -- Uncomment the following library declaration if instantiating -- any Xilinx leaf cells in this code. --library UNISIM; --use UNISIM.VComponents.all; entity top_level is Port ( -- Inouts ddr3_dq : inout std_logic_vector(31 downto 0); ddr3_dqs_p : inout std_logic_vector(3 downto 0); ddr3_dqs_n : inout std_logic_vector(3 downto 0); -- Outputs ddr3_addr : out std_logic_vector(13 downto 0); ddr3_ba : out std_logic_vector(2 downto 0); ddr3_ras_n : out std_logic; ddr3_cas_n : out std_logic; ddr3_we_n : out std_logic; ddr3_reset_n : out std_logic; ddr3_ck_p : out std_logic_vector(0 downto 0); ddr3_ck_n : out std_logic_vector(0 downto 0); ddr3_cke : out std_logic_vector(0 downto 0); ddr3_cs_n : out std_logic_vector(0 downto 0); ddr3_dm : out std_logic_vector(3 downto 0); ddr3_odt : out std_logic_vector(0 downto 0); -- Inputs -- Differential system clocks sys_clk_p : in std_logic; sys_clk_n : in std_logic; -- differential iodelayctrl clk (reference clock) clk_ref_p : in std_logic; clk_ref_n : in std_logic; tg_compare_error : out std_logic; init_calib_complete : out std_logic; -- System reset - Default polarity of sys_rst pin is Active Low. -- System reset polarity will change based on the option -- selected in GUI. sys_rst : in std_logic; led1 : out std_logic; led2 : out std_logic; but : in std_logic_vector(3 downto 0); rx_bit : in std_logic; tx_bit : out std_logic --test_clock : in std_logic ); end top_level; architecture Behavioral of top_level is component UART_RX generic ( g_CLKS_PER_BIT : integer := 723 -- Needs to be set correctly ); port ( i_Clk : in std_logic; i_RX_Serial : in std_logic; o_RX_DV : out std_logic; o_RX_Byte : out std_logic_vector(7 downto 0) ); end component; component UART_TX generic ( g_CLKS_PER_BIT : integer := 723 -- Needs to be set correctly ); port ( i_Clk : in std_logic; i_TX_DV : in std_logic; i_TX_Byte : in std_logic_vector(7 downto 0); o_TX_Active : out std_logic; o_TX_Serial : out std_logic; o_TX_Done : out std_logic ); end component; component mig_7series_0 port( ddr3_dq : inout std_logic_vector(31 downto 0); ddr3_dqs_p : inout std_logic_vector(3 downto 0); ddr3_dqs_n : inout std_logic_vector(3 downto 0); ddr3_addr : out std_logic_vector(13 downto 0); ddr3_ba : out std_logic_vector(2 downto 0); ddr3_ras_n : out std_logic; ddr3_cas_n : out std_logic; ddr3_we_n : out std_logic; ddr3_reset_n : out std_logic; ddr3_ck_p : out std_logic_vector(0 downto 0); ddr3_ck_n : out std_logic_vector(0 downto 0); ddr3_cke : out std_logic_vector(0 downto 0); ddr3_cs_n : out std_logic_vector(0 downto 0); ddr3_dm : out std_logic_vector(3 downto 0); ddr3_odt : out std_logic_vector(0 downto 0); app_addr : in std_logic_vector(27 downto 0); app_cmd : in std_logic_vector(2 downto 0); app_en : in std_logic; app_wdf_data : in std_logic_vector(255 downto 0); app_wdf_end : in std_logic; app_wdf_mask : in std_logic_vector(31 downto 0); app_wdf_wren : in std_logic; app_rd_data : out std_logic_vector(255 downto 0); app_rd_data_end : out std_logic; app_rd_data_valid : out std_logic; app_rdy : out std_logic; app_wdf_rdy : out std_logic; app_sr_req : in std_logic; app_ref_req : in std_logic; app_zq_req : in std_logic; app_sr_active : out std_logic; app_ref_ack : out std_logic; app_zq_ack : out std_logic; ui_clk : out std_logic; ui_clk_sync_rst : out std_logic; init_calib_complete : out std_logic; -- System Clock Ports sys_clk_p : in std_logic; sys_clk_n : in std_logic; -- Reference Clock Ports clk_ref_p : in std_logic; clk_ref_n : in std_logic; device_temp : out std_logic_vector(11 downto 0); sys_rst : in std_logic ); end component mig_7series_0; constant DATA_WIDTH : integer := 32; constant PAYLOAD_WIDTH : integer := DATA_WIDTH; constant nCK_PER_CLK : integer := 4; constant ADDR_WIDTH : integer := 28; constant APP_DATA_WIDTH : integer := 2*nCK_PER_CLK * PAYLOAD_WIDTH; constant APP_MASK_WIDTH : integer := APP_DATA_WIDTH / 8; signal app_addr : std_logic_vector(ADDR_WIDTH-1 downto 0); signal init_calib_complete_i : std_logic; signal device_temp : std_logic_vector(11 downto 0); signal app_cmd : std_logic_vector(2 downto 0); signal app_en : std_logic; signal app_rdy : std_logic; signal app_wdf_data : std_logic_vector(APP_DATA_WIDTH-1 downto 0); signal app_wdf_end : std_logic; signal app_ref_ack : std_logic; signal app_zq_ack : std_logic; signal app_wdf_wren : std_logic; signal app_rd_data : std_logic_vector(APP_DATA_WIDTH-1 downto 0); signal app_rd_data_end : std_logic; signal app_rd_data_valid : std_logic; signal app_wdf_mask : std_logic_vector(APP_MASK_WIDTH-1 downto 0); signal app_wdf_rdy : std_logic; signal app_sr_active : std_logic; signal clk : std_logic; --Mine signaler type state_type is (reset, init, idle, prep_write, do_write, do_wait_after_write, prep_read, do_read, do_wait_after_read, clean_up, end_state); signal state : state_type; type init_state_type is (step1, step2, step3, step4); signal init_state : init_state_type; signal init_count : integer range 0 to 127 := 0; constant c_CLKS_PER_BIT : integer := 723; signal tx_done, rx_dv, tx_active, tx_dv, wait_for_tx_done, wait_for_but_release : STD_LOGIC; signal tx_byte, rx_byte : STD_LOGIC_VECTOR(7 downto 0); signal count : integer range 0 to 127 := 0; signal data_read : std_logic_vector(31 downto 0); signal first_init : std_logic := '1'; signal sys_rst_test, rst : std_logic := '1'; begin x2: UART_RX generic map ( g_CLKS_PER_BIT => c_CLKS_PER_BIT ) port map( i_Clk => clk, i_RX_Serial => rx_bit, o_RX_DV => rx_dv, o_RX_Byte => rx_byte); x3: UART_TX generic map ( g_CLKS_PER_BIT => c_CLKS_PER_BIT ) port map( i_Clk => clk, i_TX_DV => tx_dv, i_TX_Byte => tx_byte, o_TX_Active => tx_active, o_TX_Serial => tx_bit, o_TX_Done => tx_done); u_mig_7series_0 : mig_7series_0 port map ( -- Memory interface ports ddr3_addr => ddr3_addr, ddr3_ba => ddr3_ba, ddr3_cas_n => ddr3_cas_n, ddr3_ck_n => ddr3_ck_n, ddr3_ck_p => ddr3_ck_p, ddr3_cke => ddr3_cke, ddr3_ras_n => ddr3_ras_n, ddr3_reset_n => ddr3_reset_n, ddr3_we_n => ddr3_we_n, ddr3_dq => ddr3_dq, ddr3_dqs_n => ddr3_dqs_n, ddr3_dqs_p => ddr3_dqs_p, init_calib_complete => init_calib_complete_i, device_temp => device_temp, ddr3_cs_n => ddr3_cs_n, ddr3_dm => ddr3_dm, ddr3_odt => ddr3_odt, -- Application interface ports app_addr => app_addr, app_cmd => app_cmd, app_en => app_en, app_wdf_data => app_wdf_data, app_wdf_end => app_wdf_end, app_wdf_wren => app_wdf_wren, app_rd_data => app_rd_data, app_rd_data_end => app_rd_data_end, app_rd_data_valid => app_rd_data_valid, app_rdy => app_rdy, app_wdf_rdy => app_wdf_rdy, app_sr_req => '0', app_ref_req => '0', app_zq_req => '0', app_sr_active => app_sr_active, app_ref_ack => app_ref_ack, app_zq_ack => app_zq_ack, ui_clk => clk, ui_clk_sync_rst => rst, app_wdf_mask => app_wdf_mask, -- System Clock Ports sys_clk_p => sys_clk_p, sys_clk_n => sys_clk_n, -- Reference Clock Ports clk_ref_p => clk_ref_p, clk_ref_n => clk_ref_n, sys_rst => sys_rst ); process(clk) begin -- if(rising_edge(clk)) then -- if(but(0) = '1') then -- rst <= '1'; -- end if; -- end if; if(rising_edge(clk)) then case(state) is when reset => --rst <= '1'; led1 <= '0'; led2 <= '0'; state <= init; when init => led2 <= '1'; -- if(count > 20) then -- rst <= '0'; -- else -- count <= count + 1; -- rst <= '1'; -- end if; --rst <= '0'; app_en <= '0'; app_wdf_end <= '0'; app_wdf_wren <= '0'; app_addr <= (others => '0'); app_cmd <= (others => '0'); app_wdf_data <= (others => '0'); app_wdf_mask <= (others => '0'); if(init_calib_complete_i = '1') then --led2 <= '1'; state <= idle; end if; when idle => led1 <= '1'; --led2 <= '1'; tx_dv <= '1'; tx_byte <= X"47"; state <= end_state; when end_state => --led1 <= '1'; --led2 <= '1'; tx_dv <= '0'; when others => state <= idle; end case; end if; end process; end Behavioral;
ModelSim - Simulating Button Presses
I want to use four push buttons as inputs and three seven-segment LED displays as outputs. Two push buttons should step up and down through the sixteen RAM locations; the other two should increment and decrement the contents of the currently-displayed memory location. I am now trying to simulate my design using ModelSim test benches, with button presses. Here is what I believe to be the relevant portions of my code: library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity DE2_TOP is port ( KEY : in std_logic_vector(3 downto 0); -- Push button ); end DE2_TOP; architecture datapath of DE2_TOP is begin U1: entity work.lab1 port map ( key => key, ); end datapath; library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity raminfr is -STANDARD RAM INFERENCE port ( clk : in std_logic; we : in std_logic; a : in unsigned(3 downto 0); di : in unsigned(7 downto 0); do : out unsigned(7 downto 0) ); end raminfr; architecture rtl of raminfr is type ram_type is array (0 to 15) of unsigned(7 downto 0); signal RAM : ram_type; signal read_a : unsigned(3 downto 0); begin process (clk) begin if rising_edge(clk) then if we = '1' then RAM(to_integer(a)) <= di; end if; read_a <= a; end if; end process; do <= RAM(to_integer(read_a)); end rtl; library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity lab1 is port( clock : in std_logic; key : in std_logic_vector(3 downto 0); ); end lab1; architecture up_and_down of lab1 is signal value_in_ram : unsigned(7 downto 0); signal clk : std_logic; signal we : std_logic; signal value_counter : unsigned(7 downto 0) ; signal register_counter : unsigned(3 downto 0); begin U1: entity work.raminfr port map ( a => register_counter, di => value_counter, do => value_in_ram, clk => clk, we => we ); process(clock) begin if rising_edge(clock) then if (key(3)='0' and key(2)='0' and key(1)='1' and key(0)='0') then value_counter <= value_counter + "1"; elsif (key(3)='0' and key(2)='0' and key(1)='0' and key(0)='1') then value_counter <= value_counter - "1"; elsif (key(3)='1' and key(2)='0' and key(1)='0' and key(0)='0') then register_counter<= register_counter + "1"; value_counter <= value_in_ram; elsif (key(3)='0' and key(2)='1' and key(1)='0' and key(0)='0') then register_counter<= register_counter - "1"; value_counter <= value_in_ram; end if; end if; end process; end architecture up_and_down; The problem is that despite initializing "key" (the buttons) in my test bench, ModelSim still lists the object as "UUUU". Here is the code for my test bench, which is located in a separate file: library ieee; use ieee.std_logic_1164.all; entity DE2_TOP_TEST is end; architecture BENCH of DE2_TOP_TEST is signal KEY : std_logic_vector(3 downto 0); begin KEY<="0010"; U1: entity work.DE2_TOP port map ( key=>key, ); end BENCH; Anyone know what's wrong?
You use registers in your design. So you need to add a signal to your clock input: constant tb_clk_period : time := (1 sec) / 10_000_000; -- 10 MHz signal tb_clk : std_ulogic := '0'; ... -- clock generator tb_clk <= not tb_clk after tb_clk_period / 2;
Design for assingning output with the counted value of clock on some condition in VHDL
I'm new to VHDL and confused with this design when Acknwledgement= '1' and clk='1' then count should be count+1; and when Acknwledgement= '0' my total counted value of clocks should be assigned to the 'output' and after that resetting count='0' and output='0'. can anyone help with this. Thanks in advance. EDIT: Code from comment pasted in: library IEEE; use IEEE.STD_LOGIC_1164.all; entity acknw is port (acknw : in std_logic; clk : in std_logic; output : out integer range 0 to 15); end acknw; architecture Behavioral of acknw is begin process(clk, acknw) variable c : integer range 0 to 15; begin if(clk'event and clk = '1') then if(acknw = '1') then c := c+1; output <= c; else c := 0; output <= c; end if; end if; end process; end Behavioral;
from your comment it sounds like you want an asynchronous acknw, try something like this: library IEEE; use IEEE.STD_LOGIC_1164.all; entity acknw is port (acknw : in std_logic; clk : in std_logic; output : out integer range 0 to 15); end acknw; architecture Behavioral of acknw is begin process(clk, acknw) begin if (acknw = '0') then output <= 0; elsif rising_edge(clk) then -- rollover if (output /= 15) then output <= output + 1; else output <= 0; end if; end if; end process; end Behavioral;