signal delayed_restart_fpga : std_logic := '0';
signal restart_fpga_counter : unsigned(11 downto 0);
-
+ signal last_reset : std_logic := '0';
begin
PROC_REBOOT : process
begin
wait until rising_edge(CLK);
- if RESET = '1' then
+ last_reset <= RESET;
+
+ if RESET = '0' and last_reset = '1' then
delayed_restart_fpga <= REBOOT_ON_RESET;
restart_fpga_counter <= x"000";
else
restart_fpga_counter <= x"001";
elsif restart_fpga_counter /= x"000" then
restart_fpga_counter <= restart_fpga_counter + 1;
- if restart_fpga_counter >= x"800" then
+ if restart_fpga_counter >= x"a00" then
PREPARE_FOR_RELOAD <= '1';
end if;
if restart_fpga_counter >= x"F00" then