| // Generated from Bedrock code in Fiat Cryptogrpahy. Avoid editing directly. |
| |
| static inline br_word_t br_full_add(br_word_t x, br_word_t y, br_word_t carry, br_word_t* _sum) { |
| br_word_t carry_out, sum; |
| x = x+carry; |
| carry_out = (br_word_t)(x<carry); |
| sum = x+y; |
| carry_out = carry_out+((br_word_t)(sum<y)); |
| *_sum = sum; |
| return carry_out; |
| } |
| |
| static inline br_word_t br_full_sub(br_word_t x, br_word_t y, br_word_t borrow, br_word_t* _diff) { |
| br_word_t out_borrow, diff; |
| out_borrow = (br_word_t)(x<y); |
| diff = x-y; |
| out_borrow = out_borrow+((br_word_t)(diff<borrow)); |
| diff = diff-borrow; |
| *_diff = diff; |
| return out_borrow; |
| } |
| |
| static inline br_word_t br_full_mul(br_word_t a, br_word_t b, br_word_t* _low) { |
| br_word_t high, hh, lh, hl, low, second_halfword_w_oflow, n, ll, M; |
| n = ((((0u-(br_word_t)1)>>27)&63)+1)>>1; |
| M = ((br_word_t)1<<(n&(sizeof(br_word_t)*8-1)))-1; |
| ll = (a&M)*(b&M); |
| lh = (a&M)*(b>>(n&(sizeof(br_word_t)*8-1))); |
| hl = (a>>(n&(sizeof(br_word_t)*8-1)))*(b&M); |
| hh = (a>>(n&(sizeof(br_word_t)*8-1)))*(b>>(n&(sizeof(br_word_t)*8-1))); |
| second_halfword_w_oflow = ((ll>>(n&(sizeof(br_word_t)*8-1)))+(lh&M))+(hl&M); |
| high = ((hh+(lh>>(n&(sizeof(br_word_t)*8-1))))+(hl>>(n&(sizeof(br_word_t)*8-1))))+(second_halfword_w_oflow>>(n&(sizeof(br_word_t)*8-1))); |
| low = (second_halfword_w_oflow<<(n&(sizeof(br_word_t)*8-1)))+(ll&M); |
| *_low = low; |
| return high; |
| } |
| |
| static inline br_word_t br_value_barrier(br_word_t a) { |
| /*skip*/ |
| return a; |
| } |
| |
| static inline br_word_t br_declassify(br_word_t a) { |
| /*skip*/ |
| return a; |
| } |
| |
| static inline br_word_t br_broadcast_negative(br_word_t x) { |
| br_word_t y; |
| y = (br_word_t)((br_signed_t)x>>((((0u-(br_word_t)1)>>27)&63)&(sizeof(br_word_t)*8-1))); |
| y = br_value_barrier(y); |
| return y; |
| } |
| |
| static inline br_word_t br_broadcast_nonzero(br_word_t x) { |
| br_word_t y; |
| y = br_broadcast_negative(x|(0u-x)); |
| return y; |
| } |
| |
| static inline br_word_t br_cmov(br_word_t c, br_word_t vnz, br_word_t vz) { |
| br_word_t r, m; |
| m = br_broadcast_nonzero(c); |
| r = (m&vnz)|((~m)&vz); |
| return r; |
| } |