## Group 2 & 3

# Final Project Intermediate Status Report





# System View





### Top Down

Falcon API -> Middleware -> Hardware Kernels





## Current Block Diagram



middleware on PL side to avoid overhead



## Brief Block Diagram







#### Current Schedule

Catapult HLS
Integration into FSIC
Synopsys flow
Caravel-FSIC FPGA simulation
Caravel-FSIC FPGA Validation













Undergoing



Done





## Status Report

在lab 5的報告當中提到說我們已完成vitis HLS到catapult HLS的轉換,得到baseline的 application accelerator,同時integrate進FSIC。同時我們在simulation以及validation階段均可以跑完一次任意一種演算法(FFT、iFFT、NTT、iNTT),且算出正確的值。而目前的進度是在 simulation階段我們可以成功地依序執行多個演算法,但尚未上板進行validation。而我們 interrupt使用lab\_fir進行測試可以在simulation階段以及validation使用。



#### Current Dilemma

#### Interrupt



In our design, we put our kernel in user project Caravel SoC. When kernel finishing the task, we change the status register. The change in status register will trigger the middleware in RISC-V CPU to write the mailbox, which change the mailbox in FPGA correspondingly. After mailbox is written, it generates interrupt to the PS side.

To achieve this implementation, we add an interrupt controller in our original design. The interrupt is level trigger since we tried edge trigger but couldn't get the interrupt. Also, We changed the design in our mailbox slightly. However, we can't have the result we expect to get.



# Status Report -To be tested

- 1. Verilog testbench只寫一次mailbox然後一直toggle aa\_mb\_irq\_en(0x2100)看是不是也會一直造成interrupt拉起來。
- 2. firmware讀kernel狀態要拉到uspj外面 不然會跟dma卡在一起。 同時我們在測試synopsys IC flow的synthesis階段所花費時間過長,可能是因為 design並沒有特別進行優化導致design可能過度複雜。



# Status Report -Future Work

我們的進度規畫會希望能結合interrupt進行上板validation,同時能夠優化我們的design,並且完成整個synopsys IC flow。