Encryption Key Storage

The Kintex UltraScale FPGA supports design security using AES decryption logic and provides two methods for encryption key memory storage.  The first is a volatile memory storage supported by an external battery backup supply voltage (VBATT).  The second is a one-time programmable eFUSE register.  The XEM8350 design supports both types of key storage with user-modification required for Vbatt support.

For quantity purchases of 50 or more units, please contact Opal Kelly ([email protected]) to discuss factory installation of these components.

Volatile Encryption Key Storage (Vbatt)

A small lithium rechargeable battery and several support components can be installed to provide VBATT to the FPGA when the XEM is unpowered.  This will preserve the contents of the FPGA’s volatile key storage so long as VBATT remains over the threshold specified in the Kintex UltraScale documentation.  Please see the Xilinx UltraScale Architecture Configuration User Guide (UG570) for more details.

The applicable schematic section and components required to support this functionality are shown below.

REFDESMANUFACTURERMANUFACTURER P/NCOMMENT
BT1Seiko InstrumentsMS412FE-FL26E3V, 1mAh lithium battery
C209, C210Generic1 μF, 10%, 10V, 0402
D9Micro CommercialBAS40-04-TPSchottky Diode, SOT23
R120Generic2.0 kΩ, 1%, 0402
R121Generic0 Ω, 0402Connects VBATT to DGND(Required only if battery/LDO circuit is not used)
U30Texas InstrumentsLDO, 150 mA, 1.8V output, SOT23-5

Non-Volatile Encryption Key Storage (eFUSE)

Non-volatile storage of the encryption key is also possible by programming the Kintex UltraScale eFUSE register via JTAG.  Please see the Xilinx UltraScale Architecture Configuration User Guide (UG570) for more details.