VIA PadLock explained

VIA PadLock is a central processing unit (CPU) instruction set extension to the x86 microprocessor instruction set architecture (ISA) found on processors produced by VIA Technologies and Zhaoxin. Introduced in 2003 with the VIA Centaur CPUs, the additional instructions provide hardware-accelerated random number generation (RNG), Advanced Encryption Standard (AES), SHA-1, SHA256, and Montgomery modular multiplication.[1] [2]

Instructions

The PadLock instruction set can be divided into four subsets:[1]

The padlock capability is indicated via a [[CPUID]] instruction with EAX = 0xC0000000. If the resultant EAX >= 0xC0000001, the CPU is aware of Centaur features. An additional request with EAX = 0xC0000001 then returns PadLock support in EDX. The padlock capability can be toggled on or off with MSR 0X1107.[1]

VIA PadLock found on some Zhaoxin CPUs have SM3 hashing and SM4 block cipher added.[3]

CPUs with PadLock

See also: List of VIA microprocessors.

Supporting software

See also

Notes and References

  1. Web site: August 4, 2005 . VIA PadLock Programming Guide . dead . https://web.archive.org/web/20100526054140/http://linux.via.com.tw/support/beginDownload.action?eleid=181&fid=261 . May 26, 2010.
  2. Web site: VIA PadLock - Wicked Fast Encryption . www.logix.cz.
  3. Web site: Kaixian ZX-C+ Series 4-core CPU . Shanghai Zhaoxin Semiconductor Co., Ltd..
  4. Web site: VIA PadLock support for Linux . www.logix.cz.
  5. Web site: openssl/engines/e_padlock.c . GitHub . 26 November 2022 . en.
  6. Web site: Added new instructions for next version of VIA PadLock core. · bminor/binutils-gdb@30d1c83 . GitHub . en.