

## Learn Git and GitHub without any code!

Using the Hello World guide, you'll start a branch, write comments, and open a pull request.

Read the guide



• Figure or table with connection of push buttons on Nexys A7 board, pins: P17, M17, M18, P18, N17; voltage value: 3.3



• Table with calculated values

| Time<br>interval | Number<br>of clk<br>periods | Number of<br>clk periods<br>in hex | Number of clk periods in binary |
|------------------|-----------------------------|------------------------------------|---------------------------------|
| 2 ms             | 200 000                     | x"3_0d40"                          | b"0011_0000_1101_0100_0000"     |
| 4 ms             | 400 000                     | x"6_1A80"                          | b"0110_0001_1010_1000_0000"     |
| 10 ms            | 1 000<br>000                | x"F4240"                           | b"01111_0100_0010_0100_0000"    |

| Time<br>interval | Number<br>of clk<br>periods | Number of<br>clk periods<br>in hex | Number of clk periods in binary       |  |
|------------------|-----------------------------|------------------------------------|---------------------------------------|--|
| 250 ms           | 25 000<br>000               | x"17D7840"                         | b"10111_1101_0111_1000_0100_0000"     |  |
| 500 ms           | 50 000<br>000               | x"2FAF080"                         | b"0010_1111_1010_1111_0000_1000_0000" |  |
| 1 sec            | 100 000<br>000              | x"5F5_E100"                        | b"0101_1111_0101_1110_0001_0000_0000" |  |
| <b>→</b>         |                             |                                    |                                       |  |

## 2. Bidirectional counter

process cnt\_up\_down

```
p_cnt_up_down : process(clk)
  begin
      if rising_edge(clk) then
          if (reset = '1') then
                                            -- Synchronous reset
              s_cnt_local <= (others => '0'); -- Clear all bits
          elsif (en_i = '1') then
                                    -- Test if counter is enabled
              s_cnt_local <= s_cnt_local + 1;</pre>
              -- TEST COUNTER DIRECTION HERE
          elsif (cnt_up_i = '1') then
              s_cnt_local <= s_cnt_local + 1;</pre>
          end if;
      end if;
  end process p_cnt_up_down;
*testbench
  architecture testbench of tb cnt up down is
      -- Number of bits for testbench counter
      constant c CNT WIDTH : natural := 5;
      constant c_CLK_100MHZ_PERIOD : time := 10 ns;
      --Local signals
      signal s_clk_100MHz : std_logic;
```

```
signal s_reset
                 : std logic;
   signal s en
                 : std logic;
  signal s_cnt_up
                 : std logic;
                 : std_logic_vector(c_CNT_WIDTH - 1 downto 0);
  signal s_cnt
begin
   -- Connecting testbench signals with cnt_up_down entity
   -- (Unit Under Test)
  uut_cnt : entity work.cnt_up_down
      generic map(
        g_CNT_WIDTH => c_CNT_WIDTH
      )
      port map(
        clk
              => s_clk_100MHz,
         reset => s_reset,
        en_i => s_en,
        cnt_up_i => s_cnt_up,
        cnt_o
              => s_cnt
      );
   ______
   -- Clock generation process
   ______
   p_clk_gen : process
  begin
                        -- 75 periods of 100MHz clock
     while now < 750 ns loop
         s_clk_100MHz <= '0';
        wait for c_CLK_100MHZ_PERIOD / 2;
        s clk_100MHz <= '1';
        wait for c_CLK_100MHZ_PERIOD / 2;
     end loop;
     wait;
  end process p_clk_gen;
   ______
   -- Reset generation process
   p reset gen : process
  begin
      s_reset <= '0';
     wait for 12 ns;
     s_reset <= '1';</pre>
                             -- Reset activated
     wait for 73 ns;
      s_reset <= '0';</pre>
     wait;
  end process p_reset_gen;
   -- Data generation process
   ______
  p_stimulus : process
  begin
      report "Stimulus process started" severity note;
            <= '1';
                             -- Enable counting
      s en
```

```
s_cnt_up <= '1';
wait for 380 ns;
    -- Change counter direction
s_cnt_up <= '0';
wait for 220 ns;
s_en <= '0';
    -- Disable counting

report "Stimulus process finished" severity note;
wait;
end process p_stimulus;
end architecture testbench;</pre>
```

## testbench



## 3. Top level

```
architecture Behavioral of top is
    -- Internal clock enable
    signal s_en : std_logic;
    -- Internal counter
    signal s_cnt : std_logic_vector(4 - 1 downto 0);
begin
    -- Instance (copy) of clock_enable entity
    clk_en0 : entity work.clock_enable
        generic map(
            g MAX => 25000000
            --- WRITE YOUR CODE HERE
        port map(
            clk
                   => CLK100MHZ,
                  => BTNC,
            reset
            ce_o
                    => s_en
            --- WRITE YOUR CODE HERE
        );
```

```
-- Instance (copy) of cnt_up_down entity
    bin_cnt0 : entity work.cnt_up_down
        generic map(
            g_CNT_WIDTH => 4
            --- WRITE YOUR CODE HERE
        )
        port map(
            clk
                   => CLK100MHZ,
            reset => BTNC,
            en_i => s_en,
            cnt_up_i \Rightarrow SW(0),
            cnt o => s cnt
            --- WRITE YOUR CODE HERE
        );
    -- Display input value on LEDs
    LED(3 downto 0) <= s_cnt;</pre>
    ______
    -- Instance (copy) of hex_7seg entity
    hex2seg : entity work.hex_7seg
        port map(
            hex_i
                   => s_cnt,
            seg_o(6) \Rightarrow CA,
            seg_o(5) \Rightarrow CB
            seg_o(4) \Rightarrow CC
            seg_o(3) \Rightarrow CD,
            seg_o(2) \Rightarrow CE
            seg_o(1) \Rightarrow CF,
            seg_o(0) \Rightarrow CG
        );
    -- Connect one common anode to 3.3V
    AN <= b"1111_1110";
end architecture Behavioral;
```

