

### Agenda

- Practical issues
  - Handins
  - Audio codec function and interface
- High abstraction level modelling



2023-09-08 2



2023-09-08 4

### TSTE12 Deadlines MELE, erasmus

- First project meeting no later than Monday 11 September
- Tuesday 12 September: First version of requirement specification
- Wednesday 13 September 21.00: Lab 1 deadline
  - Pass required to be allowed continued project participation



2023-09-08 5

# Handin (homework), Individual!

- 1<sup>st</sup> handin deadline Monday 18 September
  - Available on web from Monday 11 September
- Submit answers using Lisam assignment function (individual work!!!)
- Theory question answers entered direct as text (see assignments on web)
- Use your own home directory for code answer testing (Not lab group directory)
   Use ~/TSTE12/
- Use a special terminal window when working with handins

module load TSTE12; TSTE12handin

TSTE12 Design of Digital Systems, Lecture 6

2023-09-08 6

# Individual handin task, cont.

- Create handin code answers using a plain text editor
  - emacs, vim, or the built-in editor in modelsim
  - See in the tutorial how start and use modelsim
- Upload the answers of the coding tasks onto Lisam (TSTE12 course room submission)
- Remember to compile and simulate the design
  - Will use source code for checking handin results
- Do not use handin directory for anything else but handin code and answers you make yourself!



2023-09-08 7

### Individual handin, cont.

• Hand-ins are **individual** work!

TSTE12 Design of Digital Systems, Lecture 6

- Ask me if there are questions about the handin
- Hand-ins are checked automatically (using scripts)
  - Make sure all names and types are correct in code answers
    - Datatype bit is **not** the same as std\_logic!
  - Test your code! Do not assume that you have written correct code.
  - NOTE: Do NOT use hdl-designer (do not start the software using TSTE12lab or TSTE12proj)
  - See modelsim tutorial on exercise page
    - www.isy.liu.se/edu/kurs/TSTE12/kursmaterial

TSTE12 Design of Digital Systems, Lecture 6

2023-09-08 8

### DE2-115 board components

- Audio codec used to input/output analog audio signal
- Codec function
  - Codec can be used in multiple configurations
  - Contains clock generators, A/D, D/A and filters
  - Loopback, volume control
- Codec configuration
  - Default configuration defined in documentation



### Individual

- DE2-115 FPGA default design
  - DE2-115 loads a default design at power on
    - Microprocessor design running (NIOS II Soft process, i.e. written i VHDL)
    - Check switches SW3 downto SW0 to select what to do with the SRAM contents and Codec init
    - Infinite loop: read switches, update LEDs, updates 7-segment display.
    - Help text shown on VGA screen
  - Default design is not the standard design described in the DE2-115 user manual
  - Do not depend on power-on defaults
  - Allows configuration of memory and codec for testing

| Codec programming (I2C)                                                                                                                                                                                                                                                                | 2023-09-08 10                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| <ul> <li>Codec configured using an I2C bus</li> <li>General structure <ul> <li>Multichip bus (all chips connect to the same pins)</li> </ul> </li> </ul>                                                                                                                               | VCC33 VCC33<br>R2<br>2K<br>I2C_SOLK<br>I2C_SOLT                           |
| <ul> <li>Pullup <ul> <li>Only assign 'Z' or '0' on pins</li> <li>Pullup will translate 'Z' to '1' if other chips does not sink that pin</li> <li>Separate output and input signals to/from pin</li> <li>Values do not change immediately (slow voltage changes)</li> </ul> </li> </ul> | I2C ADDRESS READ IS 0x34 GND<br>I2C ADDRESS WRITE IS 0x35 GND<br>I2C SOLK |

2023-09-08 9

| I2C protocol                                                                                                              |                                                   |
|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| <ul> <li>Bidirectional protocol</li> <li>Wired-and using pull-up</li> <li>Send byte by byte</li> <li>MSB first</li> </ul> | SDIN II RADDR RW ACK DATA BIS-8 ACK DATA BJ-0 ACK |
| <ul> <li>FPGA work as master</li> </ul>                                                                                   |                                                   |
| <ul> <li>Slave (codec) responds</li> <li>Pulls down SDA in ack cy</li> <li>Simple solution: assume</li> </ul>             | rcle                                              |
|                                                                                                                           |                                                   |

2023-09-08 12

### Numeric calculations

