

به نام خدا

عنوان:

تکلیف شماره سوم درس طراحی سیستم های دیجیتال

استاد:

دکتر مروستی

اعضا:

محمدعلی مجتبه‌دلیلیانی - ۹۹۲۰۲۳۰۳۹

تاریخ:

۱۴۰۳/۰۳/۵

**Q1.** for this question first we need a counter that can handle a generic number of decimal digits. Then we use the "for-generate" statement to handle multiple digits. After that we create a test bench to verify 4bit counter. The entity will have this ingredient: **CLK**, **RESET**, **ENABLE** and **COUNT**. For implement this we need an array of signal to hold the value for each digit. Then we use "for-generate" statement. At the end, combine the individual digit values into the final **COUNT** output.

❖**Code:**

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity DecimalCounter is
    generic (
        NUM_DIGITS : integer := 4 -- Number of digits
    );
    Port (
        clk      : in STD_LOGIC;
        rst      : in STD_LOGIC;
        en       : in STD_LOGIC;
        count    : out STD_LOGIC_VECTOR((NUM_DIGITS*4)-1 downto 0) -- Output for the counter
    );
end;
```

```
end DecimalCounter;
```

```
architecture Behavioral of DecimalCounter is
```

```
    type digit_array is array (NUM_DIGITS-1 downto 0) of STD_LOGIC_VECTOR(3 downto 0); -- Array for digits
```

```
    signal digit_values : digit_array := (others => (others => '0'));
```

```
    signal carry_signal : STD_LOGIC_VECTOR(NUM_DIGITS downto 0) := (others => '0');
```

```
begin
```

```
process(clk, rst)
```

```
begin
```

```
    if rst = '1' then
```

```
        digit_values <= (others => (others => '0')); -- Reset all digits
```

```
        carry_signal <= (others => '0');
```

```
    elsif rising_edge(clk) then
```

```
        if en = '1' then
```

```
            carry_signal(0) <= '1'; -- Initial carry to start counting
```

```
            for i in 0 to NUM_DIGITS-1 loop
```

```
                if carry_signal(i) = '1' then
```

```
                    if digit_values(i) = "1001" then
```

```
                        digit_values(i) <= "0000";
```

```
                        carry_signal(i+1) <= '1';
```

```
                else
```

```
                    digit_values(i) <= digit_values(i) + 1;
```

```
    carry_signal(i+1) <= '0';
end if;
end if;
end loop;
end if;
end if;
end process;

-- Concatenate digits into count
process(digit_values)
begin
for i in 0 to NUM_DIGITS-1 loop
    count((i*4)+3 downto i*4) <= digit_values(i);
end loop;
end process;

end Behavioral;
```

# ❖Compilation Report:

Quartus II 64-Bit - D:/DSD-HWs/homework03/question1/DecimalCounter - DecimalCounter

File Edit View Project Assignments Processing Tools Window Help

Search altera.com

Project Navigator Entity Cyclone V: SCGXF7C7F23C8 abd DecimalCounter

Table of Contents Flow Status Successful - Sat May 25 17:04:57 2024

Flow Settings Quartus II 64-Bit Version 13.1.0 Build 162 10/23/2013 SJ Web Edition

Flow Non-Default Global S Revision Name DecimalCounter

Flow Elapsed Time Top-level Entity Name DecimalCounter

Flow OS Summary Family Cyclone V

Flow Log Device SCGXF7C7F23C8

Analysis & Synthesis Timing Models Final

Flow Messages Logic utilization (in ALMs) N/A

Flow Suppressed Message Total registers 20

Total pins 19

Total virtual pins 0

Total block memory bits 0

Total DSP Blocks 0

Total HSSI RX PCGs 0

Total HSSI PMA RX Deserializers 0

Total HSSI TX PCGs 0

Total HSSI TX Channels 0

Total PLLs 0

Total DLLs 0

Tasks

Flow: RTL Simulation Customize...

| Task                   | Time |
|------------------------|------|
| Analysis & Elaboration |      |
| RTL Simulation         |      |

Messages

| Type | ID     | Message                                                                                                                                                  |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Info | 11104  | Command: quartus_map --read_settings_files=on --write_settings_files=off DecimalCounter -c DecimalCounter                                                |
| Info | 11104  | Parallel Compilation has detected 8 hyper-threaded processors. However, the extra hyper-threaded processors will not be used by default. Parallel Compil |
| Info | 12021  | Found 2 design units, including 1 entities, in source file decimalcounter.vhd                                                                            |
| Info | 12127  | Elaborating entity "DecimalCounter" for the top level hierarchy                                                                                          |
| Info | 286030 | Timing-Driven Synthesis is running                                                                                                                       |
| Info | 16010  | Generating hard_block partition "hard_block:auto_generated_inst"                                                                                         |
| Info | 21057  | Implemented 43 device resources after synthesis - the final resource count might be different                                                            |
| Info | 11104  | Quartus II 64-Bit Analysis & Synthesis was successful. 0 errors, 0 warnings                                                                              |

System \ Processing (10) /

100% 00:00:04

## ❖RTL View:





## ❖ Post-mapping:





## ❖Wave Form:







## ❖Test bench code:

```

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity DecimalCounter_tb is
end DecimalCounter_tb;

