



# HAPS Training for HW team

Yuan Chen  
Sep-2023

# CONFIDENTIAL INFORMATION

The information contained in this presentation is the confidential and proprietary information of Synopsys. You are not permitted to disseminate or use any of the information provided to you in this presentation outside of Synopsys without prior written authorization.

## IMPORTANT NOTICE

In the event information in this presentation reflects Synopsys' future plans, such plans are as of the date of this presentation and are subject to change. Synopsys is not obligated to update this presentation or develop the products with the features and functionality discussed in this presentation. Additionally, Synopsys' services and products may only be offered and purchased pursuant to an authorized quote and purchase order or a mutually agreed upon written contract with Synopsys.

# HAPS Portfolio to Serve All Markets

## HAPS-100 12F



High-Capacity Density  
Easier Setup for big designs

**Integrated  
prototyping solution**

## HAPS-100 4F



Adopted by Market Leaders

**Advancing  
prototyping leadership**

## HAPS-100 1F



*High Performance  
Single FPGA*

**Accelerating IP  
Validation**

# HAPS-100 Architecture Summary



# Hardware - Three views

Front



Back



# HAPS100 Deployment

Work as Desktop or a Prototyping Farm easily



桌面摆放



机柜安装



机柜安装 HAPS-100 12F

# HAPS-100 Backdoor Methodology

## Serving for Speeding up SW Debugging and Testing

# HAPS Xactors

- Protocols(Master or Slave):
  - AXI4, AXI4-lite, AXI3, AHB, APB
- General Purpose (Master or Slave):
  - GPIO, INT (inject Interrupts), Stream(inject streaming)
- Controlled by Tcl or C++ language, with related APIs



# HAPS Xactors Application as Back Door Image Loading

## ➤ SNPS Xactor

- AXI4\_Master (AXI access)
- GPIO(general control to i.e rst)

## ➤ Xilinx IP

- axi interconnect(small bridge, two master to one slave)

```

1 set fileName kernel_big.bin
2 set emu 8
3 set loadaddr 0x00000000
4 set burst 512
5 set word 8
6 set bus 1
7 set capim_axi 2
8 set capim_gpio 3
9
10
11 package require xactors
12
13 set taxi [ ta open master $emu $bus $capim_axi axi_master 256 32 ]
14 set gpio [ ta_open_gpio $emu $bus $capim_gpio gpio ]
15
16
17 puts "Assert DUT nreset, GPIO OUT(0)=0"
18 ta_set_output $gpio 0
19
20 puts "Loading $fileName to $loadaddr"
21
22 set count [expr ($burst*$word)]
23
24 set f [open $fileName r]
25 configure $f -translation binary -encoding binary -buffering full
26
27 set systemTime0 [clock seconds]
28 puts "start time..... [clock format $systemTime0 -format %D:%H:%M:%S]"
29 puts "loading image to memory....."
30 while { 1 } {
31
32     set addr [tell $f]
33     set buffer [read $f $count]
34
35     binary scan $buffer cu* data
36
37     ta_write_staxi $loadaddr $data
38
39     set loadaddr [expr ($loadaddr+$count) ]
40
41     if {[eof $f]} {
42         close $f
43         break
44     }
45
46 }
47
48 set systemTime1 [clock seconds]
49 puts "end time..... [clock format $systemTime1 -format %D:%H:%M:%S]"
50 puts "Deassert DUT nreset, GPIO OUT(0)=1"
51 ta_set_output $gpio 1
52

```

UMRBus over USB/PCIe



Related logic should keep in reset before backdoor loading completed

# ROM/RAM Backdoor Access

Changing ROM/RAM content on-line, without re-run the flow

- **Goal**
  - To support of ROM initialization at runtime on HAPS100
- **Challenge**
  - Emulation use-case, no existing support
- **Solution**
  - User preserves/ marks the ROM instance with directive/ attribute
  - Tool converts the ROM into a RAM with an additional write port with DF muxes which is controlled through the UMR3 CAPIM at runtime
- **Benefit**
  - Help user avoid multiple iteration of bit file generation for different ROM images

## Usage :-

- Preserve the ROM:
  - `define_directive {i:work.ROM[511:0]} {syn_preserve} {1}`
- Attribute to enable ROM backdoor logic implementation
  - `define_attribute {i:ROM[511:0]} {syn_allow_dynamic_init} {1}`
