



Prof. Dr.-Ing. L. Leutelt

**Digital Systems**

**Lab**

March 16, 2022

Hochschule für Angewandte Wissenschaften Hamburg  
Hamburg University of Applied Sciences

© 2022 Copyright PROF. DR.-ING. LUTZ LEUTELT, Hochschule für Angewandte Wissenschaften Hamburg,

All rights reserved.

Alle Rechte, auch das des auszugsweisen Nachdrucks, der auszugsweisen oder vollständigen Wiedergabe, der Speicherung in Datenverarbeitungsanlagen und der Übersetzung, vorbehalten.

Dieses Dokument wurde mit Hilfe von KOMA-Script und L<sup>A</sup>T<sub>E</sub>X gesetzt.

# Contents

|                                                                            |           |
|----------------------------------------------------------------------------|-----------|
| <b>1 Synchronous Serial Communication with an Audio Codec</b>              | <b>5</b>  |
| 1.1 Objectives of the first lab Session . . . . .                          | 5         |
| 1.2 Audio codec subsystem overview . . . . .                               | 5         |
| 1.3 Development of the parallel-to-serial converter . . . . .              | 8         |
| 1.3.1 VHDL template PAR_TO_SER_LR_DUMMY.vhd . . . . .                      | 8         |
| 1.3.2 Hierarchical VHDL design . . . . .                                   | 11        |
| 1.4 Implementation on FPGA and test . . . . .                              | 13        |
| <b>2 Audio Processing: from ASMD Chart to Implementation</b>               | <b>19</b> |
| 2.1 Objectives of the second lab session . . . . .                         | 19        |
| 2.2 VHDL test benches . . . . .                                            | 19        |
| 2.3 Specification of the AUDIO_PROCESSING module . . . . .                 | 22        |
| 2.4 Hierarchical structure . . . . .                                       | 23        |
| 2.5 Module AUDIO_ON_OFF_MOD . . . . .                                      | 24        |
| 2.6 Module SET_AUDIO_MOD . . . . .                                         | 25        |
| 2.7 Design of the module AUDIO_QNT . . . . .                               | 30        |
| 2.7.1 Analysis of the module AUDIO_VOL . . . . .                           | 30        |
| 2.7.2 Volume scaling . . . . .                                             | 32        |
| 2.7.3 ASMD chart and VHDL code of the module AUDIO_QNT . . . . .           | 33        |
| 2.8 Synthesis and test of the entire audio processing system . . . . .     | 34        |
| 2.8.1 Audio quality . . . . .                                              | 34        |
| 2.8.2 Synthesis variants . . . . .                                         | 35        |
| 2.9 Optional Task: Integrated Logic Analyzer (ILA) Debug IP core . . . . . | 35        |
| <b>3 Design of a video animation (part 1)</b>                              | <b>37</b> |
| 3.1 Objectives of the third lab session . . . . .                          | 37        |
| 3.2 Video output to the monitor . . . . .                                  | 37        |
| 3.3 Hardware dependent realization in Matlab . . . . .                     | 38        |
| 3.4 From algorithm to ASMD chart . . . . .                                 | 39        |
| 3.5 Synthesis and timing of the demo video animation . . . . .             | 40        |
| 3.6 Video output test . . . . .                                            | 40        |
| 3.7 Start of VHDL modeling . . . . .                                       | 41        |
| <b>4 Design of a video animation (part 2)</b>                              | <b>43</b> |
| 4.1 Objectives of the 4th lab session . . . . .                            | 43        |
| 4.2 Testing the video animation . . . . .                                  | 43        |





## Synchronous Serial Communication with an Audio Codec

### 1.1 Objectives of the first lab Session

You will learn in this lab session, how to develop a serial communication interface to another digital module and how to exchange data with an audio codec. In addition to the modules known from the lecture, such as frequency divider, finite state machine (FSM) to control sampling timing, serial-to-parallel converter, etc. you will design a VHDL model for a parallel-serial converter, simulate, verify and test it on an FPGA. In the end, you will be able to send analog audio signals through the system consisting of audio codec and FPGA and hear them again as analog output, initially unchanged except for quantization.

The focus will be on (re)learning the development tools Mentor ModelSim and Xilinx Vivado and investigating the timing behavior of the circuit by measuring the analog and digital input and output signals with the oscilloscope.

**Preparation time:** approx. 4-6 hours

### 1.2 Audio codec subsystem overview