architecture Behavioral of DecimalCounter_tb is
    constant NUM_DIGITS : integer := 4; -- Number of digits for testing
    signal clk      : STD_LOGIC := '0';

```

```
signal rst    : STD_LOGIC := '0';
signal en     : STD_LOGIC := '0';
signal count   : STD_LOGIC_VECTOR((NUM_DIGITS*4)-1 downto
0);

component DecimalCounter
generic (
  NUM_DIGITS : integer
);
Port (
  clk    : in STD_LOGIC;
  rst    : in STD_LOGIC;
  en     : in STD_LOGIC;
  count   : out STD_LOGIC_VECTOR((NUM_DIGITS*4)-1
downto 0)
);
end component;

begin

UUT: DecimalCounter
generic map (
  NUM_DIGITS => 4 -- Specify 4 digits
```

```
)  
port map (  
    clk => clk,  
    rst => rst,  
    en => en,  
    count => count  
);  
  
-- Clock generation  
clk_process: process  
begin  
    while True loop  
        clk <= '0';  
        wait for 10 ns;  
        clk <= '1';  
        wait for 10 ns;  
    end loop;  
end process;  
  
-- Stimulus process  
stimulus: process  
begin
```

```
-- Apply reset  
rst <= '1';  
wait for 20 ns;  
rst <= '0';  
wait for 20 ns;  
  
-- Enable counting  
en <= '1';  
wait for 500 ns;  
  
-- Disable counting  
en <= '0';  
wait for 20 ns;  
  
wait;  
end process;  
  
end Behavioral;
```

**Q2.** So for this question we should design a FIFO buffer for 64-bit system. We need 8 slots, with each slot capable of holding an 8-byte (64 bit) word. Two main components: Register File and FIFO Controller. It should handle write "WR" and read "RD" operations. The FIFO should be able to indicate when it is full "FULL" or empty "EMPTY".

❖ For this FIFO buffer:

- First, we define entity:

We need these ports: "CLK", "RESET", "WR", "RD", "W\_DATA", "R\_DATA", "FULL" AND "EMPTY"

❖ For Register File:

We need an array of 8 slots, each 64 bits wide.

And for FIFO Controller we need handle **read and write signals**.

❖ **Code:**

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity fifo_Buffer is
port (
    clk: in std_logic;
    reset: in std_logic;
    wr: in std_logic;
    rd: in std_logic;
    w_data: in std_logic_vector (63 downto 0);
    r_data: out std_logic_vector (63 downto 0);
    full: out std_logic;
    empty: out std_logic
);
end fifo_Buffer;
```

architecture Behavioral of fifo\_Buffer is

```
type mem_type is array (0 to 7) of std_logic_vector(63 downto 0);
signal mem: mem_type := (others => (others => '0'));
signal w_ptr, r_ptr: integer range 0 to 7 := 0;
signal count: integer range 0 to 8 := 0;
signal full_signal, empty_signal: std_logic;

begin

full <= full_signal;
empty <= empty_signal;

process(clk, reset)
begin

if reset = '1' then

w_ptr <= 0;
r_ptr <= 0;
count <= 0;
full_signal <= '0';
empty_signal <= '1';

elsif rising_edge(clk) then

if wr = '1' and full_signal = '0' then

mem(w_ptr) <= w_data;
w_ptr <= (w_ptr + 1) mod 8;
count <= count + 1;
```

```
end if;

if rd = '1' and empty_signal = '0' then
    r_data <= mem(r_ptr);
    r_ptr <= (r_ptr + 1) mod 8;
    count <= count - 1;
end if;

if count = 8 then
    full_signal <= '1';
else
    full_signal <= '0';
end if;

if count = 0 then
    empty_signal <= '1';
else
    empty_signal <= '0';
end if;
end if;

end process;
end Behavioral;
```