- Apply dynamic force muxes on ROM read ports
  - `(* haps_force *) $dumpvars (1, <net>);`
- Runtime: ROM backdoor related DF force muxes are reported in runtime.mp file within individual FPGA runtime directory



# Interconnection, Cables/Cards installation

## Setup for big systems

# HAPS HW Handling

Do Not Support accessories Hot-Plug when power-on

- The first Important thing --- **ESD**
  - Follow the HAPS Hardware Installation Request
- Video Guides for Cables and Daughter Cards installation
  - Installation
  - Depopulate



- 官方子卡的HT3数最多为3，超过3个HT3的自制子卡插拔比较困难，不建议

# Example of HT3 Daughter boards



# HT3 Cables and Connectors

- HAPS-100 4F HT3 Connector
  - Each HT3 connector will have dedicated multi-colored LED
  - Few scenarios of LED Color:
    - Green: No error / VCCO applied
    - Red: Error / VCCO error
    - Off: No VCCO applied
- New HT3 Cable with Shroud
  - Backward compatible with HAPS-80 S104 HT3 connectors
  - Shroud for improved connecting of HT3 cable and connector



# Cascading from Single HW to multiple HW



- Clock distribution
- HT3 connection
- Host connection

# Clock Structure

HAPS-100 4F has the same clock architecture concept as the previous HAPS system, but with more local PLL sources and all the clock connectors are equivalent. Each FPGA independently chooses 18 of 48 possible clocks.



# Example: Sharing clocks over 5 modules (20 FPGAs)

6x Global clocks across 5x HAPS-100



12x Global clocks across 5x HAPS-100



Clock Cable: 6x clock per cable

# CLK HUB – Distributes Clocks crossing systems

CLK\_HUB\_HC2



Front Panel



“Copy one CLK\_IN to its 8x CLK\_OUTS”

CLK\_QHUB\_HC2



Front Panel



Back Panel



A small/lite one, ¼ of the Full HUB

# Examples of HUB



6 clocks distributed over 8 modules



12 clocks distributed over 8 modules



# Host Interface

## *USB 3.0 and QSFP*

Three host connectors per HAPS-100 4F module

- 1x USB 3.0
- 2x QSFP



# HAPS-100 Speed-grade

- HAPS-100 4F has both speed-grade -1 and speed-grade -2 variants
- Performance of speed-grade -2 is faster than speed-grade -1 in
  - Clocks(F-max) and internal logics etc.
  - Interfaces, IO, Serdes etc.

# Fmax

- speed-grade -2 is ~16% fast than speed-grade -1
  - From below table, F-max improvement:  $775/667 \approx 116\%$
  - Page.38 of Xilinx DS923 document

## Clock Buffers and Networks

Table 37: Clock Buffers Switching Characteristics

| Symbol                                                                                       | Description                                                                                                | Speed Grade and V <sub>CCINT</sub> Operating Voltages |       |       | Units   |
|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------|-------|---------|
|                                                                                              |                                                                                                            | 0.90V                                                 | 0.85V | 0.72V |         |
|                                                                                              |                                                                                                            | -3                                                    | -2    | -1    |         |
| <b>Global Clock Switching Characteristics (Including BUFGCTRL)</b>                           |                                                                                                            |                                                       |       |       |         |
| F <sub>MAX</sub>                                                                             | Maximum frequency of a global clock tree (BUFG)                                                            | 891                                                   | 775   | 667   | 725 MHz |
| <b>Global Clock Buffer with Input Divide Capability (BUFGCE_DIV)</b>                         |                                                                                                            |                                                       |       |       |         |
| F <sub>MAX</sub>                                                                             | Maximum frequency of a global clock buffer with input divide capability (BUFGCE_DIV)                       | 891                                                   | 775   | 667   | 725 MHz |
| <b>Global Clock Buffer with Clock Enable (BUFGCE)</b>                                        |                                                                                                            |                                                       |       |       |         |
| F <sub>MAX</sub>                                                                             | Maximum frequency of a global clock buffer with clock enable (BUFGCE)                                      | 891                                                   | 775   | 667   | 725 MHz |
| <b>Leaf Clock Buffer with Clock Enable (BUFCE_LEAF)</b>                                      |                                                                                                            |                                                       |       |       |         |
| F <sub>MAX</sub>                                                                             | Maximum frequency of a leaf clock buffer with clock enable (BUFCE_LEAF)                                    | 891                                                   | 775   | 667   | 725 MHz |
| <b>GTY or GTM Clock Buffer with Clock Enable and Clock Input Divide Capability (BUFG_GT)</b> |                                                                                                            |                                                       |       |       |         |
| F <sub>MAX</sub>                                                                             | Maximum frequency of a serial transceiver clock buffer with clock enable and clock input divide capability | 512                                                   | 512   | 512   | 512 MHz |

