

# Visual System Integrator for Amazon AWS F1



System View Inc announces the availability of their intuitive graphical programming environment "**Visual System Integrator**" for developing applications on AMAZON's AWS F1 clusters.

## Easily program the AWS F1 FPGAs using C/C++ code.

Use VSI's powerful Software Import Wizard to import existing C/C++ functions, drag and drop them to FPGA's or CPU, connect them to represent the application Data Flow; press "Generate System" and let VSI system compiler create the complete system for you.



VSI generated runtime & data transport hardware, work in unison to transport the data between blocks executing in CPU and FPGA and between FPGA and FPGA.

## System level Trace

| 000                                                                         |                     |                          |       |                          |       |                     |       |                |               | Visual System Integrator Trace |     |            |         |                        |        |               |                |                           |                   |  |  |  |
|-----------------------------------------------------------------------------|---------------------|--------------------------|-------|--------------------------|-------|---------------------|-------|----------------|---------------|--------------------------------|-----|------------|---------|------------------------|--------|---------------|----------------|---------------------------|-------------------|--|--|--|
| 10.12.4.251 55 👰                                                            |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           | b                 |  |  |  |
|                                                                             | 11,700,000,0        | 000 11,800,00            | 0,000 | 11,900,00                | 0,000 | 12,000,000          | 1,000 | 12,100,000     | 0,000         | 12,200,000                     | 000 | 12,300,000 | ,000    | 12,400,000,            | 000    | 12,500,000,00 | 0 12,600,000,0 | 12,700,000,000            | 12,800            |  |  |  |
| 0.⇒ vc709_gen_ip_0_arg_2_seq_i                                              |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| 1_tcp_server_1_0 → 1_gen_ip_1_0                                             |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| 709_axi_10g_ethernet_0_s_axis_tx                                            |                     | 0                        | 0     | 0                        | 0     | 0                   | 0     | 0              | 0             | 0                              | 0   | 0          | 0       | 0                      | 0      | 0             |                |                           |                   |  |  |  |
| :p_server_0 -> axi_10g_ethernet_0                                           |                     | 0                        | 0     | 0                        | 0     | 0                   | 0     | 0              | 0             | 0                              | 0   | 0          | 0       | 0                      | 0      | 0             |                |                           |                   |  |  |  |
| axis_data_fflo_0 -> gen_ip_0                                                |                     | 0                        | 0     | 0                        | 0     | 0                   | 0     | 0              | 0             | 0                              | 0   | 0          | 0       | 0                      | 0      | 0             |                |                           |                   |  |  |  |
| _arg_3_seq_o -> 1_tcp_server_0_0                                            |                     |                          | 0     | 0                        |       | 0                   |       | 0              |               | 0                              |     | 0          |         | 0                      |        | 0             |                |                           |                   |  |  |  |
| gen_ip_0 → tcp_server_0                                                     |                     |                          | 0     | 0                        |       | 0                   |       | 0              |               | 0                              |     | 0          |         | 0                      |        | 0             |                |                           |                   |  |  |  |
|                                                                             | 11700ms             | 11800ms<br>2,000,000,000 |       | 11900ms<br>4,000,000,000 |       | 12000ms<br>6,000.00 | 0,000 | 12100ms        | 8,000,000,000 | 12200ms                        | 10  | 12300ms    |         | 12400ms<br>12,000,000) | 100    | 12500ms       | 12600ms        | 12700ms<br>16.000.000.000 | 12800ms<br>18,000 |  |  |  |
| gen jo 1.0 > vc709.gen jo 0.em 2.em 1                                       |                     |                          |       |                          |       |                     |       |                |               | т                              |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| 1_top_server_1_0 → 1_gen_ip_1_0<br>r 0 0 → vc709 ad 10o ethemet 0 s axis tx |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| top_server_0 -> axi_10g_ethemet_0                                           |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| axis_data_tho_0 > gan_ip_0                                                  |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           |                   |  |  |  |
| gen jo 0 + to server 0                                                      |                     |                          |       |                          |       |                     |       |                |               |                                |     |            |         |                        |        |               |                |                           | _                 |  |  |  |
|                                                                             | 200ms 4000ms 6000ms |                          |       |                          |       |                     |       | 8000ms 10000ms |               |                                |     |            | 12000ms |                        | 14000m | 8             | 16000ms        | 18000ms                   |                   |  |  |  |

Use VSI's integrated system level *"trace"* application shows events across the entire system , both hardware and software , on a single timeline. With this capability the developer can quickly identify functional problems or performance bottle necks.

### Access FPGA resources directly from JAVA or python

VSI software import wizard, can import Java functions. Use *VsiDevice Class* to access memory (HMC) or control devices in the FPGA.



The complete JAVA framework is available to the developer, use any of the existing frameworks like Apache STORM, HIVE, PIG, SPARK etc. and process data in FPGA(s).

## Mix and Match

VSI's modular runtime environment allows developers to communicate between blocks developed in different languages. The developer can communicate with Blocks developed in RTL (Verilog, VHDL) from C, C++, Java or Python.

## More Details .....

VSI supports AWS instances <u>*f1.2xlarge*</u> (one FPGA system), and <u>*f1.16xlarge*</u> (eight FPGA system), allowing you to utilize the full potential of this powerful heterogonous compute platform.

The AWS F1 version of **Visual System Integrator** comes with the platform definition for both <u>*f1.2xlarge*</u> and <u>*f1.16xlarge*</u> instances. The platform

describes the PCI/e connection between the FPGA boards and the CPU, the High-Speed Serial (SERDES) connection between the FPGA boards and the HMC memory controllers present in the FPGAs.

The developer can place the compute *"block"* in any of the FPGAs, the VSI system generator will transport the data using the appropriate connection. The developer can read/write data into the HMC memory of any of the connected FPGAs from the CPU using C, C++, Java or python, then invoke a processing function in the FPGA, the processing function in FPGA can be developed in C, C++, Verilog or VHDL.

#### **Simulation Context**

The AWS "Debug" platform includes a simulator "**context**". The VSI compiler creates a RTL simulation project for the block placed in this context. The user can choose the simulator (XSIM or QUESTA). The VSI runtime will transfer data between the Simulator and the rest of the system.

For more information, please visit our website http://www.systemviewinc.com