The module `AUDIO_CODEC_COM`, which is to be implemented in the FPGA, establishes the data exchange with the audio codec PCM3006, which is located on an expansion board (see Figure 1.1). The block diagram in Figure 1.2, which was already presented in the lecture, shows the individual components of the subsystem: frequency divider, serial-to-parallel converter, parallel-to-serial converter, and FSM for controlling the sampling times. The frequency divider provides three clock signals `SYSCLK`, `BCK` and `LRC` for the audio codec. `LRC` determines the sampling rate to be set to approximately 48 kHz, `BCK` is the bit clock, and `SYSCLK` is the clock for oversampling the internal filters in the audio codec. The frequency ratios of these three clocks are given in Table 1.1.

All three clocks are derived from the system clock `CLK`, which is provided by an on-board oscillator of the Modsys 2.0 board to the Artix-7 FPGA (see Figure 1.8). This system clock is set to 100 MHz,



Figure 1.1: Expansion board "AUDIO CODEC BOARD" with the audio codec PCM3006.

and the derived clocks SYSCLK, BCK, LRC are generated inside the FPGA by dividing the system clock frequency by appropriate powers of two.

#### Prep Task 1

If you use the system clock from the oscillator of the Modsys 2.0 board ( $f_{\text{SYSCLK}} = 100 \text{ MHz}$ ), you obviously cannot exactly set a sampling frequency 48 kHz, because the ratio of the two frequencies is not exactly a power of two.

- What sampling frequency  $\hat{f}_{\text{LRC}}$  can you set that is closest to  $f_{\text{LRC}}=48 \text{ kHz}$ ?
- Calculate the relative error  $\epsilon_{\text{rel}} = (f_{\text{LRC}} - \hat{f}_{\text{LRC}})/f_{\text{LRC}}$ .
- What ratio  $f_{\text{CLK}}/f_{\text{SYSCLK}}$  did you assume?

In the following, the individual parts of the AUDIO\_CODEC\_COM module are briefly introduced once again. Further details can be found in the lecture slides and the source code in EMIL.

**Frequency divider: CODEC\_CLK\_GEN** The three clock signals LRC, BCK and SYSCLK are generated by this module. The ratio  $P = f_{\text{CLK}} / f_{\text{SYSCLK}}$  is set in the prescaler module FRQ\_PRE\_DIV, which enables the internal counter in the frequency divider CODEC\_CLK\_GEN only in every P-th cycle ( $P = 2^p$ ) of the system clock CLK.

**Timing of actions: AUDIO\_CDC\_FSM** The main task of this module is to control the timing of

| Clock Signal                                 | Frequency                  |
|----------------------------------------------|----------------------------|
| FPGA system clock $f_{\text{CLK}}$           | 100 MHz                    |
| Audio codec oversampling $f_{\text{SYSCLK}}$ | $256 \cdot f_{\text{LRC}}$ |
| Bit clock $f_{\text{BCK}}$                   | $32 \cdot f_{\text{LRC}}$  |
| Sampling clock $f_{\text{LRC}}$              | approx. 48 kHz             |

Table 1.1: Frequency ratios of the clock signals occurring in the FPGA system.



Figure 1.2: Block diagram of the overall system.



Figure 1.3: Important points in time during serial-to-parallel and parallel-to-serial conversion.

serial-to-parallel and parallel-to-serial conversion. In particular, a regular Finite State Machine also controls the times at which bits are written to and read from the audio codec. Figure 1.3 shows this as an example for the left channel. Table 1.2 indicates which actions in the converters are triggered by the signals.

**Serial-to-parallel converter SER\_TO\_PAR\_LR** This module consists of one shift register per channel L/R, into which bits arriving at input DIN are shifted with each rising edge of BCK. If all 16 values of an audio sample have been read, the content of the respective shift register is copied into an associated parallel register. There the sample value remains stored and is available for further processing until it has to make room for a new value. The value of the signal LRC determines which pair of shift and parallel registers (for left or right channel) is currently updated.

**Parallel-to-serial converter PAR\_TO\_SER\_LR** It is your task to develop this module in this lab session. The module converts a 16-bit audio value calculated by the AUDIO\_PROCESSING module into a serial data stream and starts outputting it at output DOUT with each falling edge of BCK. The module does not need a parallel register, since we can assume that the AUDIO\_PROCESSING module will provide the processed audio signal values in time, and the values can be read directly into the shift register. Only one shift register shall be used for both channels L/R, in contrast to the serial-to-parallel converter. Remember: you have already started deriving a block diagram for a parallel-to-serial converter in the lecture.