- Bit-vectors (and std\_logic\_vectors) does not directly correspond to a value
  - "1011" could mean 11 in decimal (unsigned), or -5 in decimal (2's complement)
- Datatypes are included in supporting packages to enable arithmetic on bit-vectors
  - ieee.numeric\_bit.all
  - ieee.numeric\_std.all
- Must use defined types signed or unsigned to allow calculations
  - Same definitions as bit\_vector and std\_logic\_vector
  - Can copy values between types due to same element type



2023-09-08 13

### Numeric calculations example

 Counter incrementing 3-bit count value each clock cycle

- Asynchronous reset

library ieee; use ieee.numeric\_bit.all;

entity INL3\_KB is port ( C : in bit; R : in bit; Q : out bit\_vector(1 to 3)); end entity; architecture KB of INL3\_KB is begin

process(C,R)
variable count : unsigned(1 to 3);
begin
if R = '1' then
 count := (others => '0');
elsif C'event and (C='1') then
 count := count + 1;
end if;
Q <= bit\_vector(count);
end process;</pre>

end architecture;

LINKÖPING UNIVERSITY

<page-header><page-header><page-header><section-header><list-item><list-item><list-item><code-block></code>

2023-09-08 17

### Another aspect of signal assignment

- One signal can be assigned from different parts of the code
  - Support multiple entities driving the same wire
  - Example: Databus in a computer connecting multiple memories and CPU
- Modelling must be strict and clear
  - Same result independant of simulator tool
  - Should not be able to detect the order the processes where calculated
- Not all data types support multiple sources for the value

TSTE12 Design of Digital Systems, Lecture 6

2023-09-08 18

### Multiple assignment on one signal

- Each process containing a signal assignment will have a driver in the simulator generating a contribution to the final signal value
  - Concurrent signal assignments will have one driver each
  - Processes only have one driver for each signal (even with multiple assignment)
  - The signal update seen before is done individually on each driver
  - One driver does not know anything about other drivers
- When the value of a signal is fetched, the contributions from the different drivers current values are collected.

 The resulting signal value depends on the definition of how to combine the values from the different drivers, using a resolution function





2023-09-08 21

### Example of implementing Multivalued logic in VHDL

• Alternative to data type BIT but simpler than std\_logic

```
Type MVL4 is ('X', '0', '1', 'Z');
```

```
Type MVL4_VECTOR is array(NATURAL range <>) of MVL4;
```

-  ${\bf X}$  leftmost to make it the initial value unless explicitly initialized in the code

2023-09-08 22

### **Multidriver signals**

- Requires a resolution signal
- Different combinations possible
  - X always overrides others
  - 0 and 1 at the same time gives  $\boldsymbol{X}$
  - $Z \mbox{ and } Z \mbox{ gives } Z$

TSTE12 Design of Digital Systems, Lecture 6

2023-09-08 23

### Resolution function definition

Subtype DotX is wiredX MVL4;

• WiredX is the name of the resolution function

Function WiredX (V:MVL4\_VECTOR) return MVL4;

• Where V is a vector containing all values of all drivers of a signal



2023-09-08 24

### **Resolution function implementation**

• Implement as a loop and lookup table

```
Function wiredX (V: MVL4_VECTOR) return MVL4 is
    Variable result: MVL4:= 'Z';
Begin
    For i in V'RANGE loop -- range not known in advance
        Result = table_WIREDX(result,V(i));
        Exit when result = 'X';
    End loop;
    Return result;
End wiredX;
```

```
TSTE12 Design of Digital Systems, Lecture 6
                                                                    2023-09-08 25
  Resolution function impl., cont.

    Check of X in loop is not necessary, but speed up

     simulation
   • Table should then look like:
      Type MVL4_TABLE is array (MVL4, MVL4) of MVL4;
      Constant table_WIREDX : MVL4_TABLE :=
      - -
      - -
                  Х
                        0
                             1
                                   Ζ
      - -
                            ′Χ′,
                                 ′X′),
               (('X', 'X',
                                          - -
                                                Х
                      '0',
                ('X',
('X',
                           'X', '0'),
'1', '1'),
                                          - -
                                                0
                     Ϋ́Χ΄,
                                         - -
                                                1
                ('X', '0', '1', 'Z')); --
                                                Ζ
```

2023-09-08 26

# Resolution function impl. Cont. Table lookup may be used for most functions Not possible to know the order of the value in V, may therefore require a more complex algorithm

TSTE12 Design of Digital Systems, Lecture 6

### 2023-09-08 27

### Bus data type

Type busX is array (Natural range <>) of DotX;

- However, a new data type requires all logic operations to be specified
  - Complicated
- Better approach: conversion function
  - Only read bus using a call to a Sense function
     Function Sense (value : busX) return bit\_vector;
  - Only assign value to the bus using the Drive function
     Function Drive (value : bit\_vector) return busX



2023-09-08 28

2023-09-08 29

P4

0

**S**3

**P**2

S2(DEL\_S2)

**S**4

P3

I1

I2

# Algorithmic level development

- Specification in many cases in natural language
   Ambigous description in many cases
- Want an executable specification
  - Allows testing of the behavior the description describes
- Use VHDL to capture the specification
  - Use the full language capabilities
  - Description not intended for synthesis

TSTE12 Design of Digital Systems, Lecture 6

### Process Model Graph (PMG)

- Typical example
- Arcs describes signals with names and delays
  - example process 4 to 1
- VHDL Code example: S <= xxx after DEL\_S;
- Physical or functional partitioning
  - Single process may map to multiple hardware units
  - Multiple process may map to single hardware unit





2023-09-08 31

### Example approach

- Map groups of sentences onto VHDL processes
- Assign each process an activity list
- Develop VHDL code that implements each activity



2023-09-08 32

### Example: Serial to Paralell converter

- English text description
  - The 8-bit parallel word (PARIN) is loaded into the converter when the control signal LD makes a zero to one transition At this time the status signal BUSY is set high. The data is shifted out serially at a rate controlled by the input shift clock SHCLK. Shifting occurs at the rise of the clock. BUSY remains high until shifting is complete. While BUSY is high, no further loads will be accepted.
- Note some sentences are shared between functions
- Two processes: LOAD and SHIFT

```
TSTE12 Design of Digital Systems, Lecture 6
```

```
2023-09-08 33
```

### Serial to Paralell converter, cont.

- LOAD: (a) 8-bit parallel word (PARIN) load when LD makes a zero to one transition. Set BUSY high. (b) BUSY remains high until shift complete. No new loads while BUSY high
- SHIFT: (a) Data shifted out controlled by rising edge of SHCLK.
  (b) BUSY remain high until shift complete



| PMG version                                                                                                                                                                                                                          | architecture TWO_PROC of PAR_TO_SER is<br>signal SH_COMP: BIT :='0';<br>signal PREG: BIT_VECTOR(0 to 7);<br>begin                                                                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Corresponding code<br/>based on processes</li> <li>PMG defines interface of<br/>each process + signals<br/>between the processes</li> <li>Code start by defining<br/>processes and comments<br/>about activities</li> </ul> | LOAD:process(LD,SH_COMP)<br>begin<br>Activities:<br>1)Register Load<br>2)Busy Set<br>3)Busy Reset<br>end process LOAD;<br>SHIFT:process(BUSY,SHCLK)<br>variable COUNT: INTEGER;<br>variable OREG: BIT_VECTOR(0 to 7);<br>begin<br>Activities:<br>1)Shift Initialize<br>2)Shift<br>3)Shift Complete<br>end process SHIFT; |
|                                                                                                                                                                                                                                      | end TWO_PROC;                                                                                                                                                                                                                                                                                                            |

