## **DUT Algorithm Development**

This document describes how to interface the DUT (Design Under Test) or victim to the DUT Wrapper. The DUT is the algorithm to be attacked or tested.

The DUT or victim algorithm is user provided. However, the DUT wrapper is included with FOBOS. The DUT Wrapper handels communication to the control board and includes FIFOs to store input data for the DUT along with output FIFO.



## **Data flow description:**

Test vectors are sent form PC one at a time to the control board which stores them breifly in a FIFO. The PC sends a command indicating test vector is complete. This will initiates the process of sending the data from the controller to the DUT through the interface shown in the figure above.

The DUT wrapper then puts data in the correct FIFOs (PDI, SDI and RDI).

Once the DUT wrapper receives the start command from the controller, it de-assersts the reset signal and the DUT will run and use the data in the FIFOs. The output of the DUT is stored in the DO fifo. Once the DO FIFO accumulates EXPECTED\_OUTPUT bytes, the DUT wrapper will send this data to the control board which forwards it to the PC.

## The DUT Wrapper – DUT interface

The protocol follows a simle AXI stream protocol. The DUT (victim) is instantiated as follows in the FOBOS\_DUT.vhd file

victim: entity work.victim(behav)

```
-- Choices for W and SW are independently any multiple of 4, defined in generics above
```

```
generic map (
               => W, -- pdi and do width (mulltiple of 4)
    \mathbf{G} \mathbf{W}
                => SW -- sdi width (multiple of 4)
    G SW
port map(
       rst => start, --! The FOBOS DUT start signal meets requirements for synchronous resets
used in
                  --! CAESAR HW Development Package AEAD
-- data signals
       pdi data => pdi data,
       pdi valid => pdi valid,
       pdi ready => pdi ready,
 sdi data => sdi data,
       sdi valid => sdi valid,
       sdi ready => sdi ready,
       do data => result data,
       do ready => result ready,
       do valid => result valid
----! if rdi interface for side-channel protected versions is required, uncomment the rdi interface
-- ,rdi data => rdi data,
-- rdi ready => rdi ready,
       rdi valid => rdi valid
);
```

The generic W is the PDI and DO width. The generic SW is the SDI width.

It is highly recommended that the DUT is tested using the sources/dut/fobos\_dut\_tb.vhd test bench and ensure that the result data in the do port is valid. This testbench needs one test vector to be stored in the file dinFile.txt (see \_testVectorGeneration in doc/QickStart) .