``` entity XXX is port (Clock : in Std_logic; Reset : in Std_logic; Enable: in Std_logic; Load : in Std_logic; Mode : in Std_logic; Data : in Std_logic_vector(7 downto 0); X : out Std_logic_vector(7 downto 0)); end; ``` | Enable | Load | Mode | Х | |--------|------|------|---| | 0 | 0 | 0 | | | 0 | 0 | 1 | | | 0 | 1 | 0 | | | 0 | 1 | 1 | | | 1 | 0 | 0 | | | 1 | 0 | 1 | | | 1 | 1 | 0 | | | 1 | 1 | 1 | | ## **TASK** Fill in what X is based on the input signals (in the table) How many FF's are created here? What type of circuit is this / What does it do? ``` architecture when else function of XXX is constant zero byte: std_logic_vector(7 downto 0) := "000000000"; : Unsigned(7 downto 0); signal Q function dec count (input: Unsigned) return Unsigned is constant decade max : Unsigned(3 downto 0) := "1001"; constant zero nibble: Unsigned(3 downto 0) := "0000"; variable output : unsigned(input'range); begin output := when input(3 downto 0) /= decade max else input + 1 (input(7 downto 4) + 1) & zero nibble when input(7 downto 4) /= decade max else unsigned(zero byte); return output; end function dec count; begin Q <= unsigned(X) when Enable unsigned(Data) when not Load else unsigned(X) + 1 when not Mode else dec count(unsigned(X)); X <= zero byte when not reset else std logic vector(Q) when rising edge(Clock); end: ```