## ❖ Compilation Report:

The screenshot shows the Quartus II 64-Bit interface with the following details:

- Project Navigator:** Shows the entity "fifo\_Buffer" under "Cyclone V: SCGXF7C7F23C8".
- Table of Contents:** Includes sections like Flow Summary, Flow Settings, Flow Non-Default Global S, Flow Elapsed Time, Flow OS Summary, Flow Log, Analysis & Synthesis, Flow Messages, and Flow Suppressed Message.
- Flow Summary:** Displays successful compilation details:

|                                 |                                            |
|---------------------------------|--------------------------------------------|
| Flow Status                     | Successful - Sat May 25 18:26:00 2024      |
| Quartus II 64-Bit Version       | 13.1.0 Build 162 10/23/2013 SJ Web Edition |
| Revision Name                   | fifo_Buffer                                |
| Top-level Entity Name           | fifo_Buffer                                |
| Family                          | Cyclone V                                  |
| Device                          | SCGXF7C7F23C8                              |
| Timing Models                   | Final                                      |
| Logic utilization (in ALMs)     | N/A                                        |
| Total registers                 | 276                                        |
| Total pins                      | 134                                        |
| Total virtual pins              | 0                                          |
| Total block memory bits         | 512                                        |
| Total DSP Blocks                | 0                                          |
| Total HSSI RX PCSS              | 0                                          |
| Total HSSI PMA RX Deserializers | 0                                          |
| Total HSSI TX PCSS              | 0                                          |
| Total HSSI TX Channels          | 0                                          |
| Total PLLs                      | 0                                          |
| Total DLLs                      | 0                                          |
- Messages:** A list of synthesis messages:

```
> 19000 Inferred 1 megafunctions from design logic
> 12130 Elaborated megafunction instantiation "altsyncram:mem_rtl_0"
> 12133 Instantiated megafunction "altsyncram:mem_rtl_0" with the following parameter:
> 12021 Found 1 design units, including 1 entities, in source file db/altsyncram_hvt1.tdf
> 286030 Timing-Driven Synthesis is running
> 16010 Generating hard block partition "hard_block:auto_generated_inst"
> 21057 Implemented 547 device resources after synthesis - the final resource count might be different
> 19000 Quartus II 64-Bit Analysis & Synthesis was successful. 0 errors, 1 warning
```

## ❖RTL View:



# Post-Mapping View:

1:



2:



3:



4:



5:



6:



7:



8:



9:



10:



11:



12:



## ❖Wave Form Code:





7:13 PM  
5/25/2024



## ❖Test Bench Code:

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.std_logic_arith.ALL;
```

```
ENTITY tb_fifo_Buffer IS
END tb_fifo_Buffer;
```

```
ARCHITECTURE behavior OF tb_fifo_Buffer IS
```

--Inputs and outputs

```
signal Clk,reset,enr,enw,empty,full : std_logic := '0';
signal data_in,data_out : std_logic_vector(7 downto 0) := (others =>
'0');

--temporary signals
signal i : integer := 0;
-- Clock period definitions
constant Clk_period : time := 10 ns;
constant DEPTH : integer := 16; --specify depth of fifo here.
```

BEGIN

```
-- Instantiate the Unit Under Test (UUT)
uut: entity work.fifo_Buffer
generic map(DEPTH => DEPTH)
PORT MAP (clk => clk,
          reset => reset,
          enr => enr,
          enw => enw,
          data_in => data_in,
          data_out => data_out,
          fifo_empty => empty,
          fifo_full => full);
```

```

-- Clock process definitions

Clk_process :process
begin
    Clk <= '0';
    wait for Clk_period/2;
    Clk <= '1';
    wait for Clk_period/2;
end process;

-- Stimulus process
stim_proc: process
begin
    reset <= '1'; --apply reset for one clock cycle.
    wait for clk_period;
    reset <= '0';
    wait for clk_period*3; --wait for 3 clock periods(simply)
    enw <= '1';    enr <= '0';      --write 10 values to fifo.
    for i in 1 to 10 loop
        data_in <= conv_std_logic_vector(i,8);
        wait for clk_period;
    end loop;
    enw <= '0';    enr <= '1';      --read 4 values from fifo.

```

```
wait for clk_period*4;  
enw <= '1';    enr <= '1';      --read and write at the same time  
for 2 clock cycles  
wait for clk_period*2;  
enw <= '0';    enr <= '0';      --neither read nor write  
wait for clk_period*10; --wait for some clock cycles.  
enw <= '1';    enr <= '0';      --write 10 values to fifo.  
for i in 11 to 20 loop  
  data_in <= conv_std_logic_vector(i,8);  
  wait for clk_period;  