# GTY – MGB2

- FPGA GTYs are connected to HAPS-100's MGB2 I/F
- speed-grade -2 is ~19% fast than speed-grade -1 in GTY
  - HAPS-100 speed-grade -1 support up to 21Gbps @MGB2
  - HAPS-100 speed-grade -2 support up to 25Gbps @MGB2



# Power up/down

- PSU Power On/Off button controls 12V output
- Push the Power On/Off button of PSU will directly power up the HAPS



Back

Front



# Example of Chained PSU

- PSU can be chained for multiple HAPS cascading
- Only push button of the Master PSU, then all HAPS are powered up





# HAPS Training for SW team

# HAPS-100 High Value Use Cases

Enabling Pre-Silicon Validation using Prototyping

## *Software Debug*



**HAPS-100**



Daughtercard

*System validation with Real-World IO*



*Software Debug with Hybrid Prototyping*

*Software-driven Power Validation*



Speed Adaptor



*System validation with Speed Adaptors*

# Use Case

- First Generation Project
- ASIC Design Size: Single Die ~2.5B gates, 4 Dies in 2 socket totally
- Design Size on HAPS
  - Single Die validation, 4 CPU core, full network, ~850M gates on 6x HAPS-100, 24 FPGAs
  - Dual Die validation, 16 CPU core, trimmed network, ~800M gates on 6x HAPS-100, 24 FPGAs
- Performance on HAPS
  - CPU clock: 30+Mhz
  - CMN clock: 12+Mhz
- OS boot-up time on HAPS
  - **~4 Minutes**



# IPK PHY card

HT3接口直接连接到HAPS上



# Bitfile Download, Confprosh

# Host Interface

## *USB 3.0 and QSFP*

Three host connectors per HAPS-100 4F module

- 1x USB 3.0
- 2x QSFP



# Confprosh

- For HAPS-100, Confpro GUI is not supported
- You can manage & configure HAPS-100 HW by Confpro shell and download script

# Scan HW

- Connect USB cable of HAPS-100 to Lab PC
- Power on the HAPS-100
- As long as the umrbus3 driver is installed successfully, you can scan HAPS HW from confpro shell
- Entering shell mode by “confprosh”
- Use “cfg\_scan” to scan the HAPS HW connected to the Lab PC

```
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ which confprosh
/local/apps/protocomp/R-2020.12-SP1-1/bin/confprosh
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ confprosh
confprosh Version R-2020.12-SP1-1 64Bit (Fri Apr 1 09:05:35 2022)
Copyright (c) 2008 - 2022 Synopsys, Inc.
This software and the associated documentation are proprietary to Synopsys, Inc.
This software may only be used in accordance with the terms and conditions of a written license agreement with Synopsys, Inc.
All other use, reproduction, or distribution of this software is strictly prohibited.

>cfg_scan
{DEVICE emu:8 TYPE HAPS80D FPGAS 2 SERIAL {H[REDACTED]} STATE available PORT {}} {DEVICE emu:9 TYPE HAPS80 FPGAS 4 SERIAL {H[REDACTED]} STATE available PORT {}} {DEVICE /umr3usb0/mod-E[REDACTED] TYPE HAPS100_4F_1 FPGAS 4 SERIAL {E[REDACTED]} STATE available PORT USB} {DEVICE /umr3usb1/mod-E[REDACTED] TYPE HAPS100_4F_2 FPGAS 4 SERIAL {E[REDACTED]} STATE available PORT USB}
>
```

# Fill the HW Serial Number to the Download script and HMF

- Fill in the SN of HAPS you want to use in “config\_haps100.tcl” and “hmf.txt”

