

# **Development Kit**

# **Getting Started User Guide**



Copyright © 2005 by Terasic Technologies Inc.

http://www.terasic.com

#### TREX C1 DEVELOPMENT KIT

## Page Index

| CHAPTER 1 ABOUT THIS KIT                                                         |    |
|----------------------------------------------------------------------------------|----|
| 1-1 Features                                                                     | 1  |
| 1-2 Getting Help                                                                 | 1  |
| CHAPTER 2 YOUR T-REX BOARD                                                       | 2  |
| 2-1 THE TREX C1 (TR1)                                                            | 2  |
| 2-2 The Board                                                                    | 2  |
| 2-3 FEATURES                                                                     |    |
| 2-4 Power Up the Board to See the Demo                                           | 4  |
| CHAPTER 3 INSTALLATION                                                           | 7  |
| 3-1 Install Quartus II                                                           | 7  |
| 3-2 CONNECTING THE USB CABLE TO THE BOARD - USB BLASTER INSTALLATION             | 7  |
| 3-3 POTENTIAL PROBLEMS AND WORKAROUND FOR USING USB BLASTER                      |    |
| 3-4 INSTALL TERASIC LAB CD-ROM                                                   |    |
| CHAPTER 4 FIRST LAB: 7-SEG DISPLAY                                               |    |
| 4-1 Power Up the Board                                                           | 11 |
| 4-2 REPEATING THE LAB FROM SCRATCH                                               |    |
| 4-3 COMPILING THE DESIGN                                                         |    |
| 4-4 DOWNLOAD BITSTREAM                                                           | 15 |
| 4-5 THE TOP LEVEL RTL AND PIN ASSIGNMENT                                         |    |
| CHAPTER 5 LAB 2: HOW TO WORK WITH SCANNED 7-SEG DISPLAY                          |    |
| 5-1 THE 7-SEG DISPLAY MODULE ON TREX C1                                          |    |
| 5-2 Pure Combinational Logic Lab - Using Non-Scanned Mode                        |    |
| 5-3 THE VERILOG CODE FOR COMBINATIONAL LAB                                       |    |
| 5-4 SEQUENTIAL LOGIC LAB - USE THE SCANNED MODE                                  |    |
| 5-5 When Counter = 00                                                            |    |
| 5-6 THE VERILOG CODE FOR SCANNED MODE                                            |    |
| CHAPTER 6 LAB 3: TREX CONTROL PANEL                                              |    |
| 6-1 CONNECT PC TO THE BOARD USING USB CABLE                                      |    |
| 6-2 CONTROL THE BOARD USING TREX PANEL                                           |    |
| 6-3 THE FLASH PROGRAMMER                                                         |    |
| 6-4 THE SDRAM CONTROLLER AND PROGRAMMER                                          |    |
| 6-5 PS2 COMMUNICATION TO THE BOARD                                               |    |
| 6-6 TOOLS - MULTI-PORT SDRAM/FLASH CONTROLLER - USE A MUSIC PLAYER AS AN EXAMPLE |    |
| 6-7 VIRTUAL DPDT SWITCHES                                                        |    |

| CHAPTER 7 LAB 4: CD-QUALITY MUSIC BOX                      |  |
|------------------------------------------------------------|--|
| 7-1 LOAD ANOTHER MUSIC FILE TO PLAY FROM FLASH             |  |
| 7-2 PLAY MUSIC FROM 8MBYTE SDRAM                           |  |
| 7-3 DETAILS OF THE AUDIO DAC CONTROLLER                    |  |
| 7-4 A REFERENCE DESIGN: 1KHZ SOUND GENERATOR               |  |
| 7-5 HOW TO CREATE YOUR OWN MUSIC RAW DATA                  |  |
| CHAPTER 8 LAB 5: NTSC/PAL TV CONTROLLER                    |  |
| 8-1 YCrCb and Component Digital Video                      |  |
| 8-2 TV LAB - NTSC/PAL TV COLOR PATTERN GENERATOR           |  |
| CHAPTER 9 INTERFACES AND ASSOCIATED TESTING CODE           |  |
| 9-1 50 MHz and 27 MHz Oscillators                          |  |
| 9-2 LED1 - LED8                                            |  |
| 9-3 8 PUSH-BUTTON SWITCHES: KEY[7] TO KEY[0]               |  |
| 9-4 7-SEG DISPLAY                                          |  |
| 9-5 VGA DAC                                                |  |
| 9-6 AUDIO DAC                                              |  |
| 9-7 PS2 & RS-232 INTERFACE                                 |  |
| 9-8 VIDEO ENCODER (NTSC/PAL TV OUT) - LAB 5                |  |
| 9-9 DIP Switch                                             |  |
| 9-10 SDRAM INTERFACE                                       |  |
| 9-11 FLASH MEMORY                                          |  |
| 9-12 COMPACT FLASH CARD                                    |  |
| 9-13 Expansion Connectors (JP1, JP2)                       |  |
| CHAPTER 10 RS-232 VERSION OF THE TREX CONTROL PANEL        |  |
| 10-1 CONNECT PC TO THE BOARD USING RS232                   |  |
| 10-2 CONTROL THE BOARD USING RS232 VERSION OF TREX PANEL   |  |
| 10-3 THE C++ SOURCE CODE                                   |  |
| CHAPTER 11 LAB 8: NIOS II 5.0 CORE                         |  |
| 11-1 LOAD NIOS II 5.0 ON TREX C1                           |  |
| 11-2 RUNNING NIOS II ON TREX C1                            |  |
| CHAPTER 12 APPENDIX                                        |  |
| 12-1 REVISION HISTORY                                      |  |
| 12-2 TREX CD-ROM DIRECTORY STRUCTURE AND REFERENCE DESIGNS |  |
| 12-3 SCHEMATIC                                             |  |
| 12-4 ALWAYS VISIT TREX C1 WEBPAGE FOR NEW LABS             |  |



# **About this Kit**

The TREX C1 Development Kit provides everything you need to develop many digital designs using Altera Cyclone device. The Getting Started User Guide is written in a way to enable users to walk through many reference designs in 30 minutes. This chapter provides users key information about the kit.

### **Features**

#### The TREX C1 Development Kit includes:

- ✓ TREX C1 Development Board.
- ✓ USB Cable for power supply and FPGA programming.
- ✓ TREX C1 CD-ROM containing TREX API, reference designs, and specs.
- ✓ Altera Quartus II 5.0 Web Edition CD-ROM and Nios II 5.0 CD-ROM
- ✓ RS-232 Cable for board control using UART protocol.
- ✓ This Getting Started Guide.
- ✓ Full-size component reference card.
- ✓ 9V DC Wall-mount power supply (backup power)

### **Getting Help**

Here are some places to get help if you encounter any problem:

- Email to support@terasic.com
- ✓ SkyPE: Terasic
- ✓ Taiwan & China: +886-3-553-9672
- ✓ Korea & Japan: +82-2-512-7661
- ✓ \_North America: support@terasic.com

Chapter

# **Your T-REX Board**

This chapter will walk you through each part of your TREX C1 (TREX1) board to illustrate the features equipped.

# The TREX C1 (TR1)



The TREX C1 is designed using the same strict design and layout practices we used in our other mass production OEM products for car infotainment systems with the highest QC standard. Major design and layout considerations are listed below:

Layout traces and components are carefully arranged so that they are properly aligned. This nice alignment will increase the yield for manufacturing and ease board debugging procedure.

Jumper-free design for robustness. Jumpers are a great point of failure and might cause frustration for users who don't keep the manuals with them all the time. TR1 board uses four 0-ohm SMT resistors to replace 4 jumbers (used for power measurement in different areas).

Components' selection was made according to the volume shipped. We selected the most common component configuration used in PC and DVD players to ensure the continuous supply of the component resource in the future.

Protection on Power and IOs are considered to cover most of the accidental cases in the field.

### **The Board**

Examine your board with the following diagram in Figure 2.1. We provide a quick reference card with the kit for you to use.



<u>Figure 2.1. TREX C1 Development Board Components & Interfaces</u> (Same as the full-size component reference card attached in the package)

### **Features**

TREX1 board provides users many features to enable various multimedia project developments. Component selection was made according to the most popular design in volume production multimedia products such as DVD, VCD, and MP3 players. This TREX1 platform allows users to quickly understand all the insight tricks to design real multimedia projects for industry.

- ✓ Altera Cyclone 1C6 FPGA with 6000 LEs
- ✓ Altera Serial Configuration deivices (EPCS1) for Cyclone 1C6
- ✓ USB Blaster built in on board for programming and user API controlling

- ✓ JTAG Mode and AS Mode are supported
- ✓ 8Mbyte (1M x 4 x 16) SDRAM
- ✓ 1Mbyte Flash Memory
- ✓ CF Card Socket
- ✓ 8 Push-button switches
- ✓ 4-bit DIP Switch
- ✓ 8 User LEDs
- ✓ 50MHz Oscillator and 27MHz Crystal for external clock source
- ✓ 16-bit CD-Quality Audio DAC with line-out jack
- VGA DAC (4-bit resistor network) with VGA out connector
- ✓ TV Encoder (NTSC/PAL) and TV Out connector
- ✓ RS-232 Transceiver and 9-pin connector
- ✓ Two 40-pin Expansion Headers with resistor protection
- Terasic Lab CD-ROM which contains many examples with source code to exercise the boards, including: SDRAM and Flash Controller, CD-Quality Music Player, VGA and TV Labs, CF Card reader, RS-232/PS-2 Communication Labs, and User-Control API.

### Power Up the Board to See the Demo

TREX1 board comes with a preloaded bitstream to demostrate some features of the board. This bitstream also allows users to check if the board is working properly in seconds. Perform the following steps:

- 1. Connect the USB cable from PC to your TREX1 board
- 2. Connect your headphone or PC speaker to the line-out jack of TREX1
- 3. Connect your LCD Monitor to your TREX1
- 4. Press the Power ON/OFF Switch on TREX1.
- Make sure the [RUN<->PROG] switch is set to RUN position (Note that PROG position is only used for AS Mode programming). Please refer to Figure 2.2.



Figure 2.2. JTAG/Operation (RUN) mode and AS Mode (PROG) switch settling.

 You should be able to see the board is running. And you should hear the 1K/2khz sounds from your headset's left and right channels, respectively.



Figure 2.3. USB, Headset, and VGA Connection

#### What you should see and hear

- You should hear 1KHz and 2KHz sound from the left and right channels of headset/speaker, respectively.
- ✓ You should see a 4096-color pattern on your LCD monitor. Set the DIP switch 4 to ON for 800x600; set DIP switch 4 to OFF for 640x480 (Please refer to Figure 2.4).
- ✓ You should see the LEDs and 7-SEG display are running.
- Set DIP switch 1, 2, 3 to ON will turn its corresponding 7-SEG display

### digit (3, 2, 1) OFF, respectively.



Figure 2.4. 4096-color VGA Pattern

Chapter

# Installation

This chapter will walk you through each step to install the kit on your PC and bring up the board correctly.

## Install Quartus II



You need Quartus II installed on your PC to use TREX1 board. Please refer to "Installing the Quartus II Software" in the Quartus II Installation & Licensing Manual for PCs, which is included on the TREX Development Kit CD-ROM, for the software installation instructions.