| TSTE12 Design of Digital Systems, Lecture 6                                                                                                                                                   |                                                                                                                                                                                                                                                                                  | 2023-09-08 35                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>FSTE12 Design of Digital Systems, Lecture 6</li> <li>PMG -&gt; Code</li> <li>Each process has<br/>a check for an<br/>event, and then a<br/>part that execute<br/>the data</li> </ul> | <pre>SHIFT:process(BUSY,SHCLK) variable COUNT: INTEGER; variable OREG: BIT_VECTOR(0 beginActivities: if BUSY'EVENT and     BUSY = '1' then1)Shift Initialize     COUNT := 7;     OREG := PREG;     SH_COMP &lt;= '0'; end if;     if SHCLK'EVENT and         SHCLK= '1'and</pre> |                                                                                                                                                                            |
| operations                                                                                                                                                                                    | BUSY='1' then<br>2)Shift<br>SO<=OREG(COUNT);<br>COUNT := COUNT - 1;<br>if COUNT <= 0 then<br>SH COMP <= '1';<br>PREG <= PARIN<br>2)Busy Set<br>BUSY <= '1';<br>end if;<br>if SH_COMP'EVE<br>and SH_COMP<br>3)Busy R                                                              | <pre>PREG &lt;= PARIN;<br/>2)Busy Set<br/>BUSY &lt;= '1';<br/>end if;<br/>if SH_COMP'EVENT<br/>and SH_COMP='1' then<br/>3)Busy Reset<br/>BUSY &lt;= '0';<br/>end if;</pre> |
|                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                  |                                                                                                                                                                            |

