## **CAMELLIA SPECIFICATION**

# INTERFACE (portName\_(direction))

**KIN\_I:** The data input array [KIN\_I()] is used to pass a new key to the cipher.

KRDY I: The key ready input [KRDY I], when asserted, indicates that a new key is provided in KIN I.

**DIN\_I:** The data input array [DIN I()] is used to pass a word to the cipher.

**ENCDEC\_I:** The encdec input [ENCDEC\_I] indicates whether the current data in DIN\_I is to decrypt or to encrypt. The signal is negated to ENCRYPT, and is asserted to DECRYPT the input data.

**DRDY\_I:** The data ready input [DRDY\_I], when asserted, indicates the beginning of either a new encryption phase, or a new decryption phase.

**BSY\_O:** The busy output [BSY\_O()], when asserted, indicates that the cipher is either reading a new key, or it is (de)encoding a word.

**KVDL\_O:** The key read output [KVDL\_O], when asserted, indicates that the cipher read a key.

**DVLD\_O:** The data ready output [DVDL\_O], when asserted, indicates that new data is provided on [DOUT O]

**DOUT\_O:** The data output array [DOUT O] provides the output result generated by the cipher.

## Load a key

- CLOCK EDGE 0
  - o A key is provided on [KIN\_I]
  - o [KRDY\_I] is asserted
- CLOCK EDGE 1
  - o cipher asserts BSY\_O in response to asserted [KRDY\_I]
- CLOCK EDGE 7
  - o cipher negates BSY\_O
  - cipher asserts [KVDL\_O]

#### encode a word

- CLOCK EDGE 0
  - o A word is provided on [DIN I]
  - o [ENCDEC\_I] is negated
  - o [DRDY\_I] is asserted
- CLOCK EDGE 1
  - o cipher asserts BSY\_O in response to asserted [DRDY\_I]
- CLOCK EDGE 24
  - o cipher negates BSY\_O
  - o cipher asserts [DVDL\_O]
  - o cipher provides new data on [DOUT\_O]

#### decode a word

- CLOCK EDGE 0
  - A word is provided on [DIN\_I]
  - o [ENCDEC\_I] is asserted
  - o [DRDY\_I] is asserted
- CLOCK EDGE 1
  - o cipher asserts BSY\_O in response to asserted [DRDY\_I]
- CLOCK EDGE 24
  - o cipher negates BSY\_O
  - cipher asserts [DVDL\_O]
  - o cipher provides new data on [DOUT\_O]