```
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ ll
total 16
-rw-rw-r--. 1 yuanc yuanc 3002 Jul 22 09:53 config_haps100.tcl
drwxrwxrwx. 2 yuanc yuanc 67 Mar 2 20:57 FB1 uA
-rw-rw-r--. 1 yuanc yuanc 60 Jul 22 09:53 hmf.txt
-rw-rw-r--. 1 yuanc yuanc 16 Mar 2 20:59 istdout.log
drwxrwxrwx. 4 yuanc yuanc 108 Jul 6 12:05 system
-rw-rw-r--. 1 yuanc yuanc 340 Mar 2 20:57 targetsystem.dcf
drwxr-xr-x. 2 yuanc yuanc 174 Jul 6 12:34 test_script
```

The screenshot shows a dual-pane code editor interface. The left pane displays the contents of the file `config_haps100.tcl`, which contains a series of Tcl commands for initializing a HAPS equipment. The right pane displays the contents of the file `hmf.txt`, which is a JSON configuration file for the target system. Both files have specific lines highlighted with yellow boxes and red outlines.

**config\_haps100.tcl:**

```
1 package require proto_rt
2 set CFG_PRJ_NAME system/targetsystem.tsd
3 #define HAPS equipment
4 set HAPS_EQ /umr3usb0/mod-E0[REDACTED]
5 puts "Scanning HW attached"
6 puts "=====
7 puts [cfg_scan]
8 puts "Starting to connect HAPS HW"
9 puts "=====
10 puts "getting Handler"
11 #method 1, directly open handler
12 puts "Select HAPS $HAPS_EQ"
13 puts [cfg_open $HAPS_EQ]
14 #method 2, open handler according to HMF file(HMF file can imply HAPS level or FPGA level
    el)
```

**hmf.txt:**

```
1 {
2     "tsdmaphaps": {
3         "FB1": {"serial": "E01[REDACTED]"}
4     }
5 }
```

The bottom status bar indicates the current file is `config_haps100.tcl` and the tab bar shows `hmf.txt` is also open.

# Download with Confpro Shell and Tcl

- Check you have .bit&.cfg under FB1\_uA(for multi-FPGA, FB1\_uB/C/D .... FB2....FB3.....)
- Check you have “targetsyste.ts” under “system”
- Then “confprosh configxxxxx.tcl”

```
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ confprosh config_haps100.tcl
Scanning HW attached
=====
{DEVICE emu:8 TYPE HAPS80D FPGAS 2 SERIAL {H█████████} STATE available PORT
T {}} {DEVICE /umr3usb0/mod-E█████ TYPE HAPS100_4F_1 FPGAS 4 SERIAL {E0:
_4F 2 FPGAS 4 SERIAL {E█████} STATE available PORT USB}
Starting to connect HAPS HW
=====
getting Handler
Select HAPS /umr3usb1/mod-E█████
cfg0
Firmware Version is:
1.0
Clear previous FPGA images
=====
System Serial Number is:
E0████████
=====
FPGA Board name is: FB1
FPGA Board TYPE is: HAPS100_4F
FPGA User Name is: FB1.uA FB1.uB FB1.uC FB1.uD

Starting to Configure HAPS with project -> system/targetsystem.ts
```

```
FB1.uA cfg Done!
FB1.uB NOT configured!
FB1.uC NOT configured!
FB1.uD NOT configured!
Close Handler.....
Start HSTDMD Training.....
Processing HMF file...
Run HSTDMD training.
HSTDMD training started with timeout of 360 seconds.
HSTDMD training will finish by Fri Jul 22 11:04:03 CST 2022.
@W| No FPGAs support HAPS-controlled training
HSTDMD training has done.

HSTDMD Training Done.....
getting Handler.....
cfg0

release reset.....
```

```
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ tree FB1_uA/
FB1_uA/
└── FB1_uA4runtime.db
    ├── FB1_uA.bit
    └── FB1_uA.cfg

0 directories, 3 files
[yuanc@rhas178 bitfile_ddr4_xactor_regen]$ ll system/targetsystem.ts
-rw-rw-r-- 1 yuanc yuanc 800 Mar 2 20:57 system/targetsystem.ts
```

# Communicate with Xactor as before

# Example of access Tcl