- ✓ Install Quartus II Web Edition using the QuartusII CD-ROM in the kit.
- ✓ Log on to the Altera web site at www.altera.com/licensing.
- Click "Quartus II Web Edition Software" and follow the instructions to request your license. A license file is e-mailed to you.
- Follow the instructions in the "Specifying the License File" in the Quartus II Installation & Licensing Manual for PCs, included on the TREX Development Kit CD-ROM.

## Connecting the USB Cable to the Board - USB Blaster Installation

The TREX1 Development Board obtains power from either the USB or the 9V-DC connector. The power source is selected automatically without using any jumper to simplify the using of the board and to avoid any potential problem caused by jumpers. Do the following steps to install both power and USB blaster programming capabilities for TREX1 board.

- ✓ Connect your USB-Blaster download cable to the TREX1 board.
- ✓ The Found New Hardware wizard may open and prompt you to install a new hardware driver. Close the wizard.
- Verify the USB-Blaster driver is located in the Quartus II directory:\<Quartus II directory>\drivers\usb-blaster. If the driver is not in your directory,

download the USB-Blaster driver from the Altera web site.

http://www.altera.com/support/software/drivers

- ✓ For Window 2000, choose Settings > Control Panel (Windows Start menu); for Window XP, choose Control Panel (Window Start Menu).
- ✓ Click Switch to Classic View if you are not in the classic view.
- ✓ Double-click the Add Hardware icon to start the Add hardware wizard and click Next to continue.
- ✓ Select Yes, I have already connected the hardware and then click Next.
- Select Add a new hardware device from the Installed hardware list. Then click Next to continue.
- ✓ Select Install from a list or specified location (Advanced). Click Next to continue.
- ✓ Select Sound, Video, and game controllers. Click Next to continue.
- Select Have Disk and point to the location of the USB-Blaster driver: \<Quartus II directory>\drivers\usb-blaster. Click OK.
- Select Altera USB-Blaster. Click Next to install the driver. Click Continue Anyway if there is any warning message. Click Finish and reboot your PC to complete the process.

### Potential Problems and Workaround for Using USB Blaster

Problems may occur when you remove the USB cable and plug back in during the operation of Quartus II. You will find that the Quartus II (programmer) might hang and is not responding. There are several ways to get back to the normal operational mode.

- ✓ Redo the Hardware Selection step by clicking Hardware Setup button in the programmer menu.
- Remove the USB Cable and then plug in again. Then you need to redo the Hardware Selection part for programming.
- ✓ Exit Quartus II and restart it again.
- If above workarounds do not solve your problem, try to use the 9V-DC power adapter because some of the USB ports on PC do not supply enough voltage/current.

### Install Terasic Lab CD-ROM

Terasic Lab CD-ROM contains everything you need to exercise every part of the

board by using many interesting labs designed and implemented at Terasic. We also implemented a API for users to control the board. Follow the steps below to install the CD-ROM

- Insert Terasic CD-ROM into your CD-ROM drive. The menu shown in Figure 3.1 will pop up.
- Click on "Read Me First" and then click on "Install Software" buttons, which will install all the labs and API software into your C:\Terasic directory. You might encounter a warning message regarding fonts as shown in Figure 3.2. Simply click on "Ignore" to continue.
- ✓ After the installation is complete, you can access Terasic's lab examples and API using Window's program menu as shown in Figure 3.3.
- Read the User Guide and follow the instructions to exercise all the interesting labs we designed for you.



Figure 3.1. Installation Menu of Terasic Lab CD-ROM

|           | .Could not register fo                        |           |
|-----------|-----------------------------------------------|-----------|
|           | ufficient permissions<br>ne system supports t |           |
| anu mat u | ie system supports t                          | HIS TOLL. |
|           |                                               |           |
|           |                                               |           |
|           |                                               |           |
| Abort     | Retry                                         | Innore    |

Figure 3.2. Simply ignore the warning message for font if there is any.

| 🛅 Terasic | 🕩 📁 Lab1_PowerUp                       |
|-----------|----------------------------------------|
| ×         | 📁 Lab2_work_with_scanneddisplay        |
|           | 📁 Lab3_Control_Panel                   |
|           | 📁 Lab4_Audio                           |
|           | 📁 Lab4_Control_Panel_SDRAM_MusicPlayer |
|           | 📁 Lab5_TV                              |
|           | 📁 Lab6_CF                              |
|           | 📁 Lab7_Control_Panel_RS232             |
|           | 📁 Lab8_NIOSII_TREX                     |
|           | 🛃 T_REX_C1_Control_Panel               |
|           | T_REX_C1_Control_Panel_RS232           |
|           | 💏 TREX_C1_UserGuide                    |

#### Figure 3.3. After installation, you can access all the labs and API from Window Start Menu

Chapter

# First Lab: 7-SEG Display

This chapter will walk you through all the steps required to exercise a simple Quartus II design example from the beginning to the end. After this chapter, users should be able to repeat the other reference designs provided by the kit.

### **Power Up the Board**



- ✓ Connect your USB download cable to the TREX1 board.
- ✓ Push the Power ON/OFF button on the board. The Power LED will light up.
- You will see the board is running with the demo code shown in Chapter 2.
   Plug your headset and press KEY1 to hear the music. If everything works fine, go to next section.

### **Repeating the Lab From Scratch**

This section is not intended to teach you how to write Verilog RTL code but to introduce you all the required elements in a Quartus II project. It will walk you through the entire design flow using Quartus II from coding to bitstream downloading. Perform the following steps:

- ✓ Launch Quartus II Software.
- Click on File > Open Project (See Figure 4.1).



#### Figure 4.1. Menu for Opening Quartus II Project

 ✓ Select The NewFlash Quartus II project under Lab1\_PowerUp directory. Refer to Figure 4.2.

| Open Project              |                                      |                     |          |          |             |  |
|---------------------------|--------------------------------------|---------------------|----------|----------|-------------|--|
| 搜尋位置①:<br>db<br>New_Flash | C Lab1_PowerUp                       |                     | •        | <b>€</b> | •           |  |
| 檔案名稱(N):<br>檔案類型(T):      | New_Flash<br>Quartus II Project File | e (*.qpf;*.quartus; | *.qar) 💌 | [<br>  ] | 開啓(0)<br>取消 |  |

Figure 4.2. Select the only project in Lab1\_PowerUp directory

✓ Please refer to Figure 4.3. Click on File Icon in the bottom of left-hand side window and select New\_Flash. Examine the file content and the IO port declaration. You will find that the 8-bit 7-SEG data bus (oSEG7) are shared by all four digits. You can enable each digit by drive 0 to its corresponding enable pins (oCOM[3..0]). In this case, we constantly drive 0 to all four enable pins. Therefore, the four 7-SEG display digits display the same HEX number.