<section-header><section-header><section-header><list-item><list-item><list-item><section-header>

| TSTE12 Design of Digital Systems, Lecture 6                                                                                                                                         | 2023-09-08 37<br><b>1t.</b> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| <ul> <li>Three processes: PREG, ENABLE</li> <li>Add delay on wires         <ul> <li>t<sub>SD</sub> = STRB_DEL + ODEL</li> <li>t<sub>ED</sub> = EN_DEL + ODEL</li> </ul> </li> </ul> | , OUTPUT                    |
|                                                                                                                                                                                     |                             |

2023-09-08 36

| Timing example, o                          | Cont.<br>PREG: process(STRB)           |
|--------------------------------------------|----------------------------------------|
|                                            | begin                                  |
| antitu DUFE DEC in                         | if (STRB = '1') then                   |
| entity BUFF_REG is<br>generic(             | REG <=DI after STRB_DEL;               |
| STRB_DEL, EN_DEL, ODEL: TIME);             | end if;<br>end process PREG;           |
| port(                                      | end process PREG,                      |
| DI: in BIT_VECTOR(1 to 8);                 | ENABLE: process(DS1,NDS2)              |
| STRB: in BIT;                              | begin                                  |
| DS1: in BIT;                               | ENBLD <= DS1 and not NDS2 after EN_DEL |
| NDS2: in BIT;                              | end process ENABLE;                    |
| <pre>D0: out BIT_VECTOR(1 to 8));</pre>    |                                        |
| end BUFF_REG;                              | OUTPUT: process(REG,ENBLD)             |
|                                            | begin                                  |
|                                            | if (ENBLD = '1') then                  |
| architecture THREE_PROC of BUFF_REG is     | DO <= REG after ODEL;                  |
| <pre>signal REG: BIT_VECTOR(1 to 8);</pre> | else                                   |
| signal ENBLD: BIT;                         | D0 <= "11111111" after ODEL;           |
| begin                                      | end if;                                |
|                                            | end process OUTPUT;<br>end THREE_PROC; |

```
TSTE12 Design of Digital Systems, Lecture 6
```

### 2023-09-08 39

### Process complexity trade-off

- Number of signals
  Many signals => slow simulation
- Large processes
  - Complex behavior may not match specification
- Ease of mapping to hardware
  - More processes may simplify mapping



| TSTE12 Design of Digital Systems, Lecture 6                                                                                                                                            | 2023-09-08 | 40 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----|
| Checking timing                                                                                                                                                                        |            |    |
| <ul> <li>Additional requirements <ul> <li>DI stable SUT ns before STRB rise</li> <li>DI stable HT ns after STRB rise</li> <li>STRB minimum high duration MPW ns</li> </ul> </li> </ul> |            |    |
| <ul> <li>Implement checks using assert statements</li> </ul>                                                                                                                           |            |    |
| assert not (not STRB'stable and (STRB = '1')<br>and not DI'stable(SUT))<br>report "Setup Time Failure";                                                                                |            |    |
|                                                                                                                                                                                        |            |    |
|                                                                                                                                                                                        |            |    |
|                                                                                                                                                                                        |            |    |

| TSTE12 Design of Digital Systems, Lecture 6 | TSTE12 Design | of Digital Sy | stems, Lecture 6 |
|---------------------------------------------|---------------|---------------|------------------|
|---------------------------------------------|---------------|---------------|------------------|

2023-09-08 41

# Timing Check placement

- Tests in architecture must be copied between architectures
   May introduce errors
  - If changed, many architectures must be changed
- Solution: Place checks in the entity
  - Check always executed, independent of selected architecture



2023-09-08 42

### Timing check example

Entity BUFF\_REG is Generic (STRB\_DEL, EN\_DEL, ODEL, SUT, HT, MPW: TIME); Port (DI: in bit\_vector(1 to 8); STRB : in bit ; DS1 : in bit; NDS2 : in bit; D0 : out bit\_vector(1 to 8)); Begin Assert STRB'stable or (STRB = '0') or DI'stable(SUT) Report "Setup time Failure"; Assert STRB'delayed(HUT)'stable or (STRB'delayed(HT) = '0') or DI'STABLE(HT) Report "Hold Time Failure"; Assert STRB'stable or (STRB = '1') or STRB'delayed'stable(MPW) Report "Minimum pulse width failure"; End BUFF\_REG; 

