Cortex-M4 optimizations for {R,M} LWE schemes
DOI:
https://doi.org/10.13154/tches.v2020.i3.336-357Keywords:
ARM Cortex-M4, Post-quantum key encapsulation, lattice-based cryptography, RLWE, MLWE, NTT, Kyber, NewHope, NewHope-CompactAbstract
This paper proposes various optimizations for lattice-based key encapsulation mechanisms (KEM) using the Number Theoretic Transform (NTT) on the popular ARM Cortex-M4 microcontroller. Improvements come in the form of a faster code using more efficient modular reductions, optimized small-degree polynomial multiplications, and more aggressive layer merging in the NTT, but also in the form of reduced stack usage. We test our optimizations in software implementations of Kyber and NewHope, both round 2 candidates in the NIST post-quantum project, and also NewHope-Compact, a recently proposed variant of NewHope with smaller parameters. Our software is the first implementation of NewHope-Compact on the Cortex-M4 and shows speed improvements over previous high-speed implementations of Kyber and NewHope. Moreover, it gives a common framework to compare those schemes with the same level of optimization. Our results show that NewHope- Compact is the fastest scheme, followed by Kyber, and finally NewHope, which seems to suffer from its large modulus and error distribution for small dimensions.
Downloads
Published
Issue
Section
License
Copyright (c) 2020 Erdem Alkim, Yusuf Alper Bilgin, Murat Cenk, François Gérard
This work is licensed under a Creative Commons Attribution 4.0 International License.