end loop;  
enw <= '0';    enr <= '0';      --neither read nor write  
wait for clk_period*10; --wait for some clock cycles.  
enw <= '0';    enr <= '1';      --read 4 values from fifo.  
wait for clk_period*4;  
enw <= '0';    enr <= '0';      --neither read nor write  
wait for clk_period;  
enw <= '0';    enr <= '1';      --read 4 values from fifo.  
wait for clk_period*8;  
enw <= '0';    enr <= '0';      --neither read nor write  
wait for clk_period;  
enw <= '0';    enr <= '1';      --read 8 values from fifo.  
wait for clk_period*4;
```

```
enw <= '0';    enr <= '0';      --neither read nor write  
wait for clk_period;  
enw <= '0';    enr <= '1';      --read 4 values from fifo.  
wait for clk_period*4;  
enw <= '0';    enr <= '0';      --neither read nor write  
wait;  
end process;
```

END;

**Q3.** To Implement the FSM and verify its correctness we first need FSM module so we declare the input and outputs then describe its behavior. After that we need Look-ahead output buffer to make sure that glitch-free moore outputs, implement a buffer that update outputs on the clock edge.

❖ **ASM chart:**



States  $\rightarrow S_0, S_1, S_p, S_y$

Conditions and transitions based on input  $a, b$  and  $y$

AYLAR

### ❖ State s0:

- Output:  $y_0 = 1, y_1 = 0, y_2 = 0$
- Decision: If  $a = 1 \rightarrow$  go to s1
- Decision: If  $a = 0 \rightarrow$  stay in s0

### ❖ State s1:

- Output:  $y_0 = 0, y_1 = 1, y_2 = 0$
- Decision: If  $a = 1$  and  $b = 0 \rightarrow$  go to s2
- Decision: If  $a = 0 \rightarrow$  stay in s1

### ❖ State s2:

- Output:  $y_0 = 0, y_1 = 0, y_2 = 1$
- Decision: If  $a = 0$  and  $b = 1 \rightarrow$  go to s0
- Decision: If  $c = 1 \rightarrow$  go to s3

### ❖ State s3:

- Output:  $y_0 = 0, y_1 = 0, y_2 = 1$
- Decision: If  $c = 0 \rightarrow$  go to s0
- Decision: If  $c = 1 \rightarrow$  stay in s3

### ❖ Code:

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity FSM is
    Port ( clk : in STD_LOGIC;
```

```
    reset : in STD_LOGIC;  
    a : in STD_LOGIC;  
    b : in STD_LOGIC;  
    c : in STD_LOGIC;  
    y0, y1, y2 : out STD_LOGIC);  
end FSM;
```

architecture Behavioral of FSM is

```
    type state_type is (s0, s1, s2, s3);  
    signal state, next_state : state_type;  
    signal y0_reg, y1_reg, y2_reg : STD_LOGIC := '0';  
begin  
    process(clk, reset)  
    begin  
        if reset = '1' then  
            state <= s0;  
        elsif rising_edge(clk) then  
            state <= next_state;  
        end if;  
    end process;
```

```
process(state, a, b, c)
begin
    case state is
        when s0 =>
            if a = '1' then
                next_state <= s1;
            else
                next_state <= s0;
            end if;
            y0_reg <= '1';
            y1_reg <= '0';
            y2_reg <= '0';

        when s1 =>
            if a = '1' and b = '0' then
                next_state <= s2;
            elsif a = '0' then
                next_state <= s1;
            else
```

```
    next_state <= s0;  
end if;  
  
y0_reg <= '0';  
y1_reg <= '1';  
y2_reg <= '0';
```

when  $s2 \Rightarrow$

```
if a = '0' and b = '1' then  
    next_state <= s0;  
elsif c = '1' then  
    next_state <= s3;  
else  
    next_state <= s2;  
end if;  
y0_reg <= '0';  
y1_reg <= '0';  
y2_reg <= '1';
```

when  $s3 \Rightarrow$

```
if c = '0' then
```

```
    next_state <= s0;  
  else  
    next_state <= s3;  
  end if;  
  y0_reg <= '0';  
  y1_reg <= '0';  
  y2_reg <= '1';  
  
when others =>  
  next_state <= s0;  
end case;  
end process;
```

