### Lab #7: Run and Debug IP

04/19/2018

4190.309A: Hardware System Design (Spring 2018)

#### Overview

- Custom IP Design
  - Processing System + BRAM + Connectivity + Custom IP (shifter)
- Integrated Logic Analyzer (ILA)
  - Extract values of nets and regs on runtime
- Practice
  - Write a short report about HW and SW of Lab 7

Tutorial: Custom IP Design

#### **Notations**

- HOST\$ XXX
  - Type XXX at the terminal of your Ubuntu-PC.
- BOARD\$ YYY
  - Type YYY at the terminal of ZedBoard (on minicom).
- TCL\$ ZZZ
  - Type ZZZ at the Tcl console of Vivado.

## Custom IP Design - Apply Block Design (1)

- Download an example IP
  - HOST\$ git clone https://github.com/K16DIABLO/HSD\_LAB7.git
  - -HOST\$ tar -zxvf lab7\_ip\_repo.tar.gz



# Custom IP Design - Apply Block Design (2)

- Execute TCL scripts of the example block design.
  - 1. Select Tcl Console tab
  - 2. TCL\$ cd \$(git\_clone\_dir)
  - 3. TCL\$ source block\_design.tcl



## Custom IP Design - Summary



## Memory map of ZYNQ SoC (1)

- BRAM is mapped to address 0x4000\_0000 ~ 0x4000\_1FFF
- Shifter is mapped to address 0x43C0\_0000 ~ 0x43C0\_FFFF





# Memory map of ZYNQ SoC (2)

Shifter is activated when \*(0x43C0\_0000) == 0x5555

```
wire magic_code = (slv_reg0 == 32'h5555);
422
423
424
          always @( posedge S_AXI_ACLK )
425
          begin
426
            if ( S_AXI_ARESETN == 1'b0 )
427
              bram state <= BRAM IDLE:
428
            else
429
              case (bram_state)
430
                BRAM_IDLE: bram_state <= (magic_code)? BRAM_READ : BRAM_IDLE;</pre>
431
                BRAM_READ: bram_state <= BRAM_WAIT;
432
                BRAM_WAIT: bram_state <= BRAM_WRITE;</pre>
433
                BRAM_WRITE: bram_state <= (run_complete)? BRAM_IDLE: BRAM_READ;</pre>
434
                default : bram_state <= BRAM_IDLE;</pre>
435
              endcase
436
          end
```

## Custom IP Design - Create Wrapper





### Review: Use your bitstream

- Copy the generated bitstream to your SD card.
  - Replace zynq.bit in the 1.1GB partition of SD card with your own bitstream.
  - Location of the generated bitstream:
    - Host\$ \$(your\_project)/\$(your\_project).runs/impl\_1/design\_1\_wrapper.bit



#### Preparing the Board

- 1. Set configuration mode pins to **01100** (SD boot mode).
- 2. Insert USB-JTAG cable at J14.
- Insert power cable at J20.then turn the power on with SW8.LD13 lights up when it is on
- 4. Insert SD card, with **your own bitstream** in it.

CAVEAT: J14 pin is very fragile!
 If you cannot pull out a USB-JTAG cable from J14, press hooks with something pointed (sharp pencil, etc.).



## Review: Connect your board to host (1)

- Setup from host terminal
  - Host\$ dmesg | tail -n 20 | grep ttyACM

```
peonghun@ARC-jh:~

jeonghun@ARC-jh:~$ dmesg | tail -n 20 | grep ttyACM

[59321.619180] cdc_acm 2-1.5:1.0: ttyACM0: USB ACM device

jeonghun@ARC-jh:~$
```

- Connect to terminal of your board
  - Host\$ minicom -D /dev/ttyACMx
    - Replace x with the number from above

## Review: Connect your board to host (2)

- Boot your board
  - Board \$> boot
  - Wait 1~2 minutes for board to boot.
- If your Zedboard does not respond
  - Press BTN7(PS-RST).
- Before turn off the board
  - BOARD\$ sudo poweroff
- To quit minicom
  - ctrl + a, q

```
Welcome to minicom 2.7

OPTIONS: I18n
Compiled on Feb 7 2016, 13:37:27.
Port /dev/ttyACM0, 13:57:36

Press CTRL-A Z for help on special keys

Unknown command 'AT' - try 'help'
zynq-uboot> boot
```

## Review: Connect your board to host (3)

- Login to Debian Linux
  - ID : zed / PW : zedzed

```
OK ] Started Getty on tty5.
        Starting Getty on tty6...
 OK ] Started Getty on tty6.
 OK ] Started getty on tty2-tty6 if dbus and logind ar
 OK ] Reached target Login Prompts.
  OK ] Reached target Multi-User System.
     ] Reached target Graphical Interface.
        Starting Update UTMP about System Runlevel Chanc
  OK ] Started Update UTMP about System Runlevel Change
Debian GNU/Linux 8 debian-zyng ttyPS0
debian-zyng login:
```

#### Run example program

- 1. BOARD\$ git clone
   https://github.com/K16DIABLO/HSD\_LAB7.git
  - If that command does not work...
    - sudo apt-get update
- 2. BOARD\$ cd HSD\_LAB7/lab7
- 3. BOARD\$ make

```
FPGA(hex)
addr
      FPGA(hex)
addr
          *(3) << 1
```

Tutorial: Integrated Logic Analyzer (ILA)

#### ILA - Mark nets to debug





5. Mark Debug design\_1\_i/myip\_0/inst/myip\_v1\_0\_S00\_AXI\_inst/Nets/bram\_state (2)

6. Mark Debug design\_1\_i/myip\_0/Nets/m00\_bram\_rddata (31)

# ILA - Set up debugger(1)











# ILA - Set up debugger(2)





### Preparing the Board

- 1. Set configuration mode pins to **01100** (SD boot mode).
- 2. Insert USB-JTAG cable at J14 & J17.
- Insert power cable at J20.then turn the power on with SW8.LD13 lights up when it is on
- 4. Insert SD card, with **your own bitstream** in it.

CAVEAT: J14 pin is very fragile!
 If you cannot pull out a USB-JTAG cable from J14, press hooks with something pointed (sharp pencil, etc.).



Figure 20 - ZedBoard Jumper Map

#### ILA - Debug





Practice: Report

#### Practice

- Submit a 1-page report with brief explanation of the following:
  - HW IP: Behavior of the shifter IP based on design sources
    - myip\_v1\_0.v
    - myip\_v1\_S00\_AXI.v
  - HW System: Composition of the block design of Lab 7
  - SW: Role of each partition of the SD card and program codes.
    - 1st partition (1.1GB partition)
    - 2nd partition (15GB partition)
    - main.c
    - Makefile

### Grading policy

- Check lists
  - Shifter IP runs (30 points)
  - Waveform of marked variables is displayed (30 points)
  - Finished tutorial in class (10 points)
  - Report (30 points)
- Submit "L7.pdf" only on eTL
  - Due: 4/24 (Tue) PM 11:59
- Show that your board works
  - In class / office hour (Tue) recommended
  - If you cannot come to the office hour, take a screen shot of your working version and mail us.