```
1 package require xactors
2 set apb_master [ta_open master 300 1 1 apb_master 32 32]
3
4 #master issues a read sequence, i.e want 16 byte read out
5 puts [ta_read $apb_master 0x0000 16]
6
7 #master issues write sequence, 32-bit write
8 ta_write $apb_master 0x0004 {0x11 0x22 0x33 0x44}
9 puts [ta_read $apb_master 0x0004 4]
10 ta_close $apb_master
```

You also can use other Tcl command (like loop, if-else, string processing etc.) to build a fancy script

```
1 package require xactors
2 set int_master [ta_open int_master 300 1 2 int_master 512]
3
4 #set the output
5 ta_set_output $int_master {0x55 0xaa 0xbb 0xcc}
6 #check the output
7 puts [ta_get_output $int_master]
8
9 #get the input port
10 puts [ta_get_input $int_master]
11
12 ta_close $int_master
```

# Maximizing HAPS ROI Through Resource Management

HAPS Gateway enables access from web browser and python scripts

- **HAPS Lab Engineers**

- Ease hardware bring-up via interactive setup validation

- **HAPS Prototypers**

- Reduce support by delivering fully packaged prototypes

- **HAPS End Users**

- Use prototypes fully scripted or from convenience of a web browser

- **Infrastructure Managers**

- Plugs into IT (Jenkins, GitLab, LDAP, Database Server, Certificates)

- **Decision Makers**

- Report utilization for investment planning



# Normal Mode Setup



Figure 64 – Simple Normal Mode Setup

# HAPS configure through TSD

The screenshot shows the Synopsys System Configuration (A6) interface. The top navigation bar includes a logo, the title "A6", and tabs for Home - A6 - System Configuration (A6), Modules, FPGAs, Global Clock Nets, Clock Generators, HT3 Connectors, MGBs, System Structure, Check System, and a right-pointing arrow. The "Modules" tab is currently selected. Below the tabs is a table with the following data:

| Title           | Description                                                           | Flags | TSD File Selection | Action                     | Status         | Info |
|-----------------|-----------------------------------------------------------------------|-------|--------------------|----------------------------|----------------|------|
| Configure       | Select Target System Definition (TSD) file and configure              | ...   |                    | <button>Configure</button> | Not configured |      |
| IP Train        | Train Synopsys IP with Hardware Mapping File (HMF)                    |       |                    | <button>Train</button>     | N/A            |      |
| IP Train Report | Generate Synopsys IP training report with Hardware Mapping File (HMF) |       |                    | <button>Report</button>    |                |      |

At the bottom left, there is a "Filter" button.

*Fiaure 16 – Device confiauration with "taraetsvstem.tsdf"*

# Lab PC License configuration

# Lab PC license configuration



# Lab PC License configuration

- License is needed when
  - Using protocompiler100\_runtime for:
    - Debug with probe, need to watch internal node waveform
    - Utility test(selftest, cable checking, HW checking)
  - Using HAPS-100 Xactors
- For Linux
  - setenv SNPSLMD\_LICENSE\_FILE 27020@serverxxxx:27020@serverxxxx
- For Windows
  - This PC -> Properties -> Advanced System Setting -> Environment Variables -> New



# Bitfile downloads(clock,reset, hstdm Training)

# Bitfiles downloads

## Configuration tcl and TSD file

- Clock, reset, bitfiles, hstdm training are managed by TSD file(automatically generated by protocompiler flow)
- TSD file example ->

