# Lab 7 - Speaker

106033233 資工大四 周聖諺 (Sheng-Yen Chou)

2022-03-28

# **Contents**

| Lab 7 - Speaker               | 4    |
|-------------------------------|------|
| Lab 7-1: Parallel-To-Serial   | . 4  |
| Design Specification          | . 4  |
| Design Implementation         | . 4  |
| Global Variables              | . 4  |
| Frequency Divider             | . 4  |
| Note Generation               | . 5  |
| Speaker Control               | . 5  |
| Speaker                       | . 5  |
| I/O Pin Assignment            | . 5  |
| Block Diagram                 | . 6  |
| RTL Simulation                | . 6  |
| Lab 7-2: Speaker Control      | . 6  |
| Design Specification          | . 6  |
| Design Implementation         | . 7  |
| Global Variables              | . 7  |
| Debounce                      | . 7  |
| One-Pulse                     | . 7  |
| Frequency Divider             | . 7  |
| Controller                    | . 7  |
| Note Generation               |      |
| Speaker Control               | . 8  |
| Binary To 7-Segment Convertor | . 8  |
| 7-Segment Frequency Divider   | . 8  |
| 7-Segment Display             | . 8  |
| Speaker                       | . 8  |
| I/O Pin Assignment            | . 9  |
| Block Diagram                 |      |
| RTL Simulation                |      |
| Lab 7-3: Speaker Control      |      |
| Design Specification          |      |
| Design Implementation         |      |
| I/O Pin Assignment            |      |
| Block Diagram                 |      |
| RTL Simulation                |      |
| Discussion                    | . 10 |

| Lab 7 - Speaker | 2022-03-28 |
|-----------------|------------|
|                 |            |
| Conclusion      |            |

# Lab 7 - Speaker

106033233 資工大四 周聖諺 (Sheng-Yen Chou)

## Lab 7-1: Parallel-To-Serial

# **Design Specification**

Source Code

## global

Global variables

## **Frequency Divider**

Output: [9:0] clk\_out

Input: clk, rst\_n

#### **Note Generation**

Input clk, rst\_n, [21:0] note\_div

Output [15:0] audio\_left, [15:0] audio\_right

## **Speaker Control**

input clk, rst\_n, [15:0] audio\_in\_left, [15:0] audio\_in\_right

Output audio\_mclk, audio\_lrck, audio\_sck, reg audio\_sdin, [9:0] clk\_out, [15:0] buff\_idx

## **Speaker**

Input clk, rst\_n

Output audio\_mclk, audio\_lrck, audio\_sck, audio\_sdin

## **Design Implementation**

**Global Variables** The global variables are used across the whole project.

**Frequency Divider** The frequency divider module output a vector which represents the clock divided by  $2^1$ ,  $2^2$ ,  $2^3$ ...,  $2^{10}$ . It can be simply implemented by adding 1 to a variable [9:0] clk\_out at each clock pulse.

**Note Generation** This module generates the serial audio signal divided by note\_div. The module divides the clock by the argument note\_div and multiply with the amplitude 16′ hB000 when the clock raises. Otherwise, multiply with the amplitude 16′ h5FFF.

**Speaker Control** The speaker\_controll module generate the clocks for the speaker, including mclk, lrck, and sck. The clock mclk is 25M Hz, which need to divide the main clock (100M Hz) by 4. The clock lrck is 25M/128 Hz, which need to divide the main clock (100M Hz) by  $2^9$ . The clock sck is 25M/4 Hz, which need to divide the main clock (100M Hz) by  $2^4$ .

In the hand, the module also serialize the 16-bits parallel data. The module transmit 1 bit per sck clock and this can be implemented by a rotating index of the 16-bits register.

The module also controls the switch between the left and the right channel. When the lrck raises, the module will produce the sound of the left channel to the audio\_sdin. Otherwise, it will output the right channel.

**Speaker** It is the top module of this lab. The Note Generation module will generate the left and right channel sound based on the given note\_div. The module speaker control will take the left and right channel of sound (audio\_in\_left and audio\_in\_right) as input and serialize them.

## I/O Pin Assignment

| I/O | audio_sdin | audio_sck | audio_lrck | audio_mclk |
|-----|------------|-----------|------------|------------|
| LOC | B16        | B15       | A16        | A14        |

