

### FPGA RGB Matrix

Created by lady ada



https://learn.adafruit.com/fpga-rgb-matrix

Last updated on 2021-11-15 05:49:11 PM EST

### Table of Contents

| Overview                                                                 | 3  |
|--------------------------------------------------------------------------|----|
| Controlling the Adafruit 32x16 RGB LED Matrix with a DE0-Nano FPGA Board | 3  |
| Prerequisites                                                            | 3  |
| New Project                                                              | 4  |
| User configuration                                                       | 4  |
| Creating the Quartus II project                                          | 4  |
| Pin settings                                                             | 7  |
| Pin settings                                                             | 7  |
| Pin Assignments                                                          | 8  |
| Making pin assignments                                                   | 8  |
| Synthesize and Upload                                                    | 10 |
| Synthesizing the design                                                  | 10 |
| Uploading the bitfile                                                    | 10 |
| Demos                                                                    | 12 |
| Running the Virtual JTAG interface server                                | 12 |
| The included Processing demos and code                                   | 13 |
| More!                                                                    | 13 |

### Overview



# Controlling the Adafruit 32x16 RGB LED Matrix with a DE0-Nano FPGA Board

Adafruit currently sells a really cool <u>16x32 RGB LED matrix panel</u> (http://adafru.it/420) in their store that is "designed to be driven by an FPGA or other high speed processor." The purpose of this tutorial is to help you get started driving a small handful of these displays with the <u>DEO-Nano board</u> (https://adafru.it/alK), which contains a mid-range Altera FPGA.

#### Prerequisites

This tutorial is for those who are familiar with electronics, microcontrollers, programming IDEs and noodling around on a windows computer with drivers, command prompts, editing text files, etc. Its a good introductory FPGA project but not a good introductory microcontroller/electronics project.

You need to have the Quartus II software installed on your computer. If not, you can download it from <u>Altera's website</u> (https://adafru.it/alL) or install it from the DVD that comes with the DEO-Nano board. You will also need to install the USB-Blaster drivers that enable your computer to communicate with the FPGA (see this short <u>YouTube</u> video (https://adafru.it/alM)).

# New Project

### User configuration

Once you are all set up and ready to begin, download the necessary files for this project from its Github repository (https://adafru.it/diq) (click on the "ZIP" icon).

Open the file vhdl/config.vhd in a text editor and change line 32 (constant NUM\_PANELS...) to indicate the total number of LED panels you have daisy-chained together in your display. For example, if you are using a 1x2 or 2x1 grid, you will want to change the line to:

constant NUM\_PANELS : integer := 2

You may optionally edit line 33 (constant PIXEL\_DEPTH...) in a similar manner to indicate how many bits-per-pixel you want to use. This will affect the level of brightness control available to you later. Finally, save the file!

#### Creating the Quartus II project

Start Quartus II and open the "New Project Wizard" from the "File" menu. On the first page, name the project rgbmatrix-fpga (or something similar) and name the top-level entity top\_level. Click Next.

| New Project Wizard                                                                                                                                       | ×    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Directory, Name, Top-Level Entity [page 1 of 5]                                                                                                          |      |
| What is the working directory for this project?                                                                                                          |      |
| C:  Users\Brian \Quartus II Projects\rgbmatrix-fpga                                                                                                      |      |
| What is the name of this project?                                                                                                                        |      |
| rgbmatrix-fpga                                                                                                                                           |      |
| What is the name of the top-level design entity for this project? This name is case sensitive and must exactly match the entity name in the design file. |      |
| top_level                                                                                                                                                |      |
| Use Existing Project Settings                                                                                                                            |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
|                                                                                                                                                          |      |
| < Back Next > Einish Cancel                                                                                                                              | Help |

Now we will add the source code files to the project. Click the "..." button to open the file browser and select the .vhd files in the vhdl folder you downloaded earlier (do not include the testbenches directory). Click "..." again and open the megawizard folder. Set the type drop-down menu to "All Files (\*.\*)" so you can select the .qip, .cmp, and megawizard\_vjtag.vhd files (do not include megawizard\_vjtag\_inst.vhd). Add them to the project and click Next.

| jle name:                                                                                                |                                |         |                             |             | Add        |
|----------------------------------------------------------------------------------------------------------|--------------------------------|---------|-----------------------------|-------------|------------|
|                                                                                                          | Туре                           | Library | Design Entry/Synthesis Tool | HDL Version | Add All    |
| gbmatrix-fpga/vhdl/megawizard/megawizard_vjtag.vhd<br>gbmatrix-fpga/vhdl/megawizard/megawizard_vjtag.qip | VHDL File<br>IP Variation File |         |                             | Default     | Remove     |
| pmatrix-ppga/vhg/megawizarg/megawizarg_vitag.cmp<br>pmatrix-fpga/vhg/top_level.vhg                       | VHDL File                      | _       |                             | Default     | Up         |
| gbmatrix-fpga/vhdl/memory.vhd                                                                            | VHDL File                      |         |                             | Default     |            |
| gbmatrix-fpga/vhdl/ledctrl.vhd                                                                           | VHDL File                      |         |                             | Default     | Down       |
| gbmatrix-fpga/vhdl/jtag_iface.vhd                                                                        | VHDL File                      |         |                             | Default     |            |
| gbmatrix-fpga/vhdl/config.vhd                                                                            | VHDL File                      |         |                             | Default     | Properties |
| gbmatrix-fpga/vhdl/clk_div.vhd                                                                           | VHDL File                      |         |                             | Default     |            |
|                                                                                                          |                                |         |                             |             |            |
|                                                                                                          |                                |         |                             |             |            |

The FPGA chip in use on the DEO-Nano is the Cyclone IV EP4CE22F17C6N. You can find it by setting the device family to "Cyclone IV E", package to "FBGA", pin count to 256, and speed grade to 6. Select the chip and click Next.

| Eamily: Cycle<br>Devices: A<br>Target device<br>O Auto device<br>O Specific de | ane IV E           | ter<br>ilable device | es' list  | <b>T</b> | Padgag<br>Pin gou<br>Speed | grade: FBGA<br>256<br>grade: 6<br>ow advanced device:<br>rdCopy compatible o | s<br>niy                |     | •   |
|--------------------------------------------------------------------------------|--------------------|----------------------|-----------|----------|----------------------------|------------------------------------------------------------------------------|-------------------------|-----|-----|
| Other: n/<br>vailable device<br>Name                                           | s:<br>Core Voltage | LEs                  | User I/Os | Memo     | ry Bits                    | Embedded mu                                                                  | ltiplier 9-bit elements | PLL | Glo |
| P4CE6F17C6                                                                     | 1.2V               | 6272                 | 180       | 276480   |                            | 30                                                                           | •                       | 2   | 10  |
| P4CE10F17C6                                                                    | 1.2V               | 10320                | 180       | 423936   |                            | 46                                                                           |                         | 2   | 10  |
| P4CE15E17C6                                                                    | 1.2V               | 15408                | 166       | 516096   |                            | 112                                                                          |                         | 4   | 20  |
| P4CE22F17C6                                                                    | 1.2V               | 22320                | 154       | 608256   |                            | 132                                                                          |                         | 4   | 20  |
|                                                                                |                    |                      |           |          |                            |                                                                              |                         |     |     |

Set the "Simulation" tool name to "ModelSim-Altera" and the format to "VHDL". Leave everything else as "<None>" and click Next.

| Tool Turpe              | Tool Name        | Eormat(c)     | Due Taol Automatically                                   |
|-------------------------|------------------|---------------|----------------------------------------------------------|
| Docion Entry (Synthesia | (here)           | - Chienes     | Run Tool Automatically                                   |
| Simulation              | ModelSim-Altera  |               | Run data level simulation automatically after completion |
| Timing Analysis         | (None >          |               | Run this tool automatically after compilation            |
| formal Verification     | <none></none>    |               |                                                          |
| oard-Level              | Timing           | <none></none> | •                                                        |
|                         | Symbol           | <none></none> | <b>•</b>                                                 |
|                         | Signal Integrity | <none></none> |                                                          |
|                         | Boundary Scan    | <none></none> | <b>•</b>                                                 |
|                         |                  |               |                                                          |

Click Finish to create the project!

## Pin settings

#### Pin settings

Now that the project has been created, you need to change two more settings before we can move on. Go to the Project Navigator panel in the top left area of Quartus and right click on the device ("Cyclone IV E: ..."). Select "Device" from the menu.

| Category:          |                                                                                                                                                |                 |                          |                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------|----------------|
| General            | Unused Pins                                                                                                                                    | Show in 'A      | vailable devices' list   |                |
| Programming Files  | Specify device-wide options for reserving all unused pins on the device. To reserve                                                            | Package:        | FBGA                     | •              |
| Unused Pins        | Individual dual-purpose configuration pins, go to the Dual-Purpose Pins tab. To reserve<br>other pins individually, use the Assignment Editor. | Pin count:      | 256                      | •              |
| Capacitive Loading |                                                                                                                                                | Speed gra       | de: 6                    | •              |
| Board Trace Model  | Reserve all unused pins: As input tri-stated                                                                                                   | Speed gra       | we. U                    |                |
| Voltage            |                                                                                                                                                |                 | suvericeu devices        |                |
| Pin Placement      |                                                                                                                                                | - Haroci        | opy compauble only       |                |
| CvPCIe Settings    |                                                                                                                                                | Device and      | Pin Options              |                |
|                    |                                                                                                                                                |                 |                          |                |
|                    |                                                                                                                                                | Memory Bit      | s Embedded multiplier 9- | bit elements P |
|                    |                                                                                                                                                | 76480           | 30                       | 2              |
|                    |                                                                                                                                                | 23936           | 46                       | 2              |
|                    |                                                                                                                                                | 08256           | 132                      | 4              |
|                    |                                                                                                                                                |                 |                          |                |
|                    |                                                                                                                                                |                 |                          |                |
|                    |                                                                                                                                                |                 |                          |                |
|                    | Description:                                                                                                                                   |                 |                          |                |
|                    | Reserves all unused pins on the target device in one of 5 states: as inputs that are tri-                                                      |                 |                          |                |
|                    | stated, as outputs that drive ground, as outputs that drive an unspecified signal, as                                                          |                 |                          |                |
|                    | input or stated introduction, or as input or stated interinded party.                                                                          |                 |                          | ۲.             |
|                    |                                                                                                                                                |                 |                          |                |
|                    |                                                                                                                                                |                 |                          | Ψ              |
|                    | Reset                                                                                                                                          | device resource | 15                       |                |
|                    |                                                                                                                                                |                 |                          |                |
| 1                  | OK Cancel Help                                                                                                                                 |                 | OK Car                   | ncel Help      |

A window will open. Click "Device and Pin Options...". In the left hand side of the new window that comes up, open the "Unused Pins" category. Change the "Reserve all unused pins" settings to "As input tri-stated". This will essentially prevent the unused pins on the FPGA from doing anything unwanted on the DEO-Nano when we program the design.

Now select the "Voltage" category. Change the "Default I/O standard" to "3.3-V LVTTL". This is essential to do because the panels will not recognize a signal below this voltage.

| Device and Pin Options - toplevel     Cotogenue                                                                                                                                                                                                                                 | ×                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device and Pin Options - toplevel     Category:     General     Configuration     Programming Files     Unused Pins     Dual-Purpose Pins     Capacitive Loading     Board Trace Model     I/O Timing     Woltage     Pin Placement     Error Detection CRC     CvPCIe Settings | Voltage         Specify voltage options for the device.         Default I/O standard:         3.3-V LVTT         VCCIO I/O bank1 voltage:         n/a in Cyclone IV E         VCCIO I/O bank2 voltage:         n/a in Cyclone IV E         Core voltage:         1.2V |
|                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                       |

Click OK, then click OK again.

### Pin Assignments

#### Making pin assignments

Go to the "Assignments" menu and select "Import Assignments...". Import the de0nano/rgbmatrix-fpga.qsf file. After you do this, a message should appear in the "System" console tab at the bottom of Quartus: "Import completed. 14 assignments were written (of of 14 read)."

| Specify the source and categories of assignments to import.                 |
|-----------------------------------------------------------------------------|
| Ele name: ents/GitHub/rgbmatrix-fpga/de0-nano/rgbmatrix-fpga.qsf Categories |
| Copy existing assignments into toplevel.qsf.bak before importing            |
| OK Cancel Help                                                              |

You can (optionally) customize the pin assignments that were imported by going to the "Assignments" menu and selecting "Assignment Editor". Additional information on the GPIO headers can be found in the DEO-Nano PDF manual (https://adafru.it/aIP)

(pages 18-20). A mapping of FPGA pins to GPIO headers can also be found in the de0-nano/DE0\_Nano.qsf file (open it with a text editor).

| ø  | 5    |             | Assignment Ed  | itor 🗵   |                   |                                   |         |
|----|------|-------------|----------------|----------|-------------------|-----------------------------------|---------|
| << | new: | >> 🔻 Filter | on node names: | *        |                   | <ul> <li>Category: All</li> </ul> | -       |
|    |      | Status      | From           | То       | Assignment Name   | Value                             | Enabled |
| V  | 1    | 🗸 Ok        |                | 🔷 lat    | Location GPIO 033 | PIN_B12                           | Yes     |
|    | 2    | 🗸 Ok        |                | 🔷 r1     | Location GPIO 018 | PIN_E7                            | Yes     |
|    | 3    | 🗸 Ok        |                | 🔷 b1     | Location GPIO 020 | PIN_E8                            | Yes     |
|    | 4    | 🗸 Ok        |                | 🔷 r2     | Location GPIO 022 | PIN_F9                            | Yes     |
|    | 5    | 🖌 Ok        |                | 🔷 b2     | Location GPIO 024 | PIN_C9                            | Yes     |
|    | 6    | 🖌 Ok        |                | 🔷 а      | Location GPIO 026 | PIN_E11                           | Yes     |
|    | 7    | 🖌 Ok        |                | 🔷 g1     | Location GPIO 027 | PIN_E10                           | Yes     |
|    | 8    | 🖌 Ok        |                | 🔷 с      | Location GPIO 028 | PIN_C11                           | Yes     |
|    | 9    | 🖌 Ok        |                | 🔷 g2     | Location GPIO 029 | PIN_B11                           | Yes     |
|    | 10   | 🗸 Ok        |                | 🔷 dk_out | Location GPIO 030 | PIN_A12                           | Yes     |
|    | 11   | 🗸 Ok        |                | 🔷 Ь      | Location GPIO 031 | PIN_D11                           | Yes     |
|    | 12   | 🗸 Ok        |                | 🔷 oe     | Location GPIO 032 | PIN_D12                           | Yes     |
|    | 13   | 🗸 Ok        |                | 🔷 dk_in  | Location CLK 50   | PIN_R8                            | Yes     |
|    | 14   | 🗸 Ok        |                | 🔷 rst_n  | Location KEY 0    | PIN_J15                           | Yes     |

Save any changes. Now we are ready to connect the pins on the FPGA to the pins on the RGB LED matrix panel!



Please refer to the <u>Adafruit guide for wiring details</u> (https://adafru.it/cl4) on the panel side.

You may want to use female-female jumper wires to make the connections between the IDC pins! (http://adafru.it/266)



Important: DOUBLE-CHECK ALL YOUR CONNECTIONS BEFORE POWERING ON! Be sure the board's orientation matches the diagrams when you connect the wires!

# Synthesize and Upload

### Synthesizing the design

To synthesize the design, go to the "Processing" menu and select "Start Compilation", or click on the purple arrow icon in the toolbar. Synthesis should be quite fast since the design is small. After compilation is successful, you should have a new .sof file in your Quartus project directory. It should be 703,642 bytes long.

### Uploading the bitfile

Plug in your DEO-Nano board via the USB connector. Now, go to the "Tools" menu and select "Programmer".



In the top left of the window that appears, you should see "USB-Blaster [USB-0]". If instead you see "No Hardware", click on "Hardware Setup..." and (re-)select your device.

| Hardware Setup                                                                              |                                                               |                            |                     |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------|---------------------|
| Hardware Settings JTAG S<br>Select a programming hardware<br>hardware setup applies only to | ettings<br>e setup to use when proj<br>the current programmer | gramming device<br>window. | s. This programming |
| Currently selected hardware:<br>Available hardware items                                    | No Hardware<br>No Hardware<br>USB-Blaster [USB-0]             |                            | •                   |
| Hardware                                                                                    | Server                                                        | Port                       | Add Hardware        |
| USB-Blaster                                                                                 | Local                                                         | USB-0                      | Remove Hardware     |
|                                                                                             |                                                               |                            | Close               |

Now, select the .sof file in the list, ensure "Program/Verify" is checked, and click "Start"! This should take about a second.



The FPGA is now programmed with your design! (This only programmed the SRAM though, not the onboard EEPROM — so the design is only stored until power is turned off.)

Note: In the future, you can use the command script de0-nano/program.cmd to quickly program the FPGA's SRAM with your .sof file (it uses the Quartus command line programming utility).

### Demos

### Running the Virtual JTAG interface server

Open the command script tcl/run.cmd in a text editor and ensure that the path to the quartus\_stp executable is correct. Then, double click the script to launch the Virtual JTAG interface server (tcl/vjtag\_server.tcl). This binds to a TCP port to allow programs and scripts to write data to the FPGA through Altera's Tcl API.

This allows you to send video to the FPGA from any device that can communicate over the network! For example, a remote Arduino with a Wi-Fi shield, or an Android cellphone.



#### The included Processing demos and code

Two demos written in the <u>Processing programming language</u> (https://adafru.it/alR) (a dialect of Java) are available in the processing folder. You can run either demo by copying its directory to your local sketchbook folder (usually ~/Processing). The first demo, Chaser is a basic test animation. The second demo, Magnify sends a real-time screen capture to the panels through the FPGA.



# More!

Stephen Goadhouse wrote in with an update to this project that eliminates the ghosting effect in the original writeup. Check it out by clicking below

LED\_Ctrl\_Updates.zip

https://adafru.it/djE