#### Lab #5: FPGA Board

- Synthesize and run a counter on ZedBoard

4190.309A: Hardware System Design (Spring 2018)

Tutorial: ZedBoard exploration

### Preparing the Board

- 1. Set configuration mode pins from 01100 to **00000**
- 2. Insert USB-JTAG cable at J17
- 3. Insert power cable at J20
- 4. Turn the power on with SW8
  - LD13 lights up when it is on
- 5. Check locations of switches & LED
  - We will deal with SW0~7 & LD0~7

#### ☆ CAVEAT: J17 pin is very fragile!

If you cannot pull out a USB-JTAG cable from J17, press hooks with something pointed (sharp pencil, etc.).



#### SW2LED Module

- sw2led.v: Verilog file
  - Create a design source
  - Specifying logic behavior
    - Turn LEDs on/off using switches
- sw2led.xdc: Design constraints file
  - Specify constraints
  - Connecting Verilog input/output ports to FPGA pins
  - 8 switches & 8 LEDs
    - Refer to User's Guide p. 4, pp. 19-20



# **Synthesis**

#### Synthesize and check







### Implementation

Implement and download your design into FPGA





# Enjoy Your Design!

■ Toggle SW0~7 and check how LD0~7 changes



Practice: Counter implementation

## Design: A Simple Up-Counter

- Output [7:0] LD is incremented by one every second
- Use GCLK as an input clock and use it to wait for 1s
  - GCLK signal has frequency of 100MHz (Check User's Guide p.3).
- Use CENTER\_PUSHBUTTON as a asynchronous posedge reset
  - counts up from 0 again after reset



#### Constraints

- Find which pin to use from User's Guide
- Find which bank each pin is on from User's Guide
- Start from a master constraint file from the following link:

  https://github.com/Digitart/Zodboord/blob/recetor/Decourses/XDC/zodboord/ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground-ground

https://github.com/Digilent/Zedboard/blob/master/Resources/XDC/zedboard\_master.xdc

## Grading policy

#### Check lists

- LED counts up (50 points)
- LED counts up every 1s (20 points)
- Reset works (20 points)
- Finished in class (10 points)
- Submit "counter.v" and "counter.xdc" on eTL.
  - Due: 4/10 (Tue) PM 2:00
  - Late submission will result in a penalty
- Show that your board works
  - In class / office hour (Tue) recommended
  - If you cannot come to the office hour, mail us a short video

# Appendix: Installing Driver

- Driver required for the host computer to recognize ZedBoard
  - i.e. Hardware Manager will not find the board without the driver
- Install using linux command line

sudo chmod +x \$(vivado\_dir)/data/xicom/cable\_drivers/lin64/install\_script/install\_drivers sudo \$(vivado dir)/data/xicom/cable drivers/lin64/install script/install drivers

```
🔊 🖨 📵 seonghak@seonghak-XPS-8900: /opt/Xilinx/Vivado/2016.4/data/xicom/cable_drivers/lin64/install_script/install_drivers
seonghak@seonghak-XPS-8900:/opt/Xilinx/Vivado/2016.4/data/xicom/cable_drivers/lin64/install_script/install_drivers$ ls
52-xilinx-digilent-usb.rules install_digilent.sh                           setup_pcusb
                               install drivers
52-xilinx-pcusb.rules
seonghak@seonghak-XPS-8900:/opt/Xilinx/Vivado/2016.4/data/xicom/cable_drivers/lin64/install_script/install_drivers$ sudo ./install
[sudo] password for seonghak:
INFO: Installing cable drivers.
INFO: Script name = ./install drivers
INFO: HostName = seonghak-XPS-8900
INFO: Current working dir = /opt/Xilinx/Vivado/2016.4/data/xicom/cable_drivers/lin64/install_script/install_drivers
INFO: Kernel version = 4.13.0-37-generic.
INFO: Arch = x86 64.
Successfully installed Digilent Cable Drivers
--File /etc/udev/rules.d/52-xilinx-pcusb.rules does not exist.
--File version of /etc/udev/rules.d/52-xilinx-pcusb.rules = 0000.
-- Updating rules file.
INFO: Digilent Return code = 0
INFO: Xilinx Return code = 0
INFO: Return code = 0
INFO: Driver installation successful.
CRITICAL WARNING: Cable(s) on the system must be unplugged then plugged back in order for the driver scripts to update the cables.
      ak@seonghak-XPS-8900:/opt/Xilinx/Vivado/2016.4/data/xicom/cable drivers/lin64/install script/install driversS
```