| I/O | clk | rst | btn_l | btn_m | btn_r | btn_u | btn_d | d_sel[0] | d_sel[1] | d_sel[2] | d_sel[3] |
|-----|-----|-----|-------|-------|-------|-------|-------|----------|----------|----------|----------|
| LOC | W5  | V17 | W19   | U18   | T17   | T18   | U17   | U2       | U4       | V4       | W4       |
|     |     |     |       |       |       |       |       |          |          |          |          |

| I/O | d_out[0] | d_out[1] | d_out[2] | d_out[3] | d_out[4] | d_out[5] | d_out[6] | d_out[7] |
|-----|----------|----------|----------|----------|----------|----------|----------|----------|
| LOC | V7       | U7       | V5       | U5       | V8       | U8       | W6       | W7       |

## **Block Diagram**

Lab 7-1 Logic Diagram

#### **RTL Simulation**

Lab 7-1 RTL Simulation

## **Lab 7-2: Speaker Control**

## **Design Specification**

Source Code

#### **Debounce**

Input: rst, clk, push

Output: push\_debounced

#### **One-Pulse**

Input: clk, rst, push

Output: push\_onepulse, push\_onepulse\_long, push\_debounced, push\_debounced\_long, push\_sig, push\_sig\_long

## **Frequency Divider**

Output: [9:0] clk\_out

Input: clk, rst\_n

#### Controller

Input: clk, rst\_n, btn\_l, btn\_m, btn\_r, btn\_u, btn\_d

Output: [3:0] audio\_level\_left, [3:0] audio\_level\_right, [21:0] note\_div

## **Note Generation**

Input: clk, rst\_n, [21:0] note\_div, input [3:0] audio\_level\_left, [3:0] audio\_level\_right

Output: [15:0] audio\_left, [15:0] audio\_right, [15:0] audio\_level\_magnitude

# **Speaker Control**

Input: clk, rst\_n, [15:0] audio\_in\_left, [15:0] audio\_in\_right

Output: audio\_mclk, audio\_lrck, audio\_sck, audio\_sdin, [9:0] clk\_out, [15:0] buff\_idx

## **Binary To 7-Segment Convertor**

Input: [3:0] i

Output: [3:0] P, [7:0] D

## 7-Segment7 Frequency Divider

Input: clk, rst

Output: clk\_out

## 7-Segment Display

Output: [0:3] d\_sel, [7:0] d\_out

Input: clk, rst, [7:0] d0, [7:0] d1, [7:0] d2, [7:0] d3

## **Speaker**

Input: clk, rst\_n, btn\_l, btn\_m, btn\_r, btn\_u, btn\_d

Output: audio\_mclk, audio\_lrck, audio\_sck, audio\_sdin, [3:0] d\_sel, [7:0] d\_out

## **Design Implementation**

**Global Variables** The global variables are used across the whole project.

**Debounce** For each click, the module will delay 4 clock cycle and then raise the debounce pulse. I use 4 registers to represent the delay state and send a pulse while 4 registers are all 1s.

**One-Pulse** I use a counter to count the clock cycles during the button is pressed. If the counting exceed a threshold, it will trigger a long press pulse push\_onepulse\_long. Otherwise, it will trigger a click pulse push\_onepulse.

## Frequency Divider Same as lab 6-1

**Controller** The controller module produces the corresponding note\_div for the note\_gen module according to the buttons. I concatenate the debounce signal for every button and assign different numbers to note\_div to generate sound with different tones.

In the other hand, whenever the left/right button is pressed, the module will add/minus 1 to the volume counter.

**Note Generation** It's similar to the note\_gen module in the lab 6-1 but the note\_gen in the lab 6-1 will produce the same magnitude in left and right channel. In lab 6-2, note\_gen can produces different magnitude in the left and right channel. The arguments audio\_level\_left and audio\_level\_right set the audio volume of the left and right channel.

