Skip to content

Commit

Permalink
Fixed secret-dependent branch in poly_frommsg introduced by recent ve…
Browse files Browse the repository at this point in the history
…rsions of clang with some flags (Thanks to Antoon Purnal for pointing this out!)
  • Loading branch information
cryptojedi committed Jun 3, 2024
1 parent 11d00ff commit 0264efa
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 3 deletions.
6 changes: 3 additions & 3 deletions ref/poly.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
#include "reduce.h"
#include "cbd.h"
#include "symmetric.h"
#include "verify.h"

/*************************************************
* Name: poly_compress
Expand Down Expand Up @@ -167,16 +168,15 @@ void poly_frombytes(poly *r, const uint8_t a[KYBER_POLYBYTES])
void poly_frommsg(poly *r, const uint8_t msg[KYBER_INDCPA_MSGBYTES])
{
unsigned int i,j;
int16_t mask;

#if (KYBER_INDCPA_MSGBYTES != KYBER_N/8)
#error "KYBER_INDCPA_MSGBYTES must be equal to KYBER_N/8 bytes!"
#endif

for(i=0;i<KYBER_N/8;i++) {
for(j=0;j<8;j++) {
mask = -(int16_t)((msg[i] >> j)&1);
r->coeffs[8*i+j] = mask & ((KYBER_Q+1)/2);
r->coeffs[8*i+j] = 0;
cmov_int16(r->coeffs+8*i+j, ((KYBER_Q+1)/2), (msg[i] >> j)&1);
}
}
}
Expand Down
6 changes: 6 additions & 0 deletions ref/verify.c
Original file line number Diff line number Diff line change
Expand Up @@ -45,3 +45,9 @@ void cmov(uint8_t *r, const uint8_t *x, size_t len, uint8_t b)
for(i=0;i<len;i++)
r[i] ^= b & (r[i] ^ x[i]);
}

void cmov_int16(int16_t *r, int16_t v, uint16_t b)
{
b = -b;
*r ^= b & ((*r) ^ v);
}
3 changes: 3 additions & 0 deletions ref/verify.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,7 @@ int verify(const uint8_t *a, const uint8_t *b, size_t len);
#define cmov KYBER_NAMESPACE(cmov)
void cmov(uint8_t *r, const uint8_t *x, size_t len, uint8_t b);

#define cmov_int16 KYBER_NAMESPACE(cmov_int16)
void cmov_int16(int16_t *r, int16_t v, uint16_t b);

#endif

0 comments on commit 0264efa

Please sign in to comment.