## The design purpose

### At Posedge

Both the Master and the slave take shifting operation which the Master writes data to the MOSI and the Slave Writes data to the MISO.

#### AT negedge

Both the Master and the Slave make sampling operation which the Master reads data From the MISO and The Slave reads data from the MOSI

After each CLK the Master chose The Slave Again with CS with Enable One Slave and Disable the Other

At Test Bench of the Master is to Send and Receive data from many Slaves at Same Time This Is Mainly Testing the ability Of the Exchange Between the Master and Many Slaves.

At Test Bench of The Slave Is to Receive Data from Master and makes shift Operation and Resend Shifted Data.

It wait the signal of start to begin the transmission (also the master will read "masterDataToSend" in order to send it to the slave).

And it takes 8 periods to send all data from the master to slave and slave to master.

We make it with 2 test cases different.

#### **The Simulation Results**

# The development testbench

```
# Running test set
# From Slave 0 to Master: Success
# From Master to Slave 0: Success
# From Slave 1 to Master: Success
# From Master to Slave 1: Success
# From Slave 2 to Master: Success
# From Master to Slave 2: Success
# Running test set
# From Slave 0 to Master: Success
# From Master to Slave 0: Success
# From Slave 1 to Master: Success
# From Master to Slave 1: Success
# From Slave 2 to Master: Success
# From Master to Slave 2: Success
# SUCCESS: All
                       12 testcases have been successful
```



#### **Testbench Master**

```
# From Slave to Master : Success (Expected: 11011010, Received: 11011010)
# From Master to Slave : Success (Expected: 01010111, Received: 01010111)
```



#### **Testbench slave**

```
# slaveDataReceived =01101110 ,Excpectedslave =01101110 , success=
                                                                             0
# slaveDataReceived =10110111 ,Excpectedslave =10110111 , success=
                                                                             1
# slaveDataReceived =01011011 ,Excpectedslave =01011011 , success=
                                                                             2
# slaveDataReceived =10101101 ,Excpectedslave =10101101 , success=
                                                                             3
# slaveDataReceived =01010110 ,Excpectedslave =01010110 , success=
                                                                             4
VSIM 20> run
# slaveDataReceived =10101011 ,Excpectedslave =10101011 , success=
                                                                             5
# slaveDataReceived =01010101 , Excpectedslave =01010101 , success=
                                                                             6
# slaveDataReceived =10101010 ,Excpectedslave =10101010 , success=
                                                                             7
# slaveDataReceived =01010101 ,Excpectedslave =01010101 , success=
                                                                             8
# All Translation is Done Successfully
```