## 1.3 Development of the parallel-to-serial converter

### 1.3.1 VHDL template PAR\_TO\_SER\_LR\_DUMMY.vhd

All VHDL modules necessary for communication with the audio codec are provided in EMIL. For the development of the parallel-to-serial converter PAR\_TO\_SER\_LR the file PAR\_TO\_SER\_LR\_DUMMY.vhd shall be used. This consists of the correct entity and architecture declarations, but without a meaningful behavioral description. Nevertheless, the module as well as the overall system can be simulated and synthesized.

| Signal                                    | Meaning                                                                                                                                          |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SHIFT_IN_L,</b><br><b>SHIFT_IN_R</b>   | shift a bit at input DIN (both L and R channel) into serial-to-parallel converter (SER_TO_PAR_LR)                                                |
| <b>SHIFT_OUT_L,</b><br><b>SHIFT_OUT_R</b> | shift a bit out of parallel-to-serial converter (PAR_TO_SER_LR) to output DOUT (both L and R channel)                                            |
| <b>SAVE_R_LOAD_L</b>                      | SER_TO_PAR_LR: copy content of shift register into parallel register (R channel)<br>PAR_TO_SER_LR: load new word into shift register (L channel) |
| <b>SAVE_L_LOAD_R</b>                      | SER_TO_PAR_LR: copy content of shift register into parallel register (L channel)<br>PAR_TO_SER_LR: load new word into shift register (R channel) |

Table 1.2: Meaning of output signals of Finite State Machine AUDIO\_CDC\_FSM.

Input and output signals of the PAR\_TO\_SER\_LR module to be developed are shown in Figure 1.4 and explained in Table 1.2 and the timing diagram in Figure 1.5.

The source code of PAR\_TO\_SER\_LR.DUMMY.vhd is shown in listing 1.1.

Listing 1.1: Template for the VHDL model PAR\_TO\_SER\_LR.DUMMY.vhd to be developed.

```

1 library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
3
entity PAR_TO_SER_LR is
5 generic(W : integer := 16);
port(
7 CLK, SRESETN: in std_logic;
PAR_IN_L, PAR_IN_R: in std_logic_vector(W-1 downto 0);
9 -- control signals for shifting bit out
SHIFT_OUT_L, SHIFT_OUT_R : in std_logic;
11 -- control signals for load in parallel word
SAVE_R_LOAD_L, SAVE_L_LOAD_R : in std_logic;
13 SER_OUT: out std_logic
);
15 end PAR_TO_SER_LR;
17 architecture BEHAVIORAL of PAR_TO_SER_LR is

```



Figure 1.4: Ein- und Ausgangssignale des zu entwickelnden Moduls PAR\_TO\_SER\_LR.

```

19 -- single shift reg for both channels
  signal SHIFT_REG_NEXT,SHIFT_REG : std_logic_vector( W-1 downto 0);
21
22 begin
23
24 -- process defining 1 shift reg
25 P2S_REGS: process(CLK)
26 begin
27   if CLK = '1' and CLK'event then
28     if SRESETN = '0' then
29       SHIFT_REG <= (others=>'0') after 2 ns;
30     else
31       SHIFT_REG <= SHIFT_REG_NEXT after 2 ns;
32     end if;
33   end if;
34 end process;
35
36 -----
37 -- insert your code below for next-state logic and output logic
38 -----
39 P2S_COMBIN: process(SHIFT_REG) -- modify sensitivity list as needed
40 begin
41   -- delete next lines and replace by your code
42   SHIFT_REG_NEXT <= not SHIFT_REG after 2 ns;
43   SER_OUT <= SHIFT_REG(0) after 2 ns;
44
45 end process;
46
47 end BEHAVIORAL;

```

---



Figure 1.5: Timing of the control signals for the PAR\_TO\_SER\_LR parallel-serial converter.

## Modell | Model

## Testbench | test bench



Figure 1.6: Hierarchical structure of the modules.

### 1.3.2 Hierarchical VHDL design

The VHDL design is in general hierarchical, i.e. the functionality is divided into several modules, some of which are subdivided into several modules again. The top-level module AUDIO\_SYSTEM\_TOP instantiates the modules AUDIO\_PROCESSING and AUDIO\_CODEC\_COM, each of which instantiates others. The files available in EMIL show the exact VHDL syntax for how to include so-called components. Overall, you can assume that the provided modules all instantiate correctly, as well as correctly compile, simulate, and synthesize. Figure 1.6 shows the design hierarchy of the modules.

