

# **XTS3 Family of Cores**

IEEE P1619 XTS-AES Cores

## **General Description**

XTS3 implements the NIST standard AES cipher in the XTS mode for encryption and decryption with ciphertext stealing (CTS). The XTS3 family of cores covers a wide range of area / throughput combinations, allowing the designer to choose the smallest core that satisfies the desired clock/throughput requirements. Cores contain the base AES core AES1 and are available for immediate licensing.

The design is fully synchronous and available in both source and netlist form.

## **Symbol**



## **Key Features**

Small size: XTS3-18.2 starts at less than 30,000 ASIC gates and throughput of 18.2 bits per clock

Completely self-contained: does not require external memory

Support for XTS mode encryption and decryption. Encryption-only and decryption-only versions are available.

Includes key expansion and CTS support

128+128 and 256+256 bit AES keys supported.

Easily parallelizable for even higher data rates

Flow-through design

Test bench provided

# **Applications**

 Hard drive encryption compliant with the IEEE P1619



# **XTS3 Family of Cores**

IEEE P1619 XTS-AES Cores

# **Pin Description**

| Name      | Туре   | Description                                                                                                                                    |  |  |  |
|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| CLK       | Input  | Core clock signal                                                                                                                              |  |  |  |
| CEN       | Input  | Synchronous enable signal. When LOW the core ignores all its inputs and all its outputs must be ignored.                                       |  |  |  |
| RESET     | Input  | HIGH level asynchronously resets the core                                                                                                      |  |  |  |
| E/D       | Input  | When HIGH, core is encrypting, when LOW core is decrypting. This pin is not present on encryption only or decryption only versions of the core |  |  |  |
| K256      | Input  | When HIGH, core uses the 256-bit key. This pin is not present on 256-bit only version of the core                                              |  |  |  |
| START     | Input  | HIGH level starts the input data processing                                                                                                    |  |  |  |
| READ      | Output | Read request for the input data byte                                                                                                           |  |  |  |
| WRITE     | Output | Write signal for the output interface                                                                                                          |  |  |  |
| D[127:0]  | Input  | Input Data (other data bus widths are also available)  • plain or cipher text                                                                  |  |  |  |
| IV[127:0] | Input  | IV (logical position)                                                                                                                          |  |  |  |
| K1[255:0] | Input  | AES key                                                                                                                                        |  |  |  |
| K2[255:0] | Input  | Tweak key (K <sub>2</sub> )                                                                                                                    |  |  |  |
| Q[127:0]  | Output | Output plain or cipher text                                                                                                                    |  |  |  |
| newKey    | Input  | New AES Key available on K1 input                                                                                                              |  |  |  |
| newIV     | Input  | New Tweak Key available on K2 input, and new IV available on IV input                                                                          |  |  |  |
| cts       | Input  | Marks the last full 128-bit block of the data unit in case that the next block of this data unit is less than 128 bit (CTS mode)               |  |  |  |
| PBL[3:0]  | Input  | Partial Block length (in bytes)                                                                                                                |  |  |  |

#### **Function Description**

The Advanced Encryption Standard (AES) algorithm is a new NIST data encryption standard as defined in the <a href="http://csrc.nist.gov/publications/fips/fips-197/fips-197.pdf">http://csrc.nist.gov/publications/fips/fips-197/fips-197.pdf</a>.

The XTS3 implementation fully supports the AES algorithm for 128+128 and 256+256 bit keys XTS mode as defined by the P1619 draft standard.

The core is designed for flow-through operation, with 128-bit wide input and output interfaces. XTS3 supports both encryption and decryption modes.



# **XTS3 Family of Cores**

**IEEE P1619 XTS-AES Cores** 

## Implementation Results

### **Area Utilization and Performance**

Representative area/resources figures are shown below.

| Core Type | Technology     | Area / Resources | Max Frequency | Throughput |
|-----------|----------------|------------------|---------------|------------|
| XTS3-64   | TSMC 0.09 µ LV | 140,500 gates    | 215 MHz       | 13.7 Gbps  |
| XTS3-64E  | TSMC 0.09 µ LV | 105,000 gates    | 215 MHz       | 13.7 Gbps  |
| XTS3-64D  | TSMC 0.09 µ LV | 105,000 gates    | 215 MHz       | 13.7 Gbps  |

Multiple XTS3 cores can be easily paralleled for throughputs of 100 Gbps and higher.

## **Export Permits**

US Bureau of Industry and Security has assigned the export control classification number 5E002 to the AES1 core. The core is eligible for the license exception ENC under section 740.17(A) and (B)(1) of the export administration regulations. See the IP Cores, Inc. licensing basics page, <a href="http://ipcores.com/export\_licensing.htm">http://ipcores.com/export\_licensing.htm</a>, for links to US government sites and more details.

## **Deliverables**

#### **HDL Source Licenses**

- Synthesizable Verilog RTL source code
- · Verilog testbench (self-checking)
- Vectors for testbench
- · Expected results

www.ipcores.com

· User Documentation

### **Contact Information**

IP Cores, Inc. 3731 Middlefield Rd. Palo Alto, CA 94303, USA Phone: +1 (650) 814-0205 E-mail: info@ipcores.com

#### **Netlist Licenses**

- Post-synthesis EDIF
- Testbench (self-checking)
- · Vectors for testbench
- · Expected results