Addressable LEDs on the Arty FPGA Board
by mwingerson in Circuits > Electronics
3372 Views, 18 Favorites, 0 Comments
Addressable LEDs on the Arty FPGA Board
Addressable LEDs are fun to add to any project and can now to added to any Zynq or Microblaze design. The DigiLED FPGA IP core can be customized through a simple GUI and then writing patterns to the LEDs is simple with the included drivers.
Microblaze and Zynq designs can be a difficult projects so being familiar with one or both of these tutorials can be very useful:
The prebuilt project in Vivado 2015.4 can be found here
Adding IP Repository
The DigiLED IP core is an component that connects through the AXI interface to either a Zynq design or Microblaze design. First go and grab the IP so we can add it to Vivado
- Download the DigiLED ip core from here
- Copy the IP core to a workspace location on your computer
- Then click on "Project settings" in the left panel.
- In the new window that pops up, click on IP and click on the plus button to add the IP
- Browse the the workspace location that you saved the IP core to
- Click OK
Build Microblaze Design
- Create Block Design
- Add IP blocks:
- Microblaze processor
- DigiLED
- AXI GPIO
- Run Block automation and increase the local memory of the Microblaze processor to 128KB
- Run Connection automation
- Change clock wizard to be single ended and reset active low
- Connect the GPIO core to the pushbuttons
- right-click the "led_out" and click "make external"
- double-click on the DigiLED core to customize it
- Select HSV color mode
- Change the number of LEDs so that Vivado calculates the address bus width and click OK
- Reopen the DigiLED custom window to double-check that Vivado saved the settings correctly.
- Create the HDL wrapper
If any of this is confusing then refer to the tutorials listed in the beginning
Add XDC Constraint File and Connect
- Add the master Arty XDC from Digilent
- In the XDC, change this:
set_property -dict { PACKAGE_PIN V15 IOSTANDARD LVCMOS33 } [get_ports { ck_io[0] }]; #IO_L16P_T2_CSI_B_14 Sch=ck_io[0]
To this:
set_property -dict { PACKAGE_PIN V15 IOSTANDARD LVCMOS33 } [get_ports { led_out }]; #IO_L16P_T2_CSI_B_14 Sch=ck_io[0]
Generate Bitstream, Export Hardware Design and Launch SDK
- Click Generate Bitstream in the left pain
- Go to File->Export->Export Hardware...
- Check the box to Include bitstream
- Go to File-> Launch SDK
Add Application Project
- Go to File->New->Application Project...
- Give the project a good name
- Click next
- Select "Empty Project"
- Click Finish
- Add main.c file to src directory
- Connect the power line of the WS2812 LEDs to the 3.3V pin on the Arty
- Connect the ground line to the GND pin on the Arty
- Connect the data pin to IO 0 pin of the Arty.
- Expand Debug directory and right click the .elf file
- Click Run As..-> Launch on Hardware (GDB)
Now the design should be running and you should be able to change patterns with BTN0