fe_cmov.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #include "fe.h"
  2. /*
  3. Replace (f,g) with (g,g) if b == 1;
  4. replace (f,g) with (f,g) if b == 0.
  5. Preconditions: b in {0,1}.
  6. */
  7. void fe_cmov(fe f,const fe g,unsigned int b)
  8. {
  9. crypto_int32 f0 = f[0];
  10. crypto_int32 f1 = f[1];
  11. crypto_int32 f2 = f[2];
  12. crypto_int32 f3 = f[3];
  13. crypto_int32 f4 = f[4];
  14. crypto_int32 f5 = f[5];
  15. crypto_int32 f6 = f[6];
  16. crypto_int32 f7 = f[7];
  17. crypto_int32 f8 = f[8];
  18. crypto_int32 f9 = f[9];
  19. crypto_int32 g0 = g[0];
  20. crypto_int32 g1 = g[1];
  21. crypto_int32 g2 = g[2];
  22. crypto_int32 g3 = g[3];
  23. crypto_int32 g4 = g[4];
  24. crypto_int32 g5 = g[5];
  25. crypto_int32 g6 = g[6];
  26. crypto_int32 g7 = g[7];
  27. crypto_int32 g8 = g[8];
  28. crypto_int32 g9 = g[9];
  29. crypto_int32 x0 = f0 ^ g0;
  30. crypto_int32 x1 = f1 ^ g1;
  31. crypto_int32 x2 = f2 ^ g2;
  32. crypto_int32 x3 = f3 ^ g3;
  33. crypto_int32 x4 = f4 ^ g4;
  34. crypto_int32 x5 = f5 ^ g5;
  35. crypto_int32 x6 = f6 ^ g6;
  36. crypto_int32 x7 = f7 ^ g7;
  37. crypto_int32 x8 = f8 ^ g8;
  38. crypto_int32 x9 = f9 ^ g9;
  39. b = -b;
  40. x0 &= b;
  41. x1 &= b;
  42. x2 &= b;
  43. x3 &= b;
  44. x4 &= b;
  45. x5 &= b;
  46. x6 &= b;
  47. x7 &= b;
  48. x8 &= b;
  49. x9 &= b;
  50. f[0] = f0 ^ x0;
  51. f[1] = f1 ^ x1;
  52. f[2] = f2 ^ x2;
  53. f[3] = f3 ^ x3;
  54. f[4] = f4 ^ x4;
  55. f[5] = f5 ^ x5;
  56. f[6] = f6 ^ x6;
  57. f[7] = f7 ^ x7;
  58. f[8] = f8 ^ x8;
  59. f[9] = f9 ^ x9;
  60. }