-

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 🖪 🗠 💀 New_Flash 💿 🕱 🖉 🥮 🗊                                                                                | DE M       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                          | 1          |
| Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | A Bo New Flash v*                                                                                        | Start Com  |
| - Device Design Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | rCounter_SOmhz <= rCounter_SOmhz +                                                                       | 1'b1;      |
| async_receiver.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | E10                                                                                                      |            |
| itel async_transmitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 114                                                                                                    |            |
| 10 Flash Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <pre>115 assign oLED = rCounter_50mhr[28:21] ; /</pre>                                                   |            |
| abi New Flash.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <pre>110 assign oCOM[0] = 1'b0; // enable 7-SEG Dig</pre>                                                |            |
| 2 million and a second s | # 117 assign oCOM[1] = 1'b0; // enable 7-SEG Dig                                                         |            |
| RS232_Controlle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <pre>110 amsign oCOM[2] = 1'b0; // enable 7-SEG big 110 assign oCOM[3] = 1'b0; // enable 7-SEG big</pre> |            |
| ubst SE07_Driver.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 119 assign oCOM[3] = 1'b0; // enable 7-SEG Dig<br>130 assign oSEG7 = rSEG7; // output to 7-SEG           |            |
| Software Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                          | LLUS       |
| 🔛 Other Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 10 122                                                                                                   |            |
| -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                          | 180 7-51   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | always@(rCounter_50mhz) // decode the value<br>134 begin                                                 | 2000 1 100 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <pre>g case(rCounter 50mhs[26:23])</pre>                                                                 |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5 116 4'h1: rSEG7 <= 8'b11010111;                                                                        |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4'h2: rSEG7 <= 8'b01001100;                                                                              |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 120 4'h3: rSEG7 <= 8'b01000101;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 110 A/b4, rSEC7 <= 8/b10000111;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4'h5: rSEG7 <= 8'h00100101;                                                                              |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4'h6: rSEG7 <= 8'b00100100;                                                                              |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4'h7: rSEG7 <= 8'b01010111;                                                                              |            |
| B A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 133 4'h8: rSEG7 <* 8'b00000100;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 134 4'h9: rSEG7 <= 8'b00000111;                                                                          |            |
| (* <b> x</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 135 4'ha: rSEG7 <= 8'b00000110;                                                                          |            |
| odule Progress %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 136 4'hb: rSEG7 <= 8'b10100100;                                                                          |            |
| ton me Trangation ye                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 137 4'hc: rSEG7 <= 8'b00111100;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4'hd: rSEG7 <= 8'b11000100;                                                                              |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 130 4'he: rSEG? <= 8'b00101100;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 140 4'hf: rSEG7 <= 8'b00101110;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 141 4'h0: rSEG7 <= 8'b00010100;                                                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 143 endcase                                                                                              |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 140 end                                                                                                  |            |





Figure 4.4. The 7-SEG Display Module Diagram

# **Compiling the Design**

You can click the compile button to start compilation.

 It will create a SOF file (New\_Flash.sof) for user to program FPGA. To program the active serial device, you need to convert programming file to POF format. Figure 4.5 shows the Convert Programming File menu.



#### Figure 4.5. Open the menu for Converting Programming Files

- Refer to Figure 4.6. In the Convert Programming Files Menu, Select EPCS1SI8 as our configuration devices; change the output File name to your desired name with POF extension.
- 3. click on SOF Data label and click on Add File button. Select New\_Flash.sof.
- Click on New\_Flash.sof to highlight it and Click on Properties. Check the Compression box in the pop-up window; click OK in the pop-up window and OK again in the Convert Programming Files window.

| ture use.<br>Conversion onten film  |                       |                               |        |                   |                            |
|-------------------------------------|-----------------------|-------------------------------|--------|-------------------|----------------------------|
| Conversion setup files<br>Open Cony | ersion Setup Data     |                               | Save C | onversion Setup.  |                            |
| Output programming file             |                       |                               |        |                   |                            |
| Programming file type:              | Programmer Object Fr  | le (.pof)                     |        |                   | •                          |
| Qrton:                              | Configuration device: | EPCS1SI8                      | Mode:  | Active Serial Con | nfiguration 💌              |
| File game:                          | C:/project/Lab1_Powe  | rUp/New_Flash.pof             |        |                   | 122                        |
|                                     | Remote/Local update d | lifference file: NON          | E      |                   | *                          |
|                                     |                       |                               |        |                   |                            |
|                                     | 🔽 Memory Map File     | -                             |        |                   |                            |
| Input files to convert              | 🔽 Mgmory Map File     |                               |        |                   |                            |
| File/Data area                      |                       | operties                      |        |                   | Add Data                   |
| File/Data area<br>Main Block Data   |                       | operties                      |        |                   | Add Date                   |
| File/Data area                      | Pr                    | operties<br>P1C60240          |        |                   | Add File                   |
| File/Data area<br>Main Block Data   | Pr                    |                               | e\$    |                   | Add File<br><u>R</u> emove |
| File/Data area<br>Main Block Data   | Pr                    | PIC60240<br>SOF File Properti | es     |                   | Add File                   |
| File/Data area<br>Main Block Data   | Pr                    | 21C6O240                      | e3     |                   | Add File<br><u>R</u> emove |

Figure 4.6. Convert Programming Files

### **Download Bitstream**



You can click the Programmer button to perform bitstream downloading.

 TREX board uses USB-Blaster to download bitstream. We supports both JTAG mode and Active Serial Programming mode (AS mode). By default, the switch is set to the position of RUN for JTAG mode so that the SOF bistream file is downloaded directly to the FPGA chip. AS Mode, where POF bitstream is downloaded directly to the Flash-based Serial Configuration device, should be used only when the design is finalized or the design has to be tested without a PC. Set the switch to PROG for AS mode. Note that the switch position should be kept at RUN position for normal operation. Perform the following steps:



Figure 4.7. Switch Position should be kept at RUN for JTAG/Normal Operation

2. Once the programmer button is clicked, the following programming window is popped up (See Figure 4.8).

| B New Flash edi  | Ř.                                |           |           |           |                     |
|------------------|-----------------------------------|-----------|-----------|-----------|---------------------|
| 📩 Harlwase Setap | 078-Blacks (028-0)                |           |           |           |                     |
| Mode             | TAT!                              |           |           |           | •                   |
| tropes           |                                   | 0.6       |           |           |                     |
| A Det            | For                               | Device    | Checkourn | Usestode  | Improv'<br>Condigue |
| di 112           | C/T-Box_CDLaid_ProveDpNew_Pashast | EPIC80/40 | 0093459   | 511071177 | 9                   |
| Auto Detect      |                                   |           |           |           | in the second       |
| X Dakts          |                                   |           |           |           |                     |
| 2 646 Fd-        | e                                 |           |           |           | JE.                 |

Figure 4.8. Bitstream Programming Window

- Click the Hardware Setup. The Hardware Settings tab of the Hardware Setup dialog box is displayed. USB-Blaster is visible in the Available Hardware items list of the Hardware Setup dialog box, as shown in Figure 4.9.
- 4. Click USB-Blaster to highlight it and then click the Select hardware button.

| ud ware Setup<br>lardware Settings   JTAG Se                                            | rttings                                      |                       |                                              |
|-----------------------------------------------------------------------------------------|----------------------------------------------|-----------------------|----------------------------------------------|
| Select a programming hard<br>hardware setup applies only<br>Currently selected hardware | r to the current program<br>: USB-Blaster (U | nmer window.          | es. This programming                         |
| Available hardware items<br>Hardware<br>ByteBlaster<br>USE-Silinster                    | Server<br>Local<br>Local                     | Port<br>LPT1<br>USB-0 | Select Hardware Add Hardware Remove Hardware |
|                                                                                         |                                              |                       | Clow                                         |

#### Figure 4.9. Hardware Setup Menu for USB-Blaster

- 5. Click Close to close the Hardware Setup dialog box.
- 6. In the programming window, select the desired mode (JTAG or Active Serial Programming mode).
- Click Add File button and select the desired SOF(for JTAG) or POF(for AS mode) accordingly.
- 8. Click Start button to download the selected bitstream.
- In JTAG mode, you should see the behavior of the design right away. In AS mode, you have to reboot the board (power on/off) so that the FPGA can load the bitstream from the Serial Configuration Device.

#### Note

The first time when you open up a Quartus II design project copied from somewhere else and open the Programming Window, you should delete the existing SOF/POF file by selecting the file and clicking on Delete button because the existing SOF/POF file path might be different from your current path.

Once you save the Quartus II configuration before you exit the quartus II, it will remember the SOF/POF file path next time when open the programming window.

Remember to check the Configuration/Program box after you add a new file.

In JTAG mode, you can use Auto Detect to confirm that the link and device are correct.

# The Top Level RTL and Pin Assignment



For each lab in the TREX1 Development CD, you will find a top-level RTL code (ex New\_Flash.v) and pin-assignment table (ex New\_Flash.qsf).

To create your own Quartus II project, you can simply copy the top-level and pin-assignment file to save time in doing the pin assignment again.

#### Chapter

# Lab 2: How to work with scanned 7-SEG Display

Most of the multi-bit 7-SEG display modules in the market are using scanning mode because of the consideration on both cost(pin) and power saving in industry products.

Also, the scanned-mode of 7-SEG display gives us an good example to teach students/engineers on both combinational and sequential logic using one single device. Mostly important, the students/engineers can learn how to use the most common 7-SEG display device available in the market.

## The 7-SEG Display Module on TREX C1



Figure 5.1 shows the block diagram of the scanned 7-SEG display module used on TREX C1 board.

- The 8 data bus pins (oSEG7[7:0] are connected to all the LED segments of each digit according to the numbers put in Figure 5.1. For example, oSEG7[2] connects to all the LED segments labeled 2 in each digit.
- ✓ Each digit has its own enable pin (oCOM[3:0]). For example, oCOM[0] is the enable pin of digit[0].



Figure 5.1 7-SEG module block diagram

### Pure Combinational Logic Lab - using non-scanned mode

This lab shows how to use the scanned 7-SEG display module as a pure

combinational device and show how we can show characters in different locations

- ✓ Note that both LED-segment enable pins (oSEG7[7:0]) and digit enable pins(oCOM[3:0]) are low active.
- ✓ To display 2 on digit[0], drive oCOM[0] low and oSEG[bit 1,5,7,0, 2] low as shown in the case A of Figure 5.2.
- ✓ To display 2 on digit[0] and digit[2], drive oCOM[0] and oCOM[2] low and drive 0x58 on the bus. Please refer to the Case B in Figure 5.2.



Case A: show number 2 on digit 0 by enabling bit 0 and driving 0x58 on databus



CaseB: show number 2 on digit 0 and digit 2 by enabling bit 0, bit 2, and driving 0x58 on databus.

Figure 5.2-Two cases show how to display a number on a specific digit

### The Verilog Code for Combinational Lab

For the above combinational lab in case B, the corresponding Verilog code is shown below

Verilog Code for Case B in the Combinational Lab assign oCOM[0] = 1'b0; assign oCOM[1] = 1'b1; assign oCOM[2] = 1'b0; assign oCOM[3] = 1'b1; assign oSEG7 = "0101\_1000"; // 0x58

## Sequential Logic Lab - use the scanned mode

This lab shows how to use the scanned 7-SEG display module to display four different values on the 4 digits simultaneously.

- ✓ Please see Figure 5.3.
- The 2-bit counter is running at 400Mhz (cannot be too fast or too slow to cheat our vision). The counter's output (CNT) controls a MUX and a DEMUX.
- The MUX has four inputs; we supply the FOUR numbers that we would like to display on the four 7-SEG digits as the inputs. The output of the MUX drives the common 7-SEG LED databus.
- ✓ The DeMUX has 1 input(GND); the FOUR outputs connect to the enable pins of the FOUR 7-SEG digits, respectively.



Figure 5.3-The FSM (2-bit counter) for the scanning control

### When Counter = 00

Figure 5.4 shows the FSM and circuit status when cnt = 00. At this stage, only Digit 0 (enabled by COM[0]) is displaying. The databus (SEG7) is provided with the value to be displayed on Digit 0.

Note that the FSM is using a clock with speed around 400Hz. This will give a very

stable visual effect.



Figure 5.4-The circuit/FSM state when counter (CNT) = 00

## The Verilog Code for Scanned Mode

Let us look at the code for scanned mode, which has almost 1-1 corresponding relationship to the block diagram shown in Figure 1.3.

The completed Quartus II project with the source code can be found in Lab2\_work\_with\_scanneddisplay directory.

```
Verilog Code for Scanned-mode Operation
// FSM: 2-bit counter for 7-SEG digit selection
always @(cnt) begin
if ( cnt == 2'b00 ) begin
     SEG7_reg <= 8'h17;
                             // Number = 4
COM7_reg <= 4'b1110;
end
else if (cnt == 2'b01 )begin
     SEG7_reg <= 8'h19;
                             // Number = 3
     COM7_reg <= 4'b1101;
end
else if (cnt == 2'b10 )begin
                             // Number = 2
     SEG7_reg <= 8'h58;
```

```
COM7_reg <= 4'b1011;
end
else if (cnt == 2'b11 )begin
SEG7_reg <= 8'h9f; // Number = 1
COM7_reg <= 4'b0111;
end
else begin
SEG7_reg <= 8'b111111;// All LED segs OFF
COM7_reg <= 4'b1111;
End
```

Chapter

# Lab 3: TREX Control Panel

This chapter will illustrate the TREX Control Panel package that allows users to control the board using Window GUI menu. The TREX Control Panel Package is free to the users who purchased TREX C1 Development Kit. This package provides users a simple yet powerful method to control the board.

The connection from your PC to the board can be done by a RS232 or USB cable. In this lab, we will teach users how to use the USB version of the TREX Control Panel Package.

#### Important Note on the USB Link

- The TREX Control Panel USB Version is using the same link as Altera USB Blaster. You need to release(close) the USB port in TREX Control Panel before you can use the USB Blaster link from Quartus II.
- 2. If concurrent debugging using TREX Control Panel and Altera Signal Tap is desired, users should use the TREX Control Panel's RS232 Version

### **Connect PC to the Board Using USB Cable**

Use the USB cable attached in the development kit to connect your PC to the TREX1 board. The TREX Control Panel Software leverages the same USB controller chip in USB Blaster circuit on board to communicate with the FPGA. Perform the following steps to learn how to use TREX Control Panel.

- ✓ Make sure that you have C:\Terasi\Lab3\_TREX\_Panel installed in your directory.
- ✓ Start Quartus II Software.
- ✓ Click File > Open Project.
- ✓ Select C:\Terasic\Lab3\_TREX\_Panel\New\_Flash-Multiplexer\New\_Flash project.
- Click on Programming button. Setup the programming hardware to USB-Blaster according to the instructions stated in Chapter 4.
- ✓ Select the New\_Flash.sof stored in the Lab3\_TREX\_Panel directory and download it to FPGA.

## **Control the Board Using TREX Panel**

This session will show you how to use the TREX PANEL to control your board to change 7-SEG DISPLAY, light up LEDs, talk to PS2 keyboard, and read/write the Flash Memory and SDRAM. The feature of reading/writing a byte or an entire file from/to the Flash Memory allows users to develop many multimedia applications (Flash Audio Player, Flash Picture Viewer) without worrying about how to build a Flash Memory Programmer. Perform the following steps:

 Figure 6.1 shows the concept of the TREX Control Panel. Users use Window GUI to issue commands via the USB link to the FPGA. We provide an IP to handle all the requests and perform data transferring between PC and the TREX board.



Figure 6.1. TREX Control Panel Concept Diagram

- 2. Make sure that you have programmed the board with the *C:\Terasic*\Lab3\_TREX\_Panel\New\_Flash-multiplexer\ New\_Flash.sof
- 3. Start the TREX\_C1\_Control\_Panel program located in your C:\Terasic. The user interface shown in Figure 6.2 should appear.

| 🎫 T-REX Cl Con                         | trol Panel    |         |         |         |
|----------------------------------------|---------------|---------|---------|---------|
| <u>O</u> pen <u>M</u> enu <u>H</u> elp | <u>A</u> bout |         |         |         |
| LED & PS2                              | FLASH SD      | RAM TO  | DOLS    |         |
| LED                                    |               |         |         |         |
| Refresh                                | LED7          | LED6    | LED5    | LED4    |
| 7-SEG                                  |               |         |         |         |
| Refresh                                | DIG 3 :       | DIG 2 : | DIG 1 : | DIG 0 : |
| PS2 Keyboard                           | 1             |         |         |         |
|                                        |               |         |         |         |
|                                        |               |         |         |         |
|                                        |               |         |         |         |
|                                        |               |         |         |         |
|                                        |               | Clear   |         |         |
|                                        |               |         |         | 1       |
|                                        |               |         |         |         |

Figure 6.2. TREX Control Panel

4. Click Open > Open USB Port0 (TREX Control Panel Application will list all the USB ports that connect to TREX boards . TREX Control Panel can control up to 4 TREX boards using the USB links). Figure 6.3 shows the concept of how to connect multiple TREX boards. Note that The Control Panel will occupy the USB port until you close the port – you cannot use Quartus II to download unless you close the USB port.



Figure 6.3. TREX Control Panel can control up to 4 TREX C1 boards

5. Refer to Figure 6.4. Click on the check boxes of D3, D4, D7, and D0. Then click on Refresh. You will find that that the LED3, LED4, LED7, and LED0

are lighted up. Also, you can change the numbers in DIG3 ~ DIG0 and click on Refresh. The 7-SEG display on the board will change accordingly.



Figure 6.4. LED and 7-SEG Display Control Panel

### **The Flash Programmer**

The TREX Control Panel can serves as a Flash Memory Programmer. Users can erase entire Flash memory, write one byte to the Flash, read one byte from the Flash, write a binary file to the Flash, load the content of the Flash to a file.

Follow the steps to exercise the operations to the Flash memory:

- Click on Button Flash to change to Flash Memory Control Page (Refer to Figure 6.5).
- 2. Click on Chip Erase. The button and window frame title will prompt you to wait until the operation is finished. It will take around 16 secs to finish the operation.
- 3. Please refer to Figure 6.5. Key in a random address (1688 in the example) and value in wDATA field (125 in the example). Click on Write will write 125 to address 1688.
- 4. Key in the address and click on Read. The rData will display the data read back from the address specified.

| Random A | ccess        |        |     |            |
|----------|--------------|--------|-----|------------|
| Address: | 1688         | wDATA: | 125 | rDATA: 125 |
| Chip Era | se (16 Sec.) | Writ   | e   | Read       |

Figure 6.5. Random Access to the Flash Memory

- You can also load a file into Flash by using Sequential Write function.
   Please refer to Figure 6.6. You have to specify the starting address and the length (in bytes) to be written into the Flash.
- You can click on "File Length" checkbox to indicate that you want to load entire file into the flash memory. Then Click on Write File to Flash to choose the file to be loaded into the flash memory.
- Note: Please load c:\terasic\Binary\_Raw\_Data\cdda1m into your Flash Memory now so that we can proceed with the Flash Music Player Lab in the next section.

| ddress | 3880    | Length : | 8   | File Length |
|--------|---------|----------|-----|-------------|
|        | leases. |          | 1-1 | -           |

Figure 6.6. Write an entire file into the Flash Memory

8. Sequential Read function allows you to read the content in Flash and save into a file. Figure 6.7 shows the screen capture of the Sequential Read. You can also specify the starting address and the length (in bytes) to read from the Flash. By clicking on the "Entire Flash" checkbox, you are indicating that you would like to load entire flash content (1Mbyte) into a file specified by you.

| Address : 0 | Length: 1048576            | Entrie Flash |
|-------------|----------------------------|--------------|
|             | Load Flash Content to File |              |

Figure 6.7. Load the content of the Flash Memory to a file

### The SDRAM Controller and Programmer

The TREX Control Panel can serves as a SDRAM Programmer. Users can read/write a 16-bit word from/to the SDRAM, write a binary file to the SDRAM, load the content of the SDRAM to a file.

#### Note

The SDRAM memory used on TREX1 board is a 8-Mbyte single-data-rate SDRAM organized as  $1M \times 4 \times 16$  bit.

Detailed spec can be found at

C:\Terasic\3rd\_party\_specs\Samsung\_k4s641632h\_tc75.pdf

Follow the steps to exercise the operations to the SDRAM:

- 1. Please refer to Figure 6.8. Click on Button SDRAM to switch to SDRAM Control Page.
- 2. Key in a random address (1688 in the example) and value in wDATA field (abcd in the example). Click on Write will write 0xabcd to address 1688.
- 3. Key in an address and click on Read. The rData will display the data read back from the address specified.
- You can also load a file into SDRAM by using Sequential Write function.
   Please refer to Figure 6.8. You have to specify the starting address and the length (in bytes) to be written into the SDRAM.
- You can click on "File Length" checkbox to indicate that you want to load entire file into the SDRAM. Then Click on Write File to SDRAM to choose the file to be loaded into the SDRAM.
- 6. Sequential Read function allows you to read the content in SDRAM and save into a file. Figure 6.8 shows the screen capture of the Sequential Read. You can also specify the starting address and the length (in bytes) to read from the SDRAM. By clicking on the "Entire SDRAM" checkbox, you are indicating that you would like to load entire SDRAM (8Mbyte) into a file specified by you.

| en <u>M</u> enu <u>H</u> elp | <u>A</u> bout |                               |           |              |    |
|------------------------------|---------------|-------------------------------|-----------|--------------|----|
| LED & PS2                    | FLASH         | SDRAM                         | TOOL      | S            |    |
| SDRAM                        |               |                               |           |              |    |
| Random A                     | ccess         |                               |           |              |    |
| Address :                    | 1688          |                               | bcd       |              |    |
|                              | Write         |                               | 3         | Read         | 1  |
| Address :                    | 1 <u>.</u>    | Length : 0<br>Vrite File To S | dram      | File Length  |    |
| Sequential                   | Read          |                               |           |              |    |
| Address :                    | 0             | Length : 0                    |           | Entrie Sdram | ř. |
|                              | Load          | Sdram Conte                   | nt To Fil | e            | 1  |
|                              |               |                               |           |              |    |

Figure 6.8. The SDRAM Controller Panel

### **PS2** Communication to the Board

TREX Control Panel also gives you a control window with associated IP to allow users give input using PS2 keyboard; the keys pressed on the keyboard will be displayed in the message box of the TREX Control Panel.

Figure 6.9 shows the setup of the connection. Note that the RS-232 link can be the USB as well. Figure 6.10 shows the characters typed in from the PS2 keyboard are shown in the message box of the TREX Control Panel.



Figure 6.9 PS2 and USB/RS232 connection Setup

| T-REX C1 Cor                   | ntrol Panel |           |          |         |
|--------------------------------|-------------|-----------|----------|---------|
| <u>Open M</u> enu <u>H</u> elp |             |           |          |         |
| LED & PS2                      | FLASH S     | DRAM T    | OOLS     |         |
| LED                            |             |           |          |         |
| Refresh                        | LED7        | LED6      | LED5     | ✓ LED4  |
| 7-SEG                          | DIG 3:      |           | DICT     | DICO    |
| Refresh                        | 0 •         | DIG 2 :   | DIG 1 :  | DIG 0 : |
| PS2 Keyboar                    | d           |           |          |         |
| -                              | C TECHNOL   | OGIES ANI | O ARCHES | 3       |
|                                |             | Clear     |          |         |
|                                |             |           |          |         |

Figure 6.10 TREX Control Panel – PS2 Keyboard message box

### TOOLS - Multi-Port SDRAM/Flash Controller - Use a Music Player as an Example



To let users/students implement and test their IP cores without requiring them to implement complex API/Host control software and memory (SDRAM/Flash) controllers, we provide users an integrated control environment consisting of software controller in C++, USB command controller, and multi-port SDRAM/Flash controller in Verilog.

Users can simply connect their IP to one of the three asynchronous ports of the SDRAM/Flash controller IP and then download binary data into the SDRAM/Flash. Once the content is downloaded to the SDRAM/Flash, users can configure the memory controllers so that their IP can read/write the SDRAM/Flash via the asynchronous ports connected.

Repeat the following steps to exercise the multi-port SDRAM/Flash controllers:

- ✓ Figure 6.11 shows the concept of the multiport SDRAM/Flash controller.
- ✓ Note that for every board shipped, we have downloaded a music file into the Flash memory via the USB link (Host USB Port).
- ✓ In the TREX Control Panel, click on the TOOLS button to reach the window

in Figure 6.12.

- As illustrated in Figure 6.13, select the Asynchronous 1 for Flash Multiplexer and then click on the Configure button to activate the port. Note that you need to click the Configure button to enable the connection from the Flash Memory to the Asynchronous Port 1 of the Flash Controller indicated in Figure 6.11.
- Note: Plug in your headset of speaker and you should hear the music played from the Audio DAC circuit. Press KEY 1 to reset the Audio DAC circuit to remove the background noise (sometime you need to press more than once until the background noise is removed).
- Please refer to Figure 6.11. You should see the Asynchronous Port 1 is connected to the Audio DAC part. Once you selected Asynchronous Port 1 and click the Configure button, the AUDIO\_DAC will talk to the Flash Memory directly. In this example, the AUDIO\_DAC Verilog Module will read the content of the Flash memory and send it to the external audio chip.



Figure 6.11. Block Diagram of The Multi-Port SDRAM/Flash integration

| 🖙 T-REX Cl Control Panel                                                                                                           |  |
|------------------------------------------------------------------------------------------------------------------------------------|--|
| <u>Open Menu Help A</u> bout                                                                                                       |  |
| LED & PS2 FLASH SDRAM TOOLS                                                                                                        |  |
| SDRAM Multiplexer : Host USB Port  FLASH Multiplexer : Host USB Port Virtual DPDT Switches SW 7 SW 6 SW 5 SW 4 SW 3 SW 2 SW 1 SW 0 |  |
| Configure                                                                                                                          |  |
| Board Test                                                                                                                         |  |
|                                                                                                                                    |  |

Figure 6.12 TREX Control Panel – The TOOLS page

| 🐄 T-REX C1 Control Panel                                                                                                                       |  |
|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <u>Open M</u> enu <u>H</u> elp <u>A</u> bout                                                                                                   |  |
| LED & PS2 FLASH SDRAM TOOLS                                                                                                                    |  |
| SDRAM Multiplexer : Host USB Port<br>FLASH Multiplexer : Asynchronous 1<br>Virtual DPDT Switches<br>SW 7 SW 6 SW 5 SW 4<br>SW 3 SW 2 SW 1 SW 0 |  |
| Configure Configure                                                                                                                            |  |
|                                                                                                                                                |  |

Figure 6.13 TREX Control Panel – multi-port SDRAM/Flash Usage

Verilog Code for Connecting the AUDIO DAC IP Core to Asynchronous Port 1 of the Flash Controller

//In the top-level RTL code: New\_Flash.v, you will find the following multi-port
Flash Controller instantiated:

```
Multi_Flash u2(
```

```
// Host Side
```

mFL2RS\_DATA,mRS2FL\_DATA,

mFL\_ADDR,mFL\_CMD,mFL\_Ready,mFL\_Start,

// Async Side 1

mFL\_AS\_DATA\_1, mFL\_AS\_ADDR\_1,

// Async Side 2

// Note that the Async Side 1 is the Asynchronous Port 1 of the Flash Controller. Signal mFL\_AS\_DATA\_1 is the data bus and mFL\_AS\_ADDR\_1 is the address bus. The Audio DAC IP is connected to these two buses by using the following code, which readers can find in the New\_Flash.v file.

```
AUDIO_DAC u6 (
```

// Audio DAC IP Controller

.AUD\_BCK (AUD\_BCK) , .AUD\_DATA(AUD\_DATA),

.AUD\_LRCK(AUD\_LRCK),

.CLK\_18\_4mhz(wOSC\_18\_4),

```
.ENABLE (1'b1),
```

.RESET (KEY[1]), // The reset KEY to remove noise

 $.\mathsf{FL}\_\mathsf{ADDR} \qquad (\mathsf{mFL}\_\mathsf{AS}\_\mathsf{ADDR}\_\mathsf{1}),$ 

.FL\_DATA (mFL\_AS\_DATA\_1)

);

// Users are encouraged to leverage the multi-port SDRAM and

// Flash memory controllers to develop and test their own IPs

// to speedup the development phase.

#### Important Note about the Multiport SDRAM/Flash Controller

Make sure HOST port is selected and the Configure button is clicked to activate the selection, so that you can Read/Write(access) the Flash/SDRAM from the TREX Control Panel.

Once you finish the data downloading from host, you can switch to Asynchronous port 1 (remember to click Configure button to activate your selection) to listen to the music stored in Flash memory.*II* to speedup the development phase.

#### **Virtual DPDT Switches**

To provide users a set of DPDT switches for instruction input, the TREX Control Panel implemented with a set of Virtual Switches to allow users to send instructions into the FPGA via the USB/UART link. Repeat the following steps to see how the Virtual DPDT switches work:

- Please refer to Figure 6.14. Select the number 3210 in the 7-SEG Digit Boxes and click on the REFRESH button to display the number 3210 on the 7-SEG display module.
- 2. Click on the TOOLS button in the TREX Control Panel to switch to the TOOLS page where you can find the Virtual DPDT Switches.
- Click on the SW3 and SW1 boxes. Then Click on the Configure button. You will notice that the Digit 3 and Digit 1 are turned off, as shown in Figure 6.14. Readers who are interested in using the Virtual DPDT Switches should look at the following Verilog Code examples.



Figure 6.14 TREX Control Panel – Virtual DPDT Switches

Verilog Code for illustrating how to use the Virtual DPDT Switches to turn

ON and OFF the 7-SEG digits //In the top-level RTL code: New\_Flash.v, you will find the following //code: // use 4 wires (mExt\_IO[3:0]) to turn OFF the 4-digit enable pins assign oCOM[3:0] = m\_oCOM[3:0] | mExt\_IO[3:0]; // The 7-SEG display controller outputs 4 enable pins (m\_oCOM). SEG7\_Driver u0 (oSEG7,m\_oCOM,mSEG7\_DIG,OSC\_50,KEY[0]); // The CMD\_Decoder outputs mExt\_IO[7:0] according to the setup of the SW7..SW0 in the TREX Control Panel. CMD\_Decode u5 (...skip ... // Ext Control Signals .oExt\_IO(mExt\_IO),

# Chapter

## Lab 4: CD-Quality Music Box

This chapter introduces you how to repeat the lab of using the 16-bit CD-quality audio DAC on the TREX board. We will download a 1Mbyte long CD music stream to the FLASH memory and play the music repeatedly.

#### Load Another Music File to Play From Flash



Following the steps below to prepare a 1Mbyte CD music stream and download it to the Flash Memory.

- Check C:\Terasic\Binary\_Raw\_Data\directory. There is a 1Mbyte CD music data called **5thElement\_1mbyte**, which is 1Mbyte long raw CD data.
- You can convert your MP3 file into a CD Raw Data file by using a free tool "MP3 to WMA Converter" from AudioUtilities Co. Ltd.
- Power up the board and make sure the SOF/POF file in Lab3\_Control\_Panel is programmed into the FPGA.
- 4. Start TREX\_C1\_Control\_Panel tool.
- Following the Flash Programmer section in Chapter 6 to erase Flash memory and load 5thElement\_1mbyte into the Flash.
- In Lab3\_Control\_Panel, click on TOOLS and select Asynchronous 1 as the Flash Memory R/W port.
- 7. Click **Configure** Button and you will hear the music.

#### Play Music From 8Mbyte SDRAM

We can play a 40-sec music by storing the music into the 8Mbyte SDRAM. Following the steps below to download a 8Mbyte CD music stream to SDRAM and play the music

- Check C:\Terasic\Binary\_Raw\_Data\directory. There is a 8Mbyte CD music data called **5thElement\_8mbyte**, which is 8Mbyte long raw CD data.
- You can convert your MP3 file into a CD Raw Data file by using a free tool "MP3 to WMA Converter" from AudioUtilities Co. Ltd.

3. Power up the board and make sure the SOF/POF file in

Lab4\_Control\_Panel\_SDRAM\_MusicPlayer is programmed into the FPGA.

- 4. Start TREX\_C1\_Control\_Panel tool.
- Change the SDRAM control page and download the **5thElement\_8mbyte** file into the SDRAM. The Control Panel will promote users the downloading status in a progress bar shown in Figure 7.1

| 🖚 T-REX Cl Control Panel                                     |  |  |
|--------------------------------------------------------------|--|--|
| <u>Open M</u> enu <u>H</u> elp <u>A</u> bout                 |  |  |
| LED & PS2 FLASH SDRAM TOOLS                                  |  |  |
| SDRAM<br>Random Access<br>Address: 0 wDATA: 0000 rDATA: 0000 |  |  |
| Processing 22 %                                              |  |  |
| Sequential Read                                              |  |  |
| Address : 0 Length : 0 Entire Sdram                          |  |  |
| Load SDRAM Content to a File                                 |  |  |
|                                                              |  |  |

Figure 7.1 Downloading 8Mbyte Music Data into SDRAM

- Once the downloading is finished, click on TOOLS button and select Asynchronous 1 as the SDRAM Memory R/W port.
- Note: Click on SW7 checkbox and click the Configure button as shown in Figure 7.2. You will hear the 40-sec long music from your headset or speaker.

| T-REX C1 Control Panel                                                                                                                         |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <u>Open Menu Help A</u> bout                                                                                                                   |  |  |
| LED & PS2 FLASH SDRAM TOOLS                                                                                                                    |  |  |
| SDRAM Multiplexer : Asynchronous 1<br>FLASH Multiplexer : Host USB Port<br>Virtual DPDT Switches<br>SW 7 SW 6 SW 5 SW 4<br>SW 3 SW 2 SW 1 SW 0 |  |  |
| Configure                                                                                                                                      |  |  |
| Board Test                                                                                                                                     |  |  |

Figure 7.2 Need to activate SW7 with SDRAM R/W port set to Port 1 to listen to the music played

| Verilog code for using SW7 to control the music source          |  |  |
|-----------------------------------------------------------------|--|--|
| // Note that SW 7 is represented by wire mExt_IO[7] internally. |  |  |
| // m_AUD_XXX_0 wires are connected to the AUDIO_DAC IP for      |  |  |
| // Flash memory; m_AUD_XXX_1 wires are connected to             |  |  |
| // AUDIO_DAC IP for <b>SDRAM</b> .                              |  |  |
|                                                                 |  |  |
| assign AUD_BCK = (mExt_IO[7] == 1'b0 )? m_AUD_BCK_0 :           |  |  |
| m_AUD_BCK_1;                                                    |  |  |
| assign AUD_DATA = (mExt_IO[7] == 1'b0 )? m_AUD_DATA_0:          |  |  |
| m_AUD_DATA_1;                                                   |  |  |
| assign AUD_LRCK = (mExt_IO[7] == 1'b0 )? m_AUD_LRCK_0:          |  |  |
| m_AUD_LRCK_1;                                                   |  |  |

#### **Details of the Audio DAC Controller**

TREX1 board uses MS6311, a 16-bit voltage-output Digital-to-Analog Converter (DAC) from MOSA Electronics, which is pin and function compatible with the Philips TDA1311 commonly used in CD players. The spec of the chip,

#### Ms6311\_audio.pdf, is also put in the 3rd\_party\_spec directory.

The master clock for MS6311 supports audio sampling rates from 128fs to 512fs, where fs is the audio sampling frequency (LRCK) typically 32kHz, 44.1kHz, 96kHz, or 192kHz. The master clock is used to operate the digital filters and the noise shaping circuits. In this lab, we use 96kHz sampling rate (LRCK) with 192fs = 18.432Mhz. The 18.432Mhz is generated using the PLL block inside Cyclone device. Figure 7.3 illustrates the timing diagram we generated for the audio DAC interface.



Figure 7.3. The timing diagram of the audio DAC

#### A Reference Design: 1KHz Sound Generator

There are two reference designs provided to users for them to understand how to generate correct timing and data to feed into the audio DAC. The first one is 1kHz Sound Generator. It generates a perfect triangle waveform at frequency of 1kHz. Users can use this reference design to modify sampling rate and associated master clock. To verify the timing correctness, users can generate his/her own 1kHz sound and compare with the sound generate from this reference design.

The first audio design is stored under C:\Terasic\Lab4\_Audio.

Open the Quartus II project in Lab4\_Audio and download the SOF file in the project directory.

Plug your headset and you should be able to hear the 1kHz sound.

#### How to Create Your Own Music Raw Data

This session teaches users how to create their own music raw data from a MP3

sound. Users can get any MP3 sound and follow the steps below.

- 1. Dowload a software tool called "MP3 to All Converter" from internet.
- Convert your desired MP3 music sound file into a WAV file with sampling rate at 44.1Khz. Please refer to Figure 7.4 to see how to setup the MP3 conversion tool.
- Once you have the raw WAV file, you can use Hex Workshop software to select the desired music portion and copy into a new file. Then you can use the new WAV file for TREX C1 board's audio applications.

| MP3 To        | All Converter     | v1.37 Unregistered    | . 🛛 🖬 🗙                   |
|---------------|-------------------|-----------------------|---------------------------|
| File Action   | Help              |                       |                           |
| Add D         | )<br>el Clear     | Options               | op Econvert Cancel        |
| C:\My Music\I | 'll be Missing Yo |                       |                           |
|               | Contic            | ans k                 |                           |
|               | Options           | •                     |                           |
|               | Output            | C:\My Music           | Set                       |
|               |                   | Type Sample F         | Rate - Bit Rate - Channel |
|               | Туре              | WAV 💉 44100 -         | 0 - Stereo 💌              |
|               |                   | write existing files  | Delete the source file(s) |
|               | Save              | e to source directory | <u>0</u> K                |

Figure 7.4. Convert a MP3 file into raw WAV format

Chapter

# Lab 5: NTSC/PAL TV Controller

The two most important applications of multimedia products are audio and video processing. We have demonstrated the audio capability of TREX C1 board with the labs of SDRAM/Flash Music Player. In this chapter, we will demonstrate the video capabilities of the board, which is the fundamental building block in digital video processing for TV, LCD TV, and HDTV.

#### YCrCb and Component Digital Video

CCIR 601 defines some basic properties common to digital component video, such as pixel sampling rate and color-space conversion; More specific documents (such as ITU-R BT.656) define how the data format defined by CCIR 601 is to be transmitted over various kinds of links with various numbers of lines (525 or 625).

Digital Video uses YCrCb Components/format where Y represents luma and CrCb arescaled chroma values.. This YCrCb refers to a signal format that is transmitted over a wire.

CCIR 601 illustrates how to perform subsampling on chroma values. The most common subsampling method is 4:2:2, where there is one pair of Cr, Cb samples for every other Y sample.

TREX C1 uses SPCA711a Digital Video Encoder from Sunplus, which is functional compatible as the Bt852 from Brooktree. The detailed specs are located under C:\Terasic\3rd\_party\_specs\(**SPAC711a.pdf** and **Bt852.pdf**).

The SPCA711/Bt852 is designed specifically for Video CD, video games, and any digital video systems which require the conversion of digital YCrCb(MPEG) data to analog NTSC/PAL video. The device supports both NTSC(N America, Japan) and PAL (B,D, G,H,I, M, N, Nc). The device operates with a single 2x clock and can be powered with a single 3.3V supply.

#### **TV Lab - NTSC/PAL TV Color Pattern Generator**



<u>Chroma's DTV/HDTV</u> <u>Color Pattern Generator</u> (www.chromaate.com)

In this Lab, we will use TREX C1 to implement a TV Color Pattern Generator. Follow the instructions below to exercise the lab.

- ✓ Make sure that you have C:\Terasic\Lab5\_TV installed in your directory.
- ✓ Start Quartus II Software.
- ✓ Click File > Open Project.
- ✓ Select C:\Terasic\Lab5\_TV\LED1 project.
- Click on **Programming** button. Setup the programming hardware to USB-Blaster according to the instructions stated in Chapter 4.
- Select the LED1.sof stored in the Lab3\_TREX\_Panel directory and download it to FPGA
- ✓ Connect the TV output jack of the TREX C1 board to your TV (Video In Jack). You should be able to see the color pattern shown in Figure 8.1
- ✓ Press **KEY 2** to switch between NTSC and PAL system.
- ✓ Figure 8.2 shows another setup in our lab where we use TREX C1 board to generate the TV color patterns to feed into the latest Altera DE2 multimedia board. The Altera DE2 board then convert the YCbCr (4:2:2) format to RGB using Cyclone II FPGA and display the result on a VGA Monitor. This lab setup is excellent for video/multimedia labs because:
  - TREX C1 board serves as a cheap NTSC/PAL dual system TV Color/Signal Pattern Generator instead of buying expensive NTSC/PAL TV Pattern generator.
  - (2) Altera DE2 board serves as a video processing/compression box
  - (3) Altera DE2 board can also serves as a simple TV Box as in this example, which converts TV input to VGA output to enable users to observe the results on a easy-to-get VGA monitor in the lab.





#### Figure 8.1. The output of TREX C1 as a NTSC/PAL Color Pattern Generator

TREX C1 serves as a NTSC/PAL TV Pattern Generator Altera DE2 Multimedia Board serves as a TV Box which does image processing and convert YCbCr to RGB for VGA Monitor

Figure 8.2 Another setup of the lab which uses TREX C1 with Altera DE2 board -TREX C1 serves as a TV pattern generator and DE2 board serves as a TV Box.

# Chapter

# Interfaces and Associated testing code

This chapter illustrates all major blocks and interfaces of the TREX1 board. For some interfaces like Compact Flash Card, we will be using a simple example to illustrate how to exercise the interface.

#### 50 Mhz and 27 Mhz Oscillators

TREX board provides two oscillators: 50Mhz and 27Mhz. The 27Mhz is intended for video application. The outputs of the two oscillators are connected directly to the CLK1 and CLK2 pins of the Cyclone chip

| Signal                    | Cyclone Pin Number |
|---------------------------|--------------------|
| OSC_50 (50Mhz Oscillator) | 28                 |
| OSC_27 (27Mhz Oscillator) | 153                |

### LED1 - LED8

TREX board has 8 user LEDs connected to Cyclone IO pins. Drive 1 to LED will light up the LED.

| Signal | Cyclone Pin Number |
|--------|--------------------|
| LED[0] | 50                 |
| LED[1] | 11                 |
| LED[2] | 228                |
| LED[3] | 193                |
| LED[4] | 170                |
| LED[5] | 131                |
| LED[6] | 108                |
| LED[7] | 73                 |

### 8 Push-Button Switches: KEY[7] to KEY[0]

TREX board has eight push buttons. All of the buttons are Schmitt Trigger de-bounced. The following diagram illustrates how the Schmitt Trigger works to provide exactly one zero pulse when button is pressed



Figure 9.1 The waveform after RC-de-bounced and Schmitt trigger circuits

| Signal | Cyclone Pin Number |
|--------|--------------------|
| LED[0] | 14                 |
| LED[1] | 13                 |
| LED[2] | 12                 |
| LED[3] | 8                  |
| LED[4] | 7                  |
| LED[5] | 6                  |
| LED[6] | 4                  |
| LED[7] | 2                  |

#### **7-SEG Display**

The 4-digit 7-SEG displays are sharing the same data bus (**oSEG7[7:0]**). Each digit has its own enable pin (**oCOM[3:0]**). You can display a desired number on any one of the digits by sending the display data to the shared data bus and enable the digit's corresponding oCOM pin (**by driving low**). The segments illuminate if the Cyclone pin to which they are connected **drives low**; they appear unlit when the connected Cyclone device pin drives high.



Figure 9.2. The block diagram of the 7-SEG display module

| Signal | Cyclone Pin Number |
|--------|--------------------|
| LED[0] | 198                |
| LED[1] | 197                |
| LED[2] | 196                |
| LED[3] | 195                |
| LED[4] | 188                |
| LED[5] | 187                |
| LED[6] | 186                |
| LED[7] | 185                |
| COM[0] | 203                |
| COM[1] | 202                |
| COM[2] | 201                |
| COM[3] | 200                |

### **VGA DAC**

TREX uses a 4-bit resistor-network to implement the VGA DAC for each color (R, G, B). Figure 9.3 shows the 4-bit resistor-network DAC. The variable **color** in the diagram represents three colors (R, G, B). The 4-bit resistor-network gives users 4096 colors to play with.





| Signal   | Cyclone Pin Number |
|----------|--------------------|
| VGA_B[0] | 216                |
| VGA_B[1] | 215                |
| VGA_B[2] | 214                |
| VGA_B[3] | 213                |
| VGA_G[0] | 220                |
| VGA_G[1] | 219                |
| VGA_G[2] | 218                |
| VGA_G[3] | 217                |
| VGA_R[0] | 225                |

| VGA_R[1]                            | 224 |
|-------------------------------------|-----|
| VGA_R[2]                            | 223 |
| VGA_R[3]                            | 222 |
| TR_TVRES                            | 221 |
| Must drive this pin high to disable |     |
| the TV Encoder chip because the     |     |
| data bus, /HSYNC, and /VSYNC pins   |     |
| are all shared                      |     |
| HSYNCn                              | 206 |
| VSYNCn                              | 207 |
|                                     |     |

## Audio DAC

TREX board connects to a 16-bit CD-quality Audio DAC. This audio DAC does not require any master clock. It requires three signals in total: LRCK, BCK, and DATA. Please refer to Figure 23 for the timing diagram of the interface. The spec of the Audio DAC is also put in the 3rd\_party\_spec directory.

| Signal                | Cyclone Pin Number |
|-----------------------|--------------------|
| LRCK (Sampling Clock) | 233                |
| ВСК                   | 226                |
| DATA                  | 234                |

#### PS2 & RS-232 Interface

TREX board provides PS2 and RS-232 interfaces for users to communicate with the board.

| Signal                              | Cyclone Pin Number |
|-------------------------------------|--------------------|
| PS2_CLK                             | 180                |
| PS2_DAT                             | 179                |
| PS2_LAT(reserved for joystick)      | 178                |
| PS2_DIN( reserved for joystick)     | 177                |
| TR_TXD (RS-232 transmitter – output | 204                |
| pin on FPGA)                        |                    |
| TR_RXD (RS-232 receiver – input pin | 205                |
| on FPGA )                           |                    |

#### Video Encoder (NTSC/PAL TV Out) - Lab 5

TREX uses SPCA711a Digital Video Encoder from Sunplus, which is functional compatible as the Bt852 from Brooktree. The detailed specs are located under C:\Terasic\3rd\_party\_specs\(**SPAC711a.pdf** and **Bt852.pdf**).

The SPCA711/Bt852 is designed specifically for Video CD, video games, and any digital video systems which require the conversion of digital YCrCb(MPEG) data to analog NTSC/PAL video. The device supports both NTSC(N America, Japan) and PAL (B,D, G,H,I, M, N, Nc). The device operates with a single 2x clock and can be powered with a single 3.3V supply.

| Signal                                  | Cyclone Pin Number |
|-----------------------------------------|--------------------|
| YC4                                     | 216                |
| YC5                                     | 215                |
| YC6                                     | 214                |
| YC7                                     | 213                |
| YC0                                     | 220                |
| YC1                                     | 219                |
| YC2                                     | 218                |
| YC3                                     | 217                |
| P/N (drive low for NTSC; drive high for | 222                |
| PAL)                                    |                    |
| TVRES (drive low to enable the chip,    | 221                |
| turning this chip off can save you      |                    |
| 100mA)                                  |                    |
| HSYNCn                                  | 206                |
| VSYNCn                                  | 207                |

#### Lab 6: Verilog Code and Quartus II Project for using TV encoder

Repeat the following steps to test the TV out feature:

- 1. Launch Quartus II Software.
- 2. Click on File > Open Project; select the project under directory Lab5\_TV.
- 3. Download the bitstream (LED1.sof) into the FPGA.
- 4. Use a **RCA Video cable** to connect your TREX C1 board to your TV video-in jack.
- 5. You should see a **color pattern** shown on your TV.
- 6. Users can use the code in the project library to expand their own ideas

on showing pictures/patterns on TV.

#### **DIP Switch**

There are four DIP switches on TREX1 board for users to use. Set the the switch to the **ON position to connect the corresponding pin to GROUND**.

| Signal | Cyclone Pin Number |
|--------|--------------------|
| SW1    | 184                |
| SW2    | 183                |
| SW3    | 182                |
| SW4    | 181                |

#### **SDRAM** Interface

The SDRAM used on the TREX1 board is a 8Mbyte device organized as 1M x 4 Banks x 16bits configuration. The part number of SDRAM used is **Samsung K4S641632F-TC75000** (or equivalent)

| Signal      | Cyclone Pin Number |
|-------------|--------------------|
| SD_ADDR[0]  | 77                 |
| SD_ADDR[1]  | 78                 |
| SD_ADDR[10] | 76                 |
| SD_ADDR[11] | 62                 |
| SD_ADDR[2]  | 79                 |
| SD_ADDR[3]  | 80                 |
| SD_ADDR[4]  | 68                 |
| SD_ADDR[5]  | 67                 |
| SD_ADDR[6]  | 66                 |
| SD_ADDR[7]  | 65                 |
| SD_ADDR[8]  | 64                 |
| SD_ADDR[9]  | 63                 |
| SD_BA_0     | 47                 |
| SD_BA_1     | 75                 |
| SD_CAS_N    | 44                 |
| SD_CKE      | 61                 |
| SD_CLK      | 50                 |
| SD_CS_N     | 46                 |

| SD_DATA[0]  | 15 |
|-------------|----|
| SD_DATA[1]  | 16 |
| SD_DATA[10] | 57 |
| SD_DATA[11] | 56 |
| SD_DATA[12] | 54 |
| SD_DATA[13] | 53 |
| SD_DATA[14] | 49 |
| SD_DATA[15] | 48 |
| SD_DATA[2]  | 17 |
| SD_DATA[3]  | 18 |
| SD_DATA[4]  | 19 |
| SD_DATA[5]  | 20 |
| SD_DATA[6]  | 21 |
| SD_DATA[7]  | 41 |
| SD_DATA[8]  | 59 |
| SD_DATA[9]  | 58 |
| SD_LDQM     | 42 |
| SD_RAS_N    | 45 |
| SD_UDQM     | 60 |
| SD_WE_N     | 43 |

#### **Flash Memory**

The Flash Memory used on the TREX1 board is a 1Mbyte device organized as 1M x 8bit configuration. The part number of Flash Memory used is

MX29LV800T/B or SST39LF800A (100% functional and pin compatible).

Detailed spec can be found in the <your project

*library*>\3rd\_party\_spec\sst39vf800a.pdf You can use Lab3\_TRex\_Panel and Signal Tap to observe the interface timing

| Signal     | Cyclone Pin Number |
|------------|--------------------|
| FL_ADDR[0] | 125                |
| FL_ADDR[1] | 115                |
| FL_ADDR[2] | 84                 |
| FL_ADDR[3] | 85                 |
| FL_ADDR[4] | 86                 |
| FL_ADDR[5] | 87                 |
| FL_ADDR[6] | 88                 |

| FL_ADDR[7]                           | 94  |
|--------------------------------------|-----|
| FL_ADDR[8]                           | 95  |
| FL_ADDR[9]                           | 101 |
| FL_ADDR[10]                          | 102 |
| FL_ADDR[11]                          | 103 |
| FL_ADDR[12]                          | 104 |
| FL_ADDR[13]                          | 105 |
| FL_ADDR[14]                          | 106 |
| FL_ADDR[15]                          | 113 |
| FL_ADDR[16]                          | 114 |
| FL_ADDR[17]                          | 126 |
| FL_ADDR[18]                          | 96  |
| FL_ADDR[19]                          | 97  |
| FL_ADDR[20]                          | 100 |
| FL_CE_N                              | 83  |
| FL_DQ[0]                             | 117 |
| FL_DQ[1]                             | 118 |
| FL_DQ[2]                             | 119 |
| FL_DQ[3]                             | 120 |
| FL_DQ[4]                             | 121 |
| FL_DQ[5]                             | 122 |
| FL_DQ[6]                             | 123 |
| FL_DQ[7]                             | 124 |
| FL_OE_N                              | 116 |
| FL_RST_N                             | 98  |
| FL_WE_N                              | 99  |
| nv_cs0_n                             | 81  |
| (Note that Flash is sharing data bus |     |
| with CompactFlash connector. Need    |     |
| to drive high to this pin to disable |     |
| CompactFlash.                        |     |
| nv_cs1_n                             | 82  |
| (Same as above, must drive high to   |     |
| this pin to disable CompactFlash.    |     |

## **Compact Flash Card**

The Compact Flash connector enables hardware designs to access a Compact

Flash card. TREX1 board provides true IDE mode (IDE hard-disk mode). Compact Flash spec can be found at C:\Terasic\3rd\_party\_specs\CF-spec.pdf

| Signal   | Cyclone Pin Number |
|----------|--------------------|
| da[0]    | 114                |
| da[1]    | 106                |
| da[2]    | 105                |
| nv_cs0_n | 81                 |
| nv_cs1_n | 82                 |
| dd[0]    | 115                |
| dd[1]    | 116                |
| dd[2]    | 118                |
| dd[3]    | 84                 |
| dd[4]    | 86                 |
| dd[5]    | 88                 |
| dd[6]    | 95                 |
| dd[7]    | 97                 |
| dd[8]    | 117                |
| dd[9]    | 119                |
| dd[10]   | 121                |
| dd[11]   | 85                 |
| dd[12]   | 87                 |
| dd[13]   | 94                 |
| dd[14]   | 96                 |
| dd[15]   | 98                 |
| dior_n   | 99                 |
| diow_n   | 100                |
| nv_intrq | 102                |
| IOIS16   | 120                |

| IORDY                                  | 104 |
|----------------------------------------|-----|
| CF_REG                                 | 113 |
| reset                                  | 103 |
| FL_CE_N                                | 83  |
| (Note that CF is sharing data bus with |     |
| Flash, you need to drive this pin high |     |
| to disable Flash Memory)               |     |

#### Lab 5: Testing Your Compact Flash (CF) Card

#### Repeat the following steps to test the CF card:

- 1. Make sure the power is off.
- 2. Insert your CF card into the CF socket on the TREX C1 board.
- 3. Power on the board.
- 4. Launch Quartus II Software.
- 5. Download the bitstream (LED1.sof) located in the Lab6\_CF directory into the FPGA.
- You will see the pattern displayed on the 7-SEG module is changing; 5 secs after bitstream downloading, you will see all the segments of the 7-SEG module are ON. Also, the LEDs will be turned off if there is NO error.
- 7. You can redo the test by pressing KEY1. The same testing pattern will be repeated.
- 8. Use tool like **Hex WorkShop** to examine the content of the CF card.
- Figure 9.4 shows the content of the CF card viewed by Hex Workshop.
  Note that the bytes the test program filled in is incremented from 0000 to 00FF in a 256-byte sector (the 5<sup>th</sup> sector).

| Hex Worksho                             | - [Drive | I: <sec< th=""><th>tor 5/31</th><th>[359&gt;]</th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th></sec<> | tor 5/31 | [359>]         |      |      |            |            |      |       |      |      |      |      |      |
|-----------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------|------|------|------------|------------|------|-------|------|------|------|------|------|
| <b>E</b> le <u>E</u> dit <u>D</u> isk   | Options  | Tools                                                                                                                                                        | Window   | / <u>H</u> elp |      |      |            |            |      |       |      |      |      |      |      |
| 🗃 🖬 🖨                                   | X 咱      | 82                                                                                                                                                           | 8        | 6*   C         |      | 00   | B S        | ι (        | I F  | D     |      |      | + +  |      | ×    |
| <b>≒</b> ~ « »                          | ≪ ≥ ∕    | × 1 ⊲                                                                                                                                                        | & */     | + -            | • •  | 1 %  | <u>e</u> 9 | <b>B B</b> | *    | ₩ [   |      |      |      |      |      |
| 000000000000000000000000000000000000000 | 0 0100   | 0200                                                                                                                                                         | 0300     | 0400           | 0500 | 0600 | 0700       | 0800       | 0900 | 00400 | 0B00 | 0000 | 0D00 | 0E00 | 0F00 |
| 00000020 100                            |          |                                                                                                                                                              | 1300     |                |      |      |            |            |      | 1400  |      | 1000 |      |      |      |
| 00000040 200                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      |      |
| 00000060 300                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      |      |
| 00000080 400                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       | 4B00 |      | 4D00 | 4E00 | 4F00 |
| 000000000 500                           |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      | 5F00 |
| 000000000 600                           |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      | 6D00 | 6E00 | 6F00 |
| 000000E0 700                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      | 7F00 |
| 00000100 800                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      | 8F00 |
| 00000120 900                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      |      |
| 00000140 400                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      |      |
| 00000160 B00                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      |      |      |
| 00000180 000                            | 0 C100   | C200                                                                                                                                                         | C300     | C400           | C500 | C600 | C700       | C800       | C900 | CAOO  | CB00 | CC00 | CD00 | CE00 | CF00 |
| 000001A0 D00                            | 0 D100   | D200                                                                                                                                                         | D300     | D400           | D500 | D600 | D700       | D800       | D900 | DAOO  | DB00 | DC00 | DD00 | DEOO | DF00 |
| 000001C0 E00                            | 0 E100   | E200                                                                                                                                                         | E300     | E400           | E500 | E600 | E700       | E800       | E900 | EAOO  | EB00 | EC00 | ED00 | EE00 | EF00 |
| 000001E0 F00                            |          |                                                                                                                                                              |          |                |      |      |            |            |      |       |      |      |      | FE00 |      |

Figure 9.4. The content of the CF card after testing procedure

## **Expansion Connectors (JP1, JP2)**

Headers JP1 and JP2 provide users to interface with their own special-function daughter cards using a common 40-pin cable for an IDE hard drive.

| FPGA Pin Number | Header JP1 |    | FPGA Pin Number |
|-----------------|------------|----|-----------------|
| 180             | 1          | 2  | 179             |
| 178             | 3          | 4  | 177             |
| 175             | 5          | 6  | 174             |
| 173             | 7          | 8  | 169             |
| 168             | 9          | 10 | 167             |
| VCC5V           | 11         | 12 | GND             |
| 166             | 13         | 14 | 165             |
| 164             | 15         | 16 | 163             |
| 162             | 17         | 18 | 161             |
| 160             | 19         | 20 | 159             |
| 158             | 21         | 22 | 141             |
| 140             | 23         | 24 | 139             |
| 138             | 25         | 26 | 137             |
| 136             | 27         | 28 | 135             |
| VCC3.3V         | 29         | 30 | GND             |
| 134             | 31         | 32 | 133             |
| 132             | 33         | 34 | 128             |
| 126             | 35         | 36 | 125             |
| 124             | 37         | 38 | 123             |
| 122             | 39         | 40 | 121             |

| FPGA Pin Number | Header JP2 | FPGA Pin Number |       |
|-----------------|------------|-----------------|-------|
| 199             | 1          | 2               | 7SEG0 |
| 7SEG1           | 3          | 4               | 7SEG2 |
| 7SEG3           | 5          | 6               | 7SEG4 |
| 7SEG5           | 7          | 8               | 7SEG6 |
| 7SEG7           | 9          | 10              | 184   |
| VCC5V           | 11         | 12              | GND   |

| 100     | 10 | 4.4 | 100 |
|---------|----|-----|-----|
| 183     | 13 | 14  | 182 |
| 181     | 15 | 16  | 120 |
| 119     | 17 | 18  | 118 |
| 117     | 19 | 20  | 116 |
| 115     | 21 | 22  | 114 |
| 113     | 23 | 24  | 106 |
| 105     | 25 | 26  | 104 |
| 103     | 27 | 28  | 102 |
| VCC3.3V | 29 | 30  | GND |
| 100     | 31 | 32  | 99  |
| 98      | 33 | 34  | 97  |
| 96      | 35 | 36  | 95  |
| 94      | 37 | 38  | 88  |
| 87      | 39 | 40  | 86  |

# Chapter

# **RS-232 Version of the TREX Control Panel**

The reason why we provide users the USB-Version of TREX Control Panel software package is to dramatically reduce the Flash/SDRAM programming time. However, users cannot use the USB-version Control Panel together with Altera Signal Tap tools because both tools share the same USB blaster link.

To enable users to build their own API or C++ control tools on top of our current TREX Control Panel Package, we provide users all the code (C++ and RTL) free of charge. Note that users are allowed to use and modify the code provided in the TREX CD-ROM only if the FPGA hardware platform used is designed and manufactured by Terasic Technologies.

#### **Connect PC to the Board using RS232**

Use the 9-pin cable attached in the development kit to connect your PC to the TREX1 board. For notebook PC without a serial port, you can use a USB\_to COM port cable. And follow the instructions to program the FPGA.

- Make sure the Lab7\_TREX\_Panel\_RS232 is installed to your project directory.
- 2. Start Quartus II Software.
- 3. Click File > Open Project.
- 4. Select C:\Terasic\Lab7\_TREX\_Panel\_RS232\New\_Flash
- 5. Click on **Programming** button. Setup the programming hardware to USB-Blaster according to the instructions stated in Chapter 4.
- Select the New\_Flash.sof stored in the Lab2\_TREX\_Panel\_RS232 directory and download it to FPGA.
- 7. Now you can use the RS232 cable to connect PC to your TREX1 board.

#### Control the Board Using RS232 Version of TREX Panel

This session shows how to setup the connection using RS232 to perform the RS232 version of TREX Control Panel.

- Make sure that you have programmed the board with the C:\Terasic\Lab7\_TREX\_Panel\_RS232\QII\_Project\New\_Flash.sof
- Start the TREX\_C1\_Control\_Panel\_RS232 program located in your C:\Terasic. The user interface shown in Figure 15 should appear.
- 3. Click Open > Open COM Port.
- 4. Select the COM port used to connect to the board. TREX Control Panel Application will list all the available COM ports in your system for you to choose. Figure 10.1 shows the dialog box for COM port setup. Click OK to connect to the board.
- 5. The rest of operations are same as the USB version

| Settings<br>Port | COM6   | •          |
|------------------|--------|------------|
| Baud rate        | 115200 |            |
| Data bits        | 8      | 8 <b>.</b> |
| Stop bits        | 1      | -          |
| Parity           | None   | -          |
| Flow control     | None   | •          |

Figure 10.1. COM Port Setup in TREX Control Panel

#### The C++ Source Code

All the C++ code can be found under Lab7\_Control\_Panel\_RS232/ BCB\_RS232\_Multiplexer. The software package is built using Borland C++ Builder.



Chapter

# Lab 8: NIOS II 5.0 Core

The Nios embedded processor is optimized for Altera FPGA SOPC(System on Programmable Chip) solutions. A user can easily combine the Nios processor with user logic and program it into an FPGA using SOPC Builder and the user can use NIOSII IDE environment to develop software applications running on NIOS processor.

Nios processor has many features that allow users to accelerate and optimize their designs by using simple yet non-traditional methods. In this lab, we are going to demonstrate a example where we run NIOS II 5.0 CPU on TREX C1 board and use a C++ software application to control the board.

#### Load NIOS II 5.0 on TREX C1

The NIOSII 5.0 core is built using SOPC Builder targeted for TREX C1 board. Repeat the following steps to go through the project.

- 1. Make sure Lab8\_NIOSII\_TREX in TREX CD-ROM is installed to your project directory.
- 2. Start Quartus II Software.
- 3. Click File > Open Project.
- 4. Select C:\Terasic\Lab8\_NIOSII\_TREX\standard\standard
- Click on Programming button. Setup the programming hardware to USB-Blaster according to the instructions stated in Chapter 4.
- 6. Select the standard.sof stored in the Lab8\_NIOSII\_TREX directory and download it to FPGA.
- 7. Now you can use NIOSII IDE to control the board.
- Figure 11.1 shows the screen capture of SOPC Builder targeting NIOS II core in TREX C1 board.

| and the second |                         | elp                        |                          |              |                |            |
|------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------|--------------------------|--------------|----------------|------------|
| System Contents Nios II More "cpi                                                                                | u" Setting              | gs System Generation       |                          |              |                |            |
| 🙀 Altera SOPC Builder 🛛 🔥                                                                                        |                         |                            |                          |              |                |            |
| 🗮 📩 Create New Component                                                                                         | Target                  |                            | Clock (MHz)              |              |                |            |
| E Avalon Components                                                                                              |                         | Board: Unspecified Board   |                          | clk          | 50.0           |            |
| Nios Il Processor - Alt                                                                                          | Nios Il Processor - Alt |                            |                          | elick to add |                |            |
| 🗄 Bridges                                                                                                        |                         | Device Family: Cyclone 🛛 😒 | HardCopy Compatible      |              |                |            |
| Communication                                                                                                    |                         | 1                          |                          |              |                |            |
| 🗄 Display                                                                                                        | -                       |                            |                          |              | II Mathematica | 1112550050 |
| 🗄 EP1C20 Nios Developm 🔜                                                                                         | Use                     | Module Name                | Description              |              | Clock          | Base       |
| 🗄 EP1S10 Nios Developn                                                                                           |                         | 🖽 cpu                      | Nios II Processor - Alte |              | clk            | 0x0212000  |
| 🗄 EP1S40 Nios Developn                                                                                           |                         | ⊞ ext_ram_bus              | Avalon Tri-State Bridg   |              | clk            |            |
| EP20K200E Nios Devel                                                                                             |                         | ⊞ ext_flash                | Flash Memory (Commo      |              | 11111          | ▲ 0×00000  |
| EP2C35 Nios Developm                                                                                             |                         | epcs_controller            | EPCS Serial Flash Con    | troller      | clk            | 0x0210000  |
| EP2S60 DSP Board Stra                                                                                            |                         | sys_clk_timer              | Interval timer           |              | clk            | 0x0212080  |
| EP2S60 Nios Developn <sup>™</sup>                                                                                |                         | ⊞ jtag_uart                | JTAG UART                |              | clk            | 0x021208B  |
| 🗄 Ethernet 🥃                                                                                                     |                         | 🖽 button_pio               | PIO (Parallel I/O)       |              | clk            | 0x0212086  |
| C Pridar Datitation S                                                                                            |                         | ⊞ led_pio                  | PIO (Parallel I/O)       |              | clk            | 0x0212087  |
|                                                                                                                  |                         | ⊞ high_res_timer           | Interval timer           |              | clk            | 0x02120820 |
| All Available Components                                                                                         |                         | 🗄 seven_seg_pio            | PIO (Parallel I/O)       |              | clk            | 0x0212089  |
| 🗶 🌒 🎘 O                                                                                                          |                         | ⊞ uart1                    | UART (RS-232 serial p    | oort)        | clk            | 0x0212084  |
|                                                                                                                  |                         |                            | System ID Peripheral     |              | clk            | 0x021208B  |

Figure 11.1 The Screen Capture of the SOPC Builder used to create NIOSII core on TREX C1.

#### **Running NIOS II on TREX C1**

In this example, we are running NIOS II on TREX C1 and use NIOS II processor to control the LEDs on the TREX C1 Board. Follow the steps to exercise the lab.

- 1. Make sure *C:\Terasic*\Lab8\_NIOSII\_TREX\**standard**\**standard.sof** is loaded into the FPGA
- 2. Start NIOS II IDE program.
- 3. Refer to Figure 11.2, select C:\Terasic\Lab8\_NIOSII\_TREX\standard as your workspace.
- 4. Click on File **hello\_led.c** in the left-hand side of the window as shown in Figure 11.3.
- Once the NIOSII is running on TREX C1 board, you can press the push buttons (KEY0 – KEY3). The corresponding LED0 – LED3 will be turned on according to the push button status. NIOS II IDE debugging window will also show the information on which button is pressed, as shown in Figure 11.4.



Figure 11.2. Start NIOSII IDE and open C: \Terasic\Lab8\_NIOSII\_TREX\standard as workspace







Figure 11.4. The results of running the example

#### NOTE: Is the example NOT working in your environment?

The NIOSII IDE environment assumes users' home directories for SOPC Builder are under C:\Documents and Settings\User Account\.sopc\_builder.

Therefore, the NIOSII IDE will NOT work if your Window home directory is NOT under C:\Documents and Setting\User Account\.sopc\_builder



## **Appendix**

## **Revision History**

| Date / Author  | Change Log                                   |  |
|----------------|----------------------------------------------|--|
| April 18. 2005 | Initial Version (Preliminary)                |  |
| Sean Peng      |                                              |  |
| June 20, 2005  | V1.2                                         |  |
| Sean Peng      | 1. Provide USB-version of the API.           |  |
|                | 2. Added SDRAM features.                     |  |
|                | 3. Added multi-port Flash/SDRAM controllers  |  |
|                | and associated applications.                 |  |
|                | 4. Added source code of the TREX Control     |  |
|                | Panel RS232 version.                         |  |
|                | 5. Restructured the CD-ROM directory layout  |  |
|                | and added more code examples.                |  |
| July 20, 2005  | V1.3                                         |  |
| Sean Peng      | 1. Add TV lab and NIOSII / IDE Lab examples. |  |
|                | 2. Use Autorun for CD-ROM installation       |  |

## **TREX CD-ROM Directory Structure and Reference Designs**

TREX1 board provides users many reference designs and API tool.

| Lab Directory          | Descriptions                               |
|------------------------|--------------------------------------------|
| Default Bitstream      | The Bitstream loaded into the serial       |
|                        | configuration device                       |
| Lab1_PowerUp           | PowerUp test for LED and 7-SEG             |
| Lab2_work_with_scanned | The examples on how to control the scanned |
| display                | 7-SEG display module                       |
| Lab3_Control_Panel     | TREX C1 Control Panel and associated IPs:  |

|                             | SDRAM controller, Flash Memory Controller.  |
|-----------------------------|---------------------------------------------|
|                             | Virtual DPDT switches, PS2, VGA controller, |
|                             | LED/7-SEG control. Applications includes    |
|                             | Flash Music box                             |
| Lab4_Audio                  | 1kHz sound generator                        |
| Lab4_Control_Panel_SDRAM_   | Playing CD-Quality music from SDRAM -       |
| MusicPlayer                 | implementation of a CD-Music Box.           |
| Lab5_TV                     | Generating NTSC/PAL TV signal and color     |
|                             | patterns                                    |
| Lab6_CF                     | Read, Write, and Compare testing on CF      |
|                             | card                                        |
| Lab7_Control_Panel_RS232    | TREX C1 Control Panel via RS232 link and    |
|                             | associated IPs. By using the RS232 path,    |
|                             | users can use signal tap to simultaneously  |
|                             | with the Control Panel. Signal Tap must be  |
|                             | shown in this window.                       |
| Lab8_NIOSII_TREX            | A NIOSII example on TREX C1                 |
| Raw_binary_data             | Some 1Mbyte and 8Mbyte CD music raw         |
|                             | data                                        |
| 3 <sup>rd</sup> party_specs | all 3 <sup>rd</sup> party ASIC specs.       |

#### Schematic

Please send email to **support@terasic.com** for requesting schematic information.

## Always Visit TREX C1 Webpage for New Labs

We will be continuing providing interesting examples and labs on our TREX C1 webpage. Please visit **trex.terasic.com** for more information