#### Additional VHDL

# ELEC 418 Advanced Digital Systems Dr. Ron Hayne

Images Courtesy of Thomson Engineering



# Tristate Logic and Busses





# IEEE 1164 Standard Logic

#### • 9-Valued Logic System

- 'U' Uninitialized
- 'X' Forcing Unknown
- '0' Forcing 0
- '1' Forcing 1
- 'Z' High Impedance
- 'W' Weak Unknown
- 'L' Weak 0
- 'H' Weak 1
- '-' Don't Care

# SRAM Model



| CS | ŌĒ | WE | Mode            | I/O pins |
|----|----|----|-----------------|----------|
| Н  | Χ  | X  | not selected    | high-Z   |
| L  | Н  | Н  | output disabled | high-Z   |
| L  | L  | Н  | read            | data out |
| L  | X  | L  | write           | data in  |

## VHDL Model

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_unsigned.all;
entity RAM6116 is
   port(Cs_b, We_b, Oe_b: in std_logic;
        Address: in std_logic_vector(7 downto 0);
        IO: inout std_logic_vector(7 downto 0));
end RAM6116;
```

## VHDL Model

### VHDL Model

```
process(We_b, Cs_b)
begin
  if Cs_b = '0' and rising_edge(We_b) then
     RAM1(conv_integer(Address)) <= I0;
  end if;
  end process;
end simple_ram;</pre>
```

## Generics

```
library IEEE;
use IEEE.std logic 1164.all;
entity Businv is
  generic(width: positive);
 port(x: in std logic vector(width-1 downto 0);
       y: out std logic vector(width-1 downto 0));
end Businv;
architecture Behave of Businv is
begin
  y \le not x;
end Behave;
```

# Generic Instantiation

```
entity Businv 8 is
  port(in8: in std logic vector(7 downto 0);
       out8: out std logic vector(7 downto 0));
end Businv 8;
architecture Structure of Businv 8 is
component Businv
  generic(width: positive);
  port(x: in std logic vector(width-1 downto 0);
       y: out std_logic_vector(width-1 downto 0));
end component;
begin
  B1: Businv generic map(8) port map(in8, out8);
end Structure;
```

418\_08

# Time Modeling

```
library IEEE;
use IEEE.std logic 1164.all;
entity xor2 is
  generic(gate delay: time := 2 ns);
  port(in1, in2: in std logic;
       z: out std logic);
end xor2;
architecture behave of xor2 is
begin
  z <= in1 xor in2 after gate delay;</pre>
end behave;
```

# Named Association

```
component FA is
  port(X, Y, Cin: in std logic;
       Cout, Sum: out std logic);
end component;
FA0: FA port map(A(0), B(0), '0', open, S(0));
FA0: FA port map(Sum \Rightarrow S(0),
                  X => A(0),
                  Y \Rightarrow B(0),
                  Cin => '0');
```

# Regular Structures (Generate)



```
entity Adder4 is
  port(A, B: in std_logic_vector(3 downto 0);
       Ci: in std_logic;
      S: out std_logic_vector(3 downto 0);
      Co: out std_logic);
end Adder4;
```

418\_08 13

## Generate Statements

```
architecture Structure of Adder4 is
  component FullAdder
    port(X, Y, Cin: in std logic;
         Cout, Sum: out std logic);
  end component;
  signal C: std logic vector(4 downto 0);
begin
 C(0) \le Ci;
 Co <= C(4);
  FullAdd4: for i in 0 to 3 generate
 begin
    FAx: FullAdder port map (A(i), B(i), C(i),
                              C(i+1) , S(i) ;
  end generate FullAdd4;
end Structure;
```

418\_08 14

# Summary

- IEEE 1164 Standard logic
- Generics
- Named Association
- Generate Statements

418\_08