A number of port signals are commented out, which are only needed in later lab session. The AUDIO\_PROCESSING module in the AUDIO\_PROCESSING\_DUMMY.vhd file is merely a placeholder and simply forwards the PAR\_IN\_L or PAR\_IN\_R input signals unchanged to PAR\_OUT\_L or PAR\_OUT\_R, respectively.

With the file AUDIO\_SYSTEM\_TOP\_DO.do a simple testbench is provided. It simulates the complete system with a simple input bit sequence. With this you can test if you have included all files correctly in ModelSim. Of course the output signal DOUT does not show a meaningful signal shape yet, because you still have to design your own parallel-to-serial converter. Adjust this testbench for your needs, i.e. change the input sequences with the force command and add more signals from the PAR\_TO\_SER\_LR module to the waveform viewer with the add wave command. Further changes are not necessary in the do. file.

Adding internal signals from modules instantiated as components by other modules is done by a 'path specification'. For example,

```
add wave INST_AUDIO_CODEC_COM/INST_SER_TO_PAR_LR/SHIFT_REG_R
```

adds the current value of the shift register signal SHIFT\_REG\_R of the serial-to-parallel converter to the waveform viewer. The path consists of the names of the instances of the components leading to the shift register. Note that the module name (entity name) and the name of the instances of this module must always be different (so don't use the entity name!). You can get these names from the VHDL source code or more comfortably from the instance browser of ModelSim (see Figure 1.7). After starting the simulation, click on the sim tab, then select the desired component in the Instance window and then the desired signal in the Objects window. Select it and drag it to the Transcript window, where the text path to be copied to the .do file appears.

## Prep Task 2

Design a behavioral model in VHDL of the PAR\_TO\_SER\_LR parallel-to-serial converter and verify it.

- First, simulate the overall system as it was provided to you – incomplete yet, but ready for simulation. If you succeed in the simulation without errors, start modeling the parallel-to-series converter.
- Use the file PAR\_TO\_SER\_LR.DUMMY.vhd as starting point and use the block diagram from the lecture as a guideline for implementation.
- Please mind, the module should have only one shift register for both channels and no parallel registers.
- Write 3 (non-trivial) test cases that will give you confidence that your parallel-to-serial converter will work. One test case
  - has a meaningful title (for your manager who is responsible for the project) and



Figure 1.7: Selection of signals of interest for simulation in ModelSim.

- a detailed description of the scenario (for your intern who is writing the testbench).
- This includes describing what you need to observe in the waveform viewer to know that the test case has passed.

- Simulate at least these 3 test cases and copy per test case a relevant part of your ModelSim simulation (waveforms) into the preparation sheet, based on which you explain why the test passed (if necessary why you think not).  
Please note: Always simulate your module in the overall system. It is duplicate work to write a testbench only for the parallel-to-serial converter, because a good testbench already exists. Better adapt this one appropriately.

Congratulations if you got this far in your preparation. That was quite a bit of work and you had to familiarize yourself with VHDL modeling and tools. Now you can look calmly at the lab session.

## 1.4 Implementation on FPGA and test

If the functional simulation was successful, we can move on to implementing the circuit on the FPGA. Check out the video tutorial or the tutorial in EMIL on how to synthesize with Xilinx Vivado, place & route and configure the device. The FPGA used is a Xilinx Artix-7 XC7A100T-2CSG324 on the ModSys 2.0 evaluation board (see Figure 1.8). The board provides a 100 MHz oscillator with clock divider as source for the system clock and allows to connect peripheral boards via four PCB connectors. .xdc files are used to define the mapping between FPGA pins and peripheral module devices.



Figure 1.8: ModSys2.0 board with Artix-7 FPGA for the implementation of the audio system.



Figure 1.9: Settings in Xilinx Vivado for the XC7A100T.

When creating a new project you have to select the FPGA settings as shown in Figure 1.9. Connect the AudioCodecBoard to the lower connector, the JTAG cable for programming to the JTAG socket and the power supply to the socket left of the "Power On Switch". Turn on the power with this switch before configuring (programming) with Vivado. The configuration of Xilinx FPGAs is volatile, i.e. is lost when the board is switched off. Only reconfiguration helps, unless the configuration was stored in the external memory and the FPGA is configured to load it automatically from the memory at power-on reset (we do not need this function in the lab).

The analog inputs of the AudioCodecBoard (LINE IN) have been specified for so called *line levels* with max.  $\pm 1,4\text{V}$  amplitude.

**Adjust the function generator so that these levels are not exceeded (always check with the oscilloscope) to prevent damage to the hardware.**

#### Lab Task 1: Test of the system with a sinusoidal signal

With this test you can see if you have implemented everything correctly. The input signal at LINE IN should appear as a time-shifted version at the output LINE OUT when measured with the oscilloscope. If this is not the case, first see if you have configured the FPGA successfully (*Programming succeeded*) and the power is on at the Modsyst 2.0 board. If the output still does not meet the expectation, continue first with Lab Task 2 for troubleshooting and return later.

- Apply a sinusoidal voltage of e.g. 1 V and 1 kHz to the LINE IN input. Check the

amplitude and frequency with the oscilloscope before connecting the function generator. Display both, the input and output signal, on the oscilloscope.

- If the output signal was as expected, slowly turn up the frequency of the sinusoidal signal to 30 kHz. Describe what you observe and name some characteristic frequency and amplitude values.

### Lab Task 2: Analysis of serial bit streams

In this task, we look at the serial, digital data that is exchanged between the FPGA and the audio codec. If Lab Task 1 did not bring the desired results, here is the possibility to make an error analysis based on the digital data. Maybe your VHDL model is correct, but an amplifier or the audio codec is broken...

- Apply a sinusoidal voltage of e.g. 1 V and 20 kHz to the LINE IN input. Take a complete data frame of DIN and DOUT together with the BCK and LRC signal. One data frame corresponds to one complete period of the LRC signal with one sample each for left and right channel.
- Determine the 16 bit sampling values for left and right channel and express them as decimal numbers. Are the values of DIN and DOUT the same? Explain.
- Record two consecutive data frames. What can you now state about DIN and DOUT?
- Document the results with oscilloscope images (screenshots, but *not* cell phone photos).

The data sheet of the PCM3006 [3] provides information about the timing requirements of the clock signals BCK and LRC as well as the serial data streams DIN and DOUT to be met for error-free communication (see Figure 1.10). In the following tasks, we will check whether our FPGA meets these timing requirements under the given lab conditions.

It should be noted here that the datasheet uses different signal names that are audio codec-centric, while the ones we use are FPGA-centric. Table 1.3 gives the correspondences between the signal names as used in the VHDL code (and as labeled on the Audio Codec Board) and those from the PCM3006 datasheet. It should be noted in particular that DIN and DOUT swap their roles.

| Label<br>Audio Codec Board | Datasheet<br>PCM3006 |
|----------------------------|----------------------|
| LRC                        | LRCIN                |
| BCK                        | BCKIN                |
| DIN                        | DOUT                 |
| DOUT                       | DIN                  |

Table 1.3: Different signal names on the Audio Codec Board and in the PCM3006 data sheet.



Figure 1.10: Timing requirements of the PCM3006 audio codec [3].

### Lab Task 3: Bit Timing

In this part you are to check whether the specifications of the data sheet for the timing behavior of the signals are met. The signal names according to the left column in table 1.3 are used in the following. Measure the following times and compare them with the data sheet.

- BCK pulse cycle time  $t_{(BCY)}$  (measure at BCK)
- DOUT delay time to BCK falling edge  $t_{(BDO)}$  (measur at BCK and DIN)
- DIN setup time  $t_{(DIS)}$  (measure at DOUT and BCK)
- DIN hold time  $t_{(DIH)}$ , (measure at DOUT and BCK)

#### Lab Task 4: Delay of the overall system

First measure the time delay between the analog LINE IN input and the LINE OUT output. Then you are to estimate which part of the delay is due to the audio codec and which part is due to the FPGA.

- What is the risk if you measure the delay with a sinusoidal signal?
- Therefore, perform the measurement with a rectangular 1 kHz pulse with a duty cycle of 10% and  $\pm 1$  V amplitude. How do you measure the delay you are looking for?
- Explain the shape of the output signal. Is it still rectangular?
- Which part of the delay is due to the audio codec, which due to the FPGA? Use the results of Lab Task 2 for your considerations, too.

Great, you have successfully completed the first lab session! Now you can design simple state machines in VHDL, apply the tools for simulation and synthesis and use function generator and oscilloscope for testing your circuit.