The audio is divided into 16 levels between 16' hB000 and 16' h7DFF. The module will control the amplitude with the formula audio\_level \* (`AUDIO\_IN\_BITS\_N'hB000 - `AUDIO\_IN\_BITS\_N'h7DFF)/ 15 + `AUDIO\_IN\_BITS\_N'h7DFF.

**Speaker Control** Same as lab 6-1.

**Binary To 7-Segment Convertor** Convert 4-bit binary number to 7-segment display with switch-case syntax.

**7-Segment Frequency Divider** To generate the 1000 Hz clock, I use variables counter\_in and counter\_out to count from 0 to 50000. The counter\_in will store the value for the next time step and pass the value to the counter\_out when the clock raises. The reason why we need 50000 counting is each counting is triggered only when the clock raises, so the circuit will count 1 more for every twice clock pulses.

**7-Segment Display** Since we can only control one digit of the 7-segment display each time, I design a module that takes the 4-digit patterns as input and shows the 1 digit on the display when the clock raises. Whenever the clock raises, the module will switch the control d\_sel to different digit and shows the corresponding digit. Take an example, when the first clock raise occur, the module will set d\_sel = 4′ b1110 and d\_out = d0. As for second clock pulse, the module will output d\_sel = 4′ b1101 and d\_out = d1 and so on.

**Speaker** The module speaker combines all modules listed above. The controller module detects the press of the buttons and give the note\_div, audio\_level\_left and audio\_level\_right parameter. The note\_gen module generate the left and right channel sound according the note\_div`,audio\_level\_leftandaudio\_level\_right. Thespeaker\_controlserializes the audio\_in\_leftandaudio\_in\_right" signal as the output of the left and right channel.

Finally, segment7 and display\_7seg module convert the binary number to 7-segment display pattern and shown them on the 7-segment display.

# I/O Pin Assignment

| I/O | audio_sdin | audio_sck | audio_lrck | audio_mclk |
|-----|------------|-----------|------------|------------|
| LOC | B16        | B15       | A16        | A14        |

| I/O | clk | rst  | btn_l  | btn_m    | btn_r   | btn_u   | btn_d   | d_sel[0] | d_sel[1] | d_sel[2] | d_sel[3] |
|-----|-----|------|--------|----------|---------|---------|---------|----------|----------|----------|----------|
| LOC | W5  | V17  | W19    | U18      | T17     | T18     | U17     | U2       | U4       | V4       | W4       |
|     |     |      |        |          |         |         |         |          |          |          |          |
| I/O |     | d_ou | t[0] ( | d_out[1] | d_out[2 | .] d_oı | ut[3] ( | d_out[4] | d_out[5] | d_out[6] | d_out[7] |
| LOC |     | V7   | Į      | J7       | V5      | U5      | ,       | V8       | U8       | W6       | W7       |

# **Block Diagram**

Lab 7-2 Logic Diagram

# **RTL Simulation**

Lab 7-2 RTL Simulation

# Lab 7-3: Speaker Control

# **Design Specification**

Source Code

# **Design Implementation**

I/O Pin Assignment

| I/O | audio_sdin | audio_sck | audio_lrck | audio_mclk | switch |
|-----|------------|-----------|------------|------------|--------|
| LOC | B16        | B15       | A16        | A14        | V16    |

| I/O | clk | rst  | btn_l  | btn_m    | btn_r   | btn_u   | btn_d | d_sel[0] | d_sel[1] | d_sel[2] | d_sel[3] |
|-----|-----|------|--------|----------|---------|---------|-------|----------|----------|----------|----------|
| LOC | W5  | V17  | W19    | U18      | T17     | T18     | U17   | U2       | U4       | V4       | W4       |
|     |     |      |        |          |         |         |       |          |          |          |          |
| I/O |     | d_ou | t[0] ( | d_out[1] | d_out[2 | !] d_oı | ut[3] | d_out[4] | d_out[5] | d_out[6] | d_out[7] |
| LOC |     | V7   | ι      | J7       | V5      | U5      | ,     | V8       | U8       | W6       | W7       |

## **Block Diagram**

Lab 7-3 Logic Diagram

## **RTL Simulation**

Lab 7-3 RTL Simulation

## **Discussion**

In lab 5-2, it took me lots of time to design the state machine because the always block cannot be activated by 2 edge-triggered variables. Finally, I store the variables in the 2 independent variables and add them together as the clock raises. In addition, when I implement the one-pulse module, it took me much time to detect long press and click in the mean time. In the end, I use a counter to count the clock cycle during the pressed button.

# **Conclusion**

The lab5 is much more difficult than previous labs. We' ve learned how to design a more complex circuit with the concept of state machine. We also gradually get used to a larger project.

# Reference

• None