```
-- Look-ahead output buffer to ensure glitch-free Moore  
output  
process(clk)  
begin  
  if rising_edge(clk) then  
    y0 <= y0_reg;  
    y1 <= y1_reg;  
    y2 <= y2_reg;
```

```

end if;

end process;

end Behavioral;

```

## ❖ Compilation Report:

The screenshot shows the Quartus II 64-Bit interface with the following details:

- Project Navigator:** Shows the entity "Cyclone V: SCGXFC7C7F23C8" with a sub-item "FSM".
- Flow Summary:** A table of contents for the compilation report, including sections like Flow Status, Flow Settings, and Flow Log.
- Flow Status:** Successful - Sat May 25 20:51:49 2024
 

|                                 |                                            |
|---------------------------------|--------------------------------------------|
| Quartus II 64-Bit Version       | 13.1.0 Build 162 10/23/2013 SJ Web Edition |
| Revision Name                   | FSM                                        |
| Top-level Entity Name           | FSM                                        |
| Family                          | Cyclone V                                  |
| Device                          | SCGXFC7C7F23C8                             |
| Timing Models                   | Final                                      |
| Logic utilization (in ALMs)     | N/A                                        |
| Total registers                 | 7                                          |
| Total pins                      | 8                                          |
| Total virtual pins              | 0                                          |
| Total block memory bits         | 0                                          |
| Total DSP Blocks                | 0                                          |
| Total HSSI RX PCSS              | 0                                          |
| Total HSSI PMA RX Deserializers | 0                                          |
| Total HSSI TX PCSS              | 0                                          |
| Total HSSI TX Channels          | 0                                          |
| Total PLLs                      | 0                                          |
| Total DLLs                      | 0                                          |
- Messages:** A log of compilation events:
 

| Type | ID     | Message                                                                                                                                                  |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Info | 11104  | Command: quartus_map --read_settings_files=on --write_settings_files=off FSM -c FSM                                                                      |
| Info | 12021  | Parallel Compilation has detected 8 hyper-threaded processors. However, the extra hyper-threaded processors will not be used by default. Parallel Compil |
| Info | 12127  | Found 2 design units, including 1 entities, in source file fsm.vhd                                                                                       |
| Info | 12127  | Elaborating entity "FSM" for the top level hierarchy                                                                                                     |
| Info | 286030 | Timing-Driven Synthesis is running                                                                                                                       |
| Info | 16010  | Generating hard_block partition "hard_block:auto_generated_inst"                                                                                         |
| Info | 21057  | Implemented 16 device resources after synthesis - the final resource count might be different                                                            |
| Info | 21057  | Quartus II 64-Bit Analysis & Synthesis was successful. 0 errors, 0 warnings                                                                              |

## ❖ Compilation Report for Testbench Code:



## ❖ RTL View:



## ❖Post- Mapping View:



## ❖Wave View:





## ❖Testbench code:

```

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;

entity FSM_tb is
end FSM_tb;

architecture Behavioral of FSM_tb is
    signal clk : STD_LOGIC := '0';

```

```
signal reset : STD_LOGIC := '0';
signal a : STD_LOGIC := '0';
signal b : STD_LOGIC := '0';
signal c : STD_LOGIC := '0';
signal y0, y1, y2 : STD_LOGIC;
```

component FSM

```
Port ( clk : in STD_LOGIC;
       reset : in STD_LOGIC;
       a : in STD_LOGIC;
       b : in STD_LOGIC;
       c : in STD_LOGIC;
       y0, y1, y2 : out STD_LOGIC);
```

end component;

begin

```
uut: FSM Port map (
    clk => clk,
    reset => reset,
    a => a,
    b => b,
    c => c,
```

```
y0 => y0,  
y1 => y1,  
y2 => y2  
);  
  
clk_process: process  
begin  
    clk <= '0';  
    wait for 10 ns;  
    clk <= '1';  
    wait for 10 ns;  
end process;
```

```
stim_proc: process  
begin  
    -- Initialize Inputs  
    reset <= '1';  
    wait for 20 ns;  
    reset <= '0';  
  
    -- Test sequence  
    a <= '1'; b <= '0'; c <= '0';
```

```
wait for 20 ns;  
a <= '1'; b <= '1'; c <= '0';  
  
wait for 20 ns;  
a <= '0'; b <= '1'; c <= '0';  
  
wait for 20 ns;  
a <= '0'; b <= '0'; c <= '1';  
  
wait for 20 ns;  
a <= '1'; b <= '0'; c <= '1';  
  
wait for 20 ns;  
  
-- Stop the simulation  
wait;  
end process;  
  
end Behavioral;
```