signal restart_fpga_counter : unsigned(11 downto 0) := x"000";
signal last_reset : std_logic := '0';
signal last_delayed_restart_fpga : std_logic;
+ signal last_DO_REBOOT : std_logic;
+
begin
PROC_REBOOT : process
-- restart_fpga_counter <= x"000";
-- end if;
-- else
+ last_DO_REBOOT <= DO_REBOOT;
delayed_restart_fpga <= '0';
PREPARE_FOR_RELOAD <= '0';
- if DO_REBOOT = '1' or (RESET = '0' and last_reset = '1' and REBOOT_ON_RESET = '1') then
+ if (DO_REBOOT = '1' and last_DO_REBOOT = '0') or (RESET = '0' and last_reset = '1' and REBOOT_ON_RESET = '1') then
restart_fpga_counter <= x"001";
elsif restart_fpga_counter /= x"000" then
restart_fpga_counter <= restart_fpga_counter + 1;