

# CPET-561 Embedded Systems Design I

Due: 03/30/2020

### **Education Objective**

The educational objective of this demo is to become familiar with IP cores used to interface with the audio CODEC provided on the DE1-SoC board.

#### **Technical Objective**

The technical objective of this laboratory is to design an embedded system for the Nios II processor and DE1-SoC that will load an audio (.wav) file into the external SDRAM and play it through the audio CODEC and an attached speaker.

#### **Demonstration Procedure**

- 1. Download the **Audio\_Demo\_Support\_Files** from MyCourses and unzip the folder.
- 2. Create a folder named **Audio\_Demo** and within it create a folder named **Audio Demo quartus**.
- 3. Create a new Quartus project and name it Audio\_Demo. Put the nios\_system.qsys file and the Audio Demo.vhd file in the Audio Demo quartus folder.
- 4. Open QYSYS and load the **nios\_system.qsys** file. This system has many of the standard components. New for this demo are:
  - a. The **audio\_video\_config\_component** this is a core that communicates with the CODEC via the I<sup>2</sup>C bus. It initializes the CODEC when the design is programmed into the FPGA.
  - b. **The audio component** this core manages the reads from CODEC (for microphone data) and the writes to the CODEC (for speaker data)

Additionally there is an **SDRAM controller** for interfacing with the off-FPGA SDRAM. We will use that for storing the audio data to be played. Because the SDRAM is being used, the **clock source core** is used to provide the *SDRAM clock at a 3 ns offset* from the 50MHz clock. The onchip memory is used for the source code storage (you can tell because it is connected to the instruction master). Finally, an **interval time** (timer\_0) is included as a periodic interrupt generator. It has been configured to fire an interrupt every 20.48 us (1/sample rate).

- 5. Generate the QSYS. There will be 1 warning, but it is okay to ignore. Do not connect the interrupt from the audio core.
- 6. In Quartus add the **nios\_system.qip** file and the **Audio\_Demo.vhd** file to the project. Import the pin assignments. Compile and program the board.



## CPET-561 Embedded Systems Design I

- 7. Open NIOS II Software Build Tools for Eclipse. Be sure to point your workspace to the Audio\_Demo\_quartus/software folder. Create a new application and BSP from template. Call the app Audio\_Demo\_App. Be sure to select the correct nios\_system .sopcinfo file from the Audio Demo quartus folder.
- 8. Move the **Audio\_Demo.c** and the .wav file to the application folder. Copy the system.h file from the BSP to the App.
- 9. Open the BST editor (right click on Audio\_Demo\_App\_bsp > NIOS II > bsp editor). Click on the "Software Packages" tab and click to enable alter\_hostfs. This will allow you to read a file from the computer via the C program.
- 10. Click on the "Linker Script" tab and left click on each reference to new\_sdram\_controller\_0 in Linker region names area and change them to onchip\_memory. This will ensure that all of the code exists in onchip memory so it does not get overwritten when the audio data is loaded into SRAM.
- 11. Generate the BSP, copy the **system.h** file and build the project.
- 12. Right click on the application and choose Debug As > NIOS II hardware
- 13. In the debug perspective, click on Resume. The program will go away for a LONG time. It is loading the file from the file system to the SDRAM. Be patient.
- 14. You will know when it is done loading when you see the message "file read". You should also hear audio at this point.
- 15. Be sure to edit the C program to change the FIRST\_TIME def from 1 to 0. If you don't do this, the file will load every time you try to run the program. The data will remain in the SDRAM as long as the board remains on.
- 16. Look in the **Audio\_Demo.vhd** file and you will see where I have provided a mechanism to view the CODEC signals on GPIO pins. View the audio sample clock and data on the oscilloscope. Review the C code to understand how the samples are stored and retrieved from SDRAM.
- 17. Demonstrate your working system for credit.
- 18. Save everything as we will be coming back to this next week.