diff options
author | Jack Lloyd <[email protected]> | 2018-06-20 11:38:29 -0400 |
---|---|---|
committer | Jack Lloyd <[email protected]> | 2018-06-20 11:38:29 -0400 |
commit | ed1c39cee69f935fb03d76e888dffd0a8083d287 (patch) | |
tree | 28fa5dda18ffaa739ccc07305aac9806c7cf4ffd /src/lib/math | |
parent | 661173d1f8a70133ae2e5bfacefa9d4892aadd94 (diff) |
Avoid a small timing channel in Barrett reduction
No known exploit for this but no point taking chances.
Diffstat (limited to 'src/lib/math')
-rw-r--r-- | src/lib/math/numbertheory/reducer.cpp | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/src/lib/math/numbertheory/reducer.cpp b/src/lib/math/numbertheory/reducer.cpp index c739ea31a..de17af0e4 100644 --- a/src/lib/math/numbertheory/reducer.cpp +++ b/src/lib/math/numbertheory/reducer.cpp @@ -6,6 +6,7 @@ */ #include <botan/reducer.h> +#include <botan/internal/ct_utils.h> namespace Botan { @@ -56,16 +57,19 @@ BigInt Modular_Reducer::reduce(const BigInt& x) const t1.rev_sub(x.data(), std::min(x_sw, m_mod_words + 1), ws); - if(t1.is_negative()) - { - if(ws.size() < m_mod_words + 2) - ws.resize(m_mod_words + 2); - clear_mem(ws.data(), ws.size()); + /* + * If t1 < 0 then we must add b^(k+1) where b = 2^w. To avoid a + * side channel perform the addition unconditionally, with ws set + * to either b^(k+1) or else 0. + */ + const word t1_neg = t1.is_negative(); - ws[m_mod_words + 1] = 1; + if(ws.size() < m_mod_words + 2) + ws.resize(m_mod_words + 2); + clear_mem(ws.data(), ws.size()); + ws[m_mod_words + 1] = t1_neg; - t1.add(ws.data(), m_mod_words + 2, BigInt::Positive); - } + t1.add(ws.data(), m_mod_words + 2, BigInt::Positive); t1.reduce_below(m_modulus, ws); |