

# EITF35: Introduction to Structured VLSI Design

#### Part 2.2.2: VHDL-3

Liang Liu liang.liu@eit.lth.se



Lund University / EITF35/ Liang Liu 2014

#### Outline

## Inference of Basic Storage ElementSome Design Examples

- •DFF with enable
- Counter
- Coding Style: Segment
- □Variables in Sequential Circuit
- **Poor Design Examples**



#### **Inference of Basic Storage Elements**

## □VHDL code should be clear so that the pre-designed cells can be inferred

•As an architecture designer, you need to be very familiar with the available elements

#### **VHDL code of storage elements**

Positive edge-triggered D FF
Negative edge-triggered D FF
D FF with asynchronous reset
D Latch (*DON'T USE*)







## **Positive edge-Triggered D FF**

#### □No else branch

□Note the sensitivity list (only clk)

```
library ieee;
use ieee.std_logic_1164.all;
entity dff is
   port (
      clk: in std_logic;
      d: in std_logic;
      q: out std_logic
   );
end dff:
architecture arch of dff is
begin
   process (clk)
   begin
      if (clk'event and clk='1') then
         q <= d;
      end if;
   end process;
end arch;
```



rising edge(clk)



## **Negative edge-Triggered D FF**



#### **D FF with Async. Reset**

```
entity dffr is
   port (
      clk: in std_logic;
      reset: in std_logic;
      d: in std_logic;
      q: out std_logic
   );
end dffr;
architecture arch of dffr is
begin
   process (clk,reset)
   begin
      if (reset='1') then
         q <= '0';
      elsif (clk'event and clk='1') then
         q <= d;
      end if;
   end process;
end arch;
```





### **D** Latch (Learn How to Avoid)



#### **Exercise**

c1: process(clk)
begin
 if (clk 'event
 and clk = `1')then
 q<= `1';
 end if;
end process c1;</pre>

```
c2: process(clk)
begin
    if (clk
=`1')then
        q<=`1';
    end if;
end process c2;</pre>
```

#### What is the corresponding circuits?







## Outline

#### □Inference of Basic Storage Element

#### **Some Design Examples**

- •DFF with enable
- Counter
- Coding Style: Segment
- **Variables in Sequential Circuit**
- **Poor Design Examples**



## **Design Examples: D FF with sync enable**

#### Sync Enable

•Means the enable signal is controlled by clock



N7



#### **Design Examples: D FF with sync enable**



## **Design Examples: Binary Counter**

#### Binary Counter

- •Circulates through a sequence that resembles the unsigned binary number
- •Count from 0 to 15 and repeat
- •Set a flag when counting to 15



#### **Design Examples: Binary Counter**

```
entity binary counter4 pulse is
port( clk, reset: in std logic;
max pulse: out std logic;
q: out std logic vector (3 downto 0);
end binary counter4 pulse ;
architecture two seg arch of binary counter4 pulse is
signal r reg : unsigned (3 downto 0) ;
signal r next : unsigned (3 downto 0) ;
  process (clk, reset)
    begin
      if (reset='1') then r reg <= ( others=> '0') ;
      elsif (clk'event and clk='1') then r reg <= r next;
      end if;
  end process;
  r next <= r reg + 1; -- incrementor</pre>
  q <= stdedogic vector(r reg);</pre>
  max pulse <= `1' when r reg= ``1111" else `0'; -- output</pre>
end two seg_arch;
```

### **Design Examples: Binary Counter**

#### How to wrap around: 1111->0000

Poor code ('Wrong' code)

bad:r\_next <= (r\_reg + 1) mod 16</pre>

□In the IEEE numeric\_std package, "+" on the unsigned data type is modeled after a hardware adder

□Wrap around automatically when the addition result exceeds the range.

**I**Mod operation may cannot be synthesized

```
Good:r_next <= (r_reg + 1)</pre>
```

How to wrap if we count from 0 to 9?



## Outline

Inference of Basic Storage ElementSome Design Examples

- •DFF with enable
- •Register shifter
- •Counter

#### Coding Style: Segment

**Variables in Sequential Circuit** 

**Poor Design Examples** 



## **Coding Style: Segment**

#### One-segment

- •Describe storage and combinational logic in one process
- May appear compact for certain simple circuit
- •But it can be error-prone



# Is integration always better???



## Segment: D FF with sync enable

```
architecture one_seg_arch of dff_en is
begin
  process (clk, reset)
    begin
      if (reset='1') then
        q < = '0';
      elsif (clk'event and clk='1') then
         if (en='1') then
           q \leq d;
        end if;
      end if ;
  end process;
end one seg arch;
                                              d
                                              clk
                                              reset
                               clk
                              reset
```

q\_reg



#### **Segment: Binary Counter**

```
architecture not_work_one_seg_glitch_arch
                       of binary_counter4_pulse is
   signal r_reg: unsigned(3 downto 0);
begin
   process(clk,reset)
   begin
      if (reset='1') then
         r_reg <= (others=>'0');
      elsif (clk'event and clk='1') then
         r_reg <= r_reg + 1;
         if r_reg="1111" then
            max_pulse <= '1';</pre>
                                      What will be
         else
                                     the circuit?
            max_pulse <= '0';</pre>
         end if;
      end if;
   end process;
```



## **Segment: Binary Counter**



**A** 1-bit register is inferred for the max\_pulse signal.

□The register works as a buffer and *delays the output by one clock cycle*,

□and thus the max\_pulse signal will be asserted when r\_reg="0000".



## **Segment: Summary**

#### □Two-segment code

- •Separate storage segment from the rest
- Has a clear mapping to hardware component
- Is preferred and recommended

#### One-segment code

- Mix memory segment and next-state logic/output logic
- Can sometimes be more compact
- No clear hardware mapping
- Error prone



#### **Segment: Summary**



#### Keep the hardware and the corresponding coding rule in mind and then go ahead!

•Signals inside the clk'event and clk=`1' branch are referred as registers



## Outline

Inference of Basic Storage ElementSome Design Examples

- •DFF with enable
- •Register shifter
- •Counter
- **Coding Style: Segment**

#### □Variables in Sequential Circuit

**Poor Design Examples** 



## **Variables in Sequential Circuit**

## □Signals always imply an FF under clk' event and clk='1' condition

**When you don't want to infer an FF in a <u>one-segment</u> process** 

□Variable is local in a process and is not needed outside

#### Variable may imply differently

•Variable is used *after* it is assigned: get a value every time when the process is invoked

#### no register is inferred

•Variable is used **before** it is assigned: use the value from the previous process execution

**GIFF** or register need to be inferred



#### **Variables in Sequential Circuit: Example**

```
architecture arch of varaible ff demo is
    signal tmp sigl: std logic;
    begin
      process (clk)
         begin
           if (clk'event and clk='1') then
              tmp sig1 <= a and b;
             ql <= tmp sigl;</pre>
           end if ;
       end process;
                       tmp_sig
          ab
                 d
                                   Registers are inferred
cik
                >clk
                                   q1 is one clock later than
                                   tmp_sig1
                            q1
                 d
                     α
                  cik
```

**24** Lund University / EITF35/ Liang Liu 2014

## Variables in Sequential Circuit: Example

```
architecture arch of varaible_ff_demo is
begin
  process (clk)
   variable tmp_var2: std_logic; -- declare in process
   begin
      if (clk'event and clk='1') then
        tmp_var2 := a and b; -- notice assignment format
        ql <= tmp_var2;
        end if ;
end process;
```



Use variable *tmp\_sig2* is used after it is assigned
Just a hard wire, no Reg. is inferred



### Variables in Sequential Circuit: Example

```
architecture arch of varaible ff demo is
begin
   process (clk)
     variable tmp var2: std logic; -- declare in process
     begin
       if (clk'event and clk='1') then
        ql <= tmp var2;</pre>
        tmp var2 := a and b; -- change the assignment order
       end if ;
   end process;
                                                   tmp var2
                                      ab
                                             d
                           cik
                                             clk
2min: Draw the
corresponding circuits
                                             d
                                                         a1
                                                 α
                                              cik
No Variables!
```

## Outline

Inference of Basic Storage ElementSome Design Examples

- •DFF with enable
- •Register shifter
- •Counter
- **Coding Style: Segment**
- **Variables in Sequential Circuit**
- Poor Design Examples



**Example:** a mod-10 counter: 0,1,2 ...,7,8,9, 0,1,2..., 7,8,9,0



#### How to wrap from 9 to 0?



```
entity modl0 counter is
port(clk,reset: in std logic; q:out std logic vector (3 downto 0));
end modl0 counter;
architecture poor async arch of mod10 counter is
  signal r reg: unsigned (3 downto 0) ;
  signal r next: unsigned (3 downto 0) ;
  signal async clr: std logic;
 begin
   process (clk,async clr)
      begin
         if (async clr='1') then
           r reg <= (others=>`0');
         elsif(clk'event and clk=`1') then
           r_reg<=r next;</pre>
         end if ;
    end process;
   async clr <='1' when (reset='1'or r reg="1010") else '0';
   r next <= r reg + 1;</pre>
   q <= std logic vector(r reg);</pre>
end poor async arch;
```





#### Problems

•Glitch in counter: r\_reg goes to 10 and then reset, due to the delay of comparator

•Glitches in aync\_clr can reset the counter mistakenly





Lund University / EITF35/ Liang Liu 2014

#### Remedy

```
architecture two seg of mod10 counter is
  signal r reg: unsigned (3 downto 0) ;
  signal r next: unsigned (3 downto 0) ;
  begin
    process (clk, reset)
      begin
        if (reset = '1') then r reg <= (others=> '0');
        elsif(clk'event and clk=`1') then r reg<=r next;</pre>
      end if ;
    end process;
   r next \le (others \ge '0') when (r reg = 9) else r reg = 1;
   q <= std logic vector(r reg);</pre>
end two seg;
```

#### asynchronous reset should ONLY be used for initialization!





#### **Something to remember**

■Strictly follow the synchronous design methodology; i.e., all registers in a system should be *synchronized by a common global clock signal* (otherwise special circuits are needed)

□The memory components should be coded clearly so that a predesigned cell can be *inferred from the device library*.

□Isolate the memory components from the VHDL description and code them in a *separate segment*. One-segment coding style is not advisable.

□ Asynchronous reset, if used, should be only for system initialization. It should not be used to clear the registers during regular operation

□Unless there is a compelling reason, a *variable should not* be used to infer a memory component.

## **Reading advice**

#### **RTL Hardware Design Using VHDL: P213-P254**



## Thanks

