## ECSE 323 — Group 47 Lab 4 Report Permutation

Jun Young Shin id. 260499663 Timothee Flichy id. 260557686

April 1, 2016

## 1 On-Chip Testing using the SignalTap II Logic Analyzer

During our on-chip testing of the enigma, when everything was well setup, the test output of the test bed when the reset key was pressed, we where only getting one portion of the entire cycle of the counter. The TA could not explain what was going on even though the VHDL code was working perfectly on the Altera board when we uploaded the code to it.

## 2 Permutation

The permutation is used to both encode and decode the input letter. To do so, we were given a table which depicts the character encryption list given in the figure 1. We were told to implement the first 4 rotor types. To make the permutation circuit, we need 2 input and 2 outputs. The inputs will receive a 2 bit rotor\_type and the second input is a 5-bit input\_code (letter) that must be encrypted. The outputs are a 5 bit output\_code which outputs the encrypted version of the input bits determined by the rotor position and the second input is the inv\_output\_code giving the inverted or decrypted 5 bit code. This is given by the figure 2. We tested out vhdl code on the ModelSim

| INPUT     | A | В | С | D | E | F | G | Н | Ι | J | K | L | M | N | O | P | Q | R | S | T | U | V | W | Х | Y | Z |
|-----------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Rotor I   | Ε | K | М | F | L | G | D | Q | V | Z | И | Т | 0 | W | Y | Η | X | U | S | P | Α | Ι | В | R | С | J |
| Rotor II  | Α | J | D | K | S | Ι | R | U | X | В | L | Η | W | Т | M | С | Q | G | Z | И | Ρ | Y | F | V | 0 | Ε |
| Rotor III | В | D | F | Η | J | L | С | Ρ | R | Т | Х | V | Z | И | Y | Ε | Ι | W | G | A | K | M | U | S | Q | 0 |
| Rotor IV  | Е | S | 0 | V | Ρ | Z | J | Α | Y | Q | U | Ι | R | Η | Х | L | И | F | Т | G | K | D | С | М | W | В |

Figure 1: Permutation graph.



Figure 2: Permutation symbol.

and got what we were expected to get from the permutation graph as you can see from the figures 3, 4, 5, 6, and 7.



Figure 3: Tested circuit on ModelSim



Figure 4: With rotor I.



Figure 5: With rotor II.



Figure 6: With rotor III.



Figure 7: With rotor IV.

## 3 fsm

For the Finite State Machine circuit (FSM), we built a circuit that performed the requirements mentioned on the lab sheet. The states are as following shown in the figure 8. To make this work, we wrote a FSM where we have 5



Figure 8: State Diagram.

inputs and 4 outputs as shown in the figure 9. Circuit goes as follows. The circuit checks for the INIT to go high.



Figure 9: FSM symbol.

When INIT is high, the LOAD will go high. After this, it waits for the KEYPRESS to go low (the Altera board is active high). Next it checks the KNOCK\_M and KNOCK\_R. When both KNOCK values are low, then only the EN\_R is set high. When only KNOCK\_M is high, the all EN is go high. When both KNOCK's are high, is will go to the state where all EN are high. After the states where EN are set, it will return to state 1 (where it waits) and start over again. At this point the INIT does not need to be checked. The figure 10 shows the circuit in a simulated environment. To the run the circuit,



Figure 10: FSM symbol.

we have found in the slow model that Fmax=75.04MHz, Setup slack to be 3.337 ns, and hold time of 0.445 ns. In the fast model, setup time is 7.848 ns and hold time to be 0.215 ns.