```
1 board_haps_target HAPS-100 -readback 1 -dpi 0 -clockgen 0
2 board_system_create -haps -name HAPS100_system -tsd
3 board_system_create -add HAPS100_4F -name FB1 -speed_grade -1-e
4 board_system_create -interconnect -manual CON_CABLE_100_HT3 -name con_c0 -connector { FB1.A4 FB1.B19}
5 board_system_create -interconnect -manual CON_CABLE_100_HT3 -name con_c1 -connector { FB1.A5 FB1.B20}
6 board_system_create -interconnect -manual CON_CABLE_100_HT3 -name con_c2 -connector { FB1.A6 FB1.B21}
7 board_system_create -interconnect -manual CON_CABLE_100_HT3 -name con_c3 -connector { FB1.A10 FB1.B22}
8 board_system_create -interconnect -manual DDR4_HT3 -name ddr4 -connector { FB1.A9 FB1.A8 FB1.A7}
9 board_system_configure -top_io { FB1.A1}
10 board_system_configure -top_io { FB1.B1}
11 board_system_configure -clk_src {FB1.PLL1.CLK1} -frequency 15000 -name mygclk1
12 board_system_configure -clk_src {FB1.PLL1.CLK2} -frequency 15000 -name mygclk2
13 board_system_configure -clock FB1.UA.CLK1 mygclk1
14 board_system_configure -clock FB1.UB.CLK1 mygclk1
15 board_system_configure -clock FB1.UA.CLK2 mygclk2
16 board_system_configure -clock FB1.UB.CLK2 mygclk2
17 board_system_configure -voltage FB1.A1 1.80
18 board_system_configure -voltage FB1.A4 1.20
19 board_system_configure -voltage FB1.A5 1.20
20 board_system_configure -voltage FB1.A6 1.20
21 board_system_configure -voltage FB1.A7 1.20
22 board_system_configure -voltage FB1.A8 1.20
23 board_system_configure -voltage FB1.A9 1.20
24 board_system_configure -voltage FB1.A10 1.20
25 board_system_configure -voltage FB1.B1 1.80
26 board_system_configure -voltage FB1.B19 1.20
27 board_system_configure -voltage FB1.B20 1.20
28 board_system_configure -voltage FB1.B21 1.20
29 board_system_configure -voltage FB1.B22 1.20
30 board_system_configure -fpga_id FB1.uA {0xDAC9}
31 board_system_configure -fpga_file FB1.uA {.../FB1_uA/FB1_uA.bit}
32 board_system_configure -fpga_id FB1.uB {0xEAAA}
33 board_system_configure -fpga_file FB1.uB {.../FB1_uB/FB1_uB.bit}
```

# HAPS Debug Methodology

# Overview: HAPS Debug Methods



# Triggering Techniques for debug

- Advanced trigger options available
  - Complex-Counter Triggering – Allows various counter based trigger option
  - State-Machine Triggering – Allows user to construct complex conditional trigger options
  - Pre-Armed Trigger – Enables debugging issues during startup/initialization by enabling trigger configuration without a debugger



# HAPS Protocompiler Debug Flow



# Remote Access basic operation

# Remote Access basic

- Remote access

- Linux VNC
  - Windows- remote desktop

- Jobs to do

- Downloading
  - Backdoor access
  - Issue Reset
  - Waveform viewing??



# 基础问题排查方法

# Bring-up

- 从小系统开始
- CPU系统+每个外围子系统调试
  - DDR5 --- Effort low
  - PCIe EP/RC
  - JTAG/UART/SPI...
  - **SATA I/F**
- 大系统 – Partition

# Right Thing, Right Time for Verification on HAPS

## Case Sharing



**SYNOPSYS®**

# Recommended sequence of HAPS100

## *Power off/Power cycle – PSU*

- |                                                 |                                                         |
|-------------------------------------------------|---------------------------------------------------------|
| 1. Open the handle for target HW setup          | 1. <i>set handle [cfg_open mod-E015287 mod-E012354]</i> |
| 2. Clear the HW configuration                   | 2. <i>cfg_project_clear \$handle -jobs 0</i>            |
| 3. Close the handle                             | 3. <i>cfg_close \$handle</i>                            |
| 4. Power off or Power cycle the mains as needed |                                                         |

Note: Most of the scenarios are covered without PSU mains power off

1. A project clear (*cfg\_project\_clear*)
2. Or soft power cycle (*cfg\_power\_set cfg0 cycle*)

# Multi-User Multi-Design Mode

## HAPS Multi-Design Mode (MDM)

- Small Design
  - Multi-design and Multi-User on one HAPS-100
- Subsystem
  - Multiple copies of the same design or different designs
- Configuration
  - Configure one without impact on others
  - FPGAs Allocated at load (run) time
- Debug
  - Debug in parallel



# Accelerating SW Dev and RTL Validation

Success Case: boots Linux in <1 minute



- 2x AXI4 master xactors and 1x INT\_slave xactor will be used
- All the DUT clocks come from HAPS
- Free Xilinx MIG DDR3 and Interconnection IPs are used

- **Easy Setup**
  - VDK with custom OS
  - Different IPs in HAPS
  - Smaller prototype
  - Faster prototype compile
- **Debug Productivity**
  - Boots OS in <1 minute
  - OS trace/profiling helps HW/SW debug and SW performance analysis
  - Full HW debug visibility for registers/pins