Revision 67515b4428ed32144def311fe9934faee4939757 authored by Konrad Kohbrok on 19 April 2018, 18:24:43 UTC, committed by Konrad Kohbrok on 19 April 2018, 18:24:43 UTC
1 parent b07c391
Raw File
AEAD_Poly1305_64.c
#include "AEAD_Poly1305_64.h"

inline static void Hacl_Bignum_Modulo_reduce(uint64_t *b)
{
  uint64_t b0 = b[0];
  b[0] = (b0 << (uint32_t )4) + (b0 << (uint32_t )2);
}

inline static void Hacl_Bignum_Modulo_carry_top(uint64_t *b)
{
  uint64_t b2 = b[2];
  uint64_t b0 = b[0];
  uint64_t b2_42 = b2 >> (uint32_t )42;
  b[2] = b2 & (uint64_t )0x3ffffffffff;
  b[0] = (b2_42 << (uint32_t )2) + b2_42 + b0;
}

inline static void Hacl_Bignum_Modulo_carry_top_wide(FStar_UInt128_uint128 *b)
{
  FStar_UInt128_uint128 b2 = b[2];
  FStar_UInt128_uint128 b0 = b[0];
  FStar_UInt128_uint128 b2_;
  FStar_UInt128_uint128 ret0;
  FStar_Int_Cast_Full_uint64_to_uint128((uint64_t )0x3ffffffffff, &ret0);
  FStar_UInt128_uint128 s1 = ret0;
  FStar_UInt128_logand(&b2, &s1, &b2_);
  FStar_UInt128_uint128 ret1;
  FStar_UInt128_shift_right(&b2, (uint32_t )42, &ret1);
  FStar_UInt128_uint128 s0 = ret1;
  uint64_t b2_42 = FStar_Int_Cast_Full_uint128_to_uint64(&s0);
  FStar_UInt128_uint128 b0_;
  FStar_UInt128_uint128 ret;
  FStar_Int_Cast_Full_uint64_to_uint128((b2_42 << (uint32_t )2) + b2_42, &ret);
  FStar_UInt128_uint128 s10 = ret;
  FStar_UInt128_add(&b0, &s10, &b0_);
  b[2] = b2_;
  b[0] = b0_;
}

inline static void
Hacl_Bignum_Fproduct_copy_from_wide_(uint64_t *output, FStar_UInt128_uint128 *input)
{
  {
    FStar_UInt128_uint128 uu____429 = input[0];
    uint64_t uu____428 = FStar_Int_Cast_Full_uint128_to_uint64(&uu____429);
    output[0] = uu____428;
  }
  {
    FStar_UInt128_uint128 uu____429 = input[1];
    uint64_t uu____428 = FStar_Int_Cast_Full_uint128_to_uint64(&uu____429);
    output[1] = uu____428;
  }
  {
    FStar_UInt128_uint128 uu____429 = input[2];
    uint64_t uu____428 = FStar_Int_Cast_Full_uint128_to_uint64(&uu____429);
    output[2] = uu____428;
  }
}

inline static void Hacl_Bignum_Fproduct_shift(uint64_t *output)
{
  uint64_t tmp = output[2];
  {
    uint32_t ctr = (uint32_t )3 - (uint32_t )0 - (uint32_t )1;
    uint64_t z = output[ctr - (uint32_t )1];
    output[ctr] = z;
  }
  {
    uint32_t ctr = (uint32_t )3 - (uint32_t )1 - (uint32_t )1;
    uint64_t z = output[ctr - (uint32_t )1];
    output[ctr] = z;
  }
  output[0] = tmp;
}

inline static void
Hacl_Bignum_Fproduct_sum_scalar_multiplication_(
  FStar_UInt128_uint128 *output,
  uint64_t *input,
  uint64_t s
)
{
  {
    FStar_UInt128_uint128 uu____871 = output[0];
    uint64_t uu____874 = input[0];
    FStar_UInt128_uint128 uu____870;
    FStar_UInt128_uint128 ret;
    FStar_UInt128_mul_wide(uu____874, s, &ret);
    FStar_UInt128_uint128 s1 = ret;
    FStar_UInt128_add_mod(&uu____871, &s1, &uu____870);
    output[0] = uu____870;
  }
  {
    FStar_UInt128_uint128 uu____871 = output[1];
    uint64_t uu____874 = input[1];
    FStar_UInt128_uint128 uu____870;
    FStar_UInt128_uint128 ret;
    FStar_UInt128_mul_wide(uu____874, s, &ret);
    FStar_UInt128_uint128 s1 = ret;
    FStar_UInt128_add_mod(&uu____871, &s1, &uu____870);
    output[1] = uu____870;
  }
  {
    FStar_UInt128_uint128 uu____871 = output[2];
    uint64_t uu____874 = input[2];
    FStar_UInt128_uint128 uu____870;
    FStar_UInt128_uint128 ret;
    FStar_UInt128_mul_wide(uu____874, s, &ret);
    FStar_UInt128_uint128 s1 = ret;
    FStar_UInt128_add_mod(&uu____871, &s1, &uu____870);
    output[2] = uu____870;
  }
}

inline static void Hacl_Bignum_Fproduct_carry_wide_(FStar_UInt128_uint128 *tmp)
{
  {
    uint32_t ctr = (uint32_t )0;
    FStar_UInt128_uint128 tctr = tmp[ctr];
    FStar_UInt128_uint128 tctrp1 = tmp[ctr + (uint32_t )1];
    uint64_t
    r0 =
      FStar_Int_Cast_Full_uint128_to_uint64(&tctr)
      & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
    FStar_UInt128_uint128 c;
    FStar_UInt128_shift_right(&tctr, (uint32_t )44, &c);
    FStar_Int_Cast_Full_uint64_to_uint128(r0, &tmp[ctr]);
    FStar_UInt128_add(&tctrp1, &c, &tmp[ctr + (uint32_t )1]);
  }
  {
    uint32_t ctr = (uint32_t )1;
    FStar_UInt128_uint128 tctr = tmp[ctr];
    FStar_UInt128_uint128 tctrp1 = tmp[ctr + (uint32_t )1];
    uint64_t
    r0 =
      FStar_Int_Cast_Full_uint128_to_uint64(&tctr)
      & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
    FStar_UInt128_uint128 c;
    FStar_UInt128_shift_right(&tctr, (uint32_t )44, &c);
    FStar_Int_Cast_Full_uint64_to_uint128(r0, &tmp[ctr]);
    FStar_UInt128_add(&tctrp1, &c, &tmp[ctr + (uint32_t )1]);
  }
}

inline static void Hacl_Bignum_Fproduct_carry_limb_(uint64_t *tmp)
{
  {
    uint32_t ctr = (uint32_t )0;
    uint64_t tctr = tmp[ctr];
    uint64_t tctrp1 = tmp[ctr + (uint32_t )1];
    uint64_t r0 = tctr & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
    uint64_t c = tctr >> (uint32_t )44;
    tmp[ctr] = r0;
    tmp[ctr + (uint32_t )1] = tctrp1 + c;
  }
  {
    uint32_t ctr = (uint32_t )1;
    uint64_t tctr = tmp[ctr];
    uint64_t tctrp1 = tmp[ctr + (uint32_t )1];
    uint64_t r0 = tctr & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
    uint64_t c = tctr >> (uint32_t )44;
    tmp[ctr] = r0;
    tmp[ctr + (uint32_t )1] = tctrp1 + c;
  }
}

inline static void Hacl_Bignum_Fmul_shift_reduce(uint64_t *output)
{
  Hacl_Bignum_Fproduct_shift(output);
  Hacl_Bignum_Modulo_reduce(output);
}

static void
Hacl_Bignum_Fmul_mul_shift_reduce_(
  FStar_UInt128_uint128 *output,
  uint64_t *input,
  uint64_t *input2
)
{
  {
    uint32_t ctr = (uint32_t )3 - (uint32_t )0 - (uint32_t )1;
    uint32_t i1 = ctr;
    uint32_t j = (uint32_t )2 - i1;
    uint64_t input2i = input2[j];
    Hacl_Bignum_Fproduct_sum_scalar_multiplication_(output, input, input2i);
    if (ctr > (uint32_t )0)
      Hacl_Bignum_Fmul_shift_reduce(input);
  }
  {
    uint32_t ctr = (uint32_t )3 - (uint32_t )1 - (uint32_t )1;
    uint32_t i1 = ctr;
    uint32_t j = (uint32_t )2 - i1;
    uint64_t input2i = input2[j];
    Hacl_Bignum_Fproduct_sum_scalar_multiplication_(output, input, input2i);
    if (ctr > (uint32_t )0)
      Hacl_Bignum_Fmul_shift_reduce(input);
  }
  {
    uint32_t ctr = (uint32_t )3 - (uint32_t )2 - (uint32_t )1;
    uint32_t i1 = ctr;
    uint32_t j = (uint32_t )2 - i1;
    uint64_t input2i = input2[j];
    Hacl_Bignum_Fproduct_sum_scalar_multiplication_(output, input, input2i);
    if (ctr > (uint32_t )0)
      Hacl_Bignum_Fmul_shift_reduce(input);
  }
}

inline static void Hacl_Bignum_Fmul_fmul_(uint64_t *output, uint64_t *input, uint64_t *input2)
{
  FStar_UInt128_uint128 ret;
  FStar_Int_Cast_Full_uint64_to_uint128((uint64_t )0, &ret);
  KRML_CHECK_SIZE(ret, (uint32_t )3);
  FStar_UInt128_uint128 t[3];
  for (uintmax_t _i = 0; _i < (uint32_t )3; ++_i)
    t[_i] = ret;
  Hacl_Bignum_Fmul_mul_shift_reduce_(t, input, input2);
  Hacl_Bignum_Fproduct_carry_wide_(t);
  Hacl_Bignum_Modulo_carry_top_wide(t);
  Hacl_Bignum_Fproduct_copy_from_wide_(output, t);
  uint64_t i0 = output[0];
  uint64_t i1 = output[1];
  uint64_t i0_ = i0 & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
  uint64_t i1_ = i1 + (i0 >> (uint32_t )44);
  output[0] = i0_;
  output[1] = i1_;
}

inline static void Hacl_Bignum_Fmul_fmul(uint64_t *output, uint64_t *input, uint64_t *input2)
{
  uint64_t tmp[3] = { 0 };
  memcpy(tmp, input, (uint32_t )3 * sizeof input[0]);
  Hacl_Bignum_Fmul_fmul_(output, tmp, input2);
}

inline static void
Hacl_Bignum_AddAndMultiply_add_and_multiply(uint64_t *acc, uint64_t *block, uint64_t *r)
{
  {
    uint64_t uu____871 = acc[0];
    uint64_t uu____874 = block[0];
    uint64_t uu____870 = uu____871 + uu____874;
    acc[0] = uu____870;
  }
  {
    uint64_t uu____871 = acc[1];
    uint64_t uu____874 = block[1];
    uint64_t uu____870 = uu____871 + uu____874;
    acc[1] = uu____870;
  }
  {
    uint64_t uu____871 = acc[2];
    uint64_t uu____874 = block[2];
    uint64_t uu____870 = uu____871 + uu____874;
    acc[2] = uu____870;
  }
  Hacl_Bignum_Fmul_fmul(acc, acc, r);
}

inline static void
Hacl_Impl_Poly1305_64_poly1305_update(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *m
)
{
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut0 = st[0];
  uint64_t *h = scrut0.h;
  uint64_t *acc = h;
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut = st[0];
  uint64_t *r = scrut.r;
  uint64_t *r1 = r;
  uint64_t tmp[3] = { 0 };
  FStar_UInt128_uint128 m0;
  load128_le(m, &m0);
  uint64_t r0 = FStar_Int_Cast_Full_uint128_to_uint64(&m0) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret0;
  FStar_UInt128_shift_right(&m0, (uint32_t )44, &ret0);
  FStar_UInt128_uint128 s0 = ret0;
  uint64_t r10 = FStar_Int_Cast_Full_uint128_to_uint64(&s0) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret;
  FStar_UInt128_shift_right(&m0, (uint32_t )88, &ret);
  FStar_UInt128_uint128 s00 = ret;
  uint64_t r2 = FStar_Int_Cast_Full_uint128_to_uint64(&s00);
  tmp[0] = r0;
  tmp[1] = r10;
  tmp[2] = r2;
  uint64_t b2 = tmp[2];
  uint64_t b2_ = (uint64_t )0x10000000000 | b2;
  tmp[2] = b2_;
  Hacl_Bignum_AddAndMultiply_add_and_multiply(acc, tmp, r1);
}

inline static void
Hacl_Impl_Poly1305_64_poly1305_process_last_block_(
  uint8_t *block,
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *m,
  uint64_t rem_
)
{
  uint64_t tmp[3] = { 0 };
  FStar_UInt128_uint128 m0;
  load128_le(block, &m0);
  uint64_t r0 = FStar_Int_Cast_Full_uint128_to_uint64(&m0) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret0;
  FStar_UInt128_shift_right(&m0, (uint32_t )44, &ret0);
  FStar_UInt128_uint128 s0 = ret0;
  uint64_t r1 = FStar_Int_Cast_Full_uint128_to_uint64(&s0) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret;
  FStar_UInt128_shift_right(&m0, (uint32_t )88, &ret);
  FStar_UInt128_uint128 s00 = ret;
  uint64_t r2 = FStar_Int_Cast_Full_uint128_to_uint64(&s00);
  tmp[0] = r0;
  tmp[1] = r1;
  tmp[2] = r2;
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut0 = st[0];
  uint64_t *h = scrut0.h;
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut = st[0];
  uint64_t *r = scrut.r;
  Hacl_Bignum_AddAndMultiply_add_and_multiply(h, tmp, r);
}

inline static void
Hacl_Impl_Poly1305_64_poly1305_process_last_block(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *m,
  uint64_t rem_
)
{
  uint8_t zero1 = (uint8_t )0;
  KRML_CHECK_SIZE(zero1, (uint32_t )16);
  uint8_t block[16];
  for (uintmax_t _i = 0; _i < (uint32_t )16; ++_i)
    block[_i] = zero1;
  uint32_t i0 = (uint32_t )rem_;
  uint32_t i = (uint32_t )rem_;
  memcpy(block, m, i * sizeof m[0]);
  block[i0] = (uint8_t )1;
  Hacl_Impl_Poly1305_64_poly1305_process_last_block_(block, &st[0], m, rem_);
}

static void Hacl_Impl_Poly1305_64_poly1305_last_pass(uint64_t *acc)
{
  Hacl_Bignum_Fproduct_carry_limb_(acc);
  Hacl_Bignum_Modulo_carry_top(acc);
  uint64_t a0 = acc[0];
  uint64_t a10 = acc[1];
  uint64_t a20 = acc[2];
  uint64_t a0_ = a0 & (uint64_t )0xfffffffffff;
  uint64_t r0 = a0 >> (uint32_t )44;
  uint64_t a1_ = (a10 + r0) & (uint64_t )0xfffffffffff;
  uint64_t r1 = (a10 + r0) >> (uint32_t )44;
  uint64_t a2_ = a20 + r1;
  acc[0] = a0_;
  acc[1] = a1_;
  acc[2] = a2_;
  Hacl_Bignum_Modulo_carry_top(acc);
  uint64_t i0 = acc[0];
  uint64_t i1 = acc[1];
  uint64_t i0_ = i0 & (((uint64_t )1 << (uint32_t )44) - (uint64_t )1);
  uint64_t i1_ = i1 + (i0 >> (uint32_t )44);
  acc[0] = i0_;
  acc[1] = i1_;
  uint64_t a00 = acc[0];
  uint64_t a1 = acc[1];
  uint64_t a2 = acc[2];
  uint64_t mask0 = FStar_UInt64_gte_mask(a00, (uint64_t )0xffffffffffb);
  uint64_t mask1 = FStar_UInt64_eq_mask(a1, (uint64_t )0xfffffffffff);
  uint64_t mask2 = FStar_UInt64_eq_mask(a2, (uint64_t )0x3ffffffffff);
  uint64_t mask = mask0 & mask1 & mask2;
  uint64_t a0_0 = a00 - ((uint64_t )0xffffffffffb & mask);
  uint64_t a1_0 = a1 - ((uint64_t )0xfffffffffff & mask);
  uint64_t a2_0 = a2 - ((uint64_t )0x3ffffffffff & mask);
  acc[0] = a0_0;
  acc[1] = a1_0;
  acc[2] = a2_0;
}

static void
Hacl_Impl_Poly1305_64_mk_state(
  uint64_t *r,
  uint64_t *h,
  Hacl_Impl_Poly1305_64_State_poly1305_state *ret
)
{
  ret[0] = ((Hacl_Impl_Poly1305_64_State_poly1305_state ){ .r = r, .h = h });
}

static void
Hacl_Standalone_Poly1305_64_poly1305_blocks(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *m,
  uint64_t len1
)
{
  if (len1 == (uint64_t )0)
  {
    
  }
  else
  {
    uint8_t *block = m;
    uint8_t *tail1 = m + (uint32_t )16;
    Hacl_Impl_Poly1305_64_poly1305_update(&st[0], block);
    uint64_t len2 = len1 - (uint64_t )1;
    Hacl_Standalone_Poly1305_64_poly1305_blocks(&st[0], tail1, len2);
  }
}

static void
Hacl_Standalone_Poly1305_64_poly1305_partial(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input,
  uint64_t len1,
  uint8_t *kr
)
{
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut = st[0];
  uint64_t *r = scrut.r;
  uint64_t *x0 = r;
  FStar_UInt128_uint128 k1;
  load128_le(kr, &k1);
  FStar_UInt128_uint128 k_clamped;
  FStar_UInt128_uint128 ret0;
  FStar_UInt128_uint128 ret1;
  FStar_Int_Cast_Full_uint64_to_uint128((uint64_t )0x0ffffffc0fffffff, &ret1);
  FStar_UInt128_uint128 s1 = ret1;
  FStar_UInt128_uint128 ret2;
  FStar_UInt128_uint128 ret3;
  FStar_Int_Cast_Full_uint64_to_uint128((uint64_t )0x0ffffffc0ffffffc, &ret3);
  FStar_UInt128_uint128 s0 = ret3;
  FStar_UInt128_shift_left(&s0, (uint32_t )64, &ret2);
  FStar_UInt128_uint128 s00 = ret2;
  FStar_UInt128_logor(&s00, &s1, &ret0);
  FStar_UInt128_uint128 s10 = ret0;
  FStar_UInt128_logand(&k1, &s10, &k_clamped);
  uint64_t r0 = FStar_Int_Cast_Full_uint128_to_uint64(&k_clamped) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret4;
  FStar_UInt128_shift_right(&k_clamped, (uint32_t )44, &ret4);
  FStar_UInt128_uint128 s01 = ret4;
  uint64_t r1 = FStar_Int_Cast_Full_uint128_to_uint64(&s01) & (uint64_t )0xfffffffffff;
  FStar_UInt128_uint128 ret;
  FStar_UInt128_shift_right(&k_clamped, (uint32_t )88, &ret);
  FStar_UInt128_uint128 s02 = ret;
  uint64_t r2 = FStar_Int_Cast_Full_uint128_to_uint64(&s02);
  x0[0] = r0;
  x0[1] = r1;
  x0[2] = r2;
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut0 = st[0];
  uint64_t *h = scrut0.h;
  uint64_t *x00 = h;
  x00[0] = (uint64_t )0;
  x00[1] = (uint64_t )0;
  x00[2] = (uint64_t )0;
  Hacl_Standalone_Poly1305_64_poly1305_blocks(&st[0], input, len1);
}

Prims_nat AEAD_Poly1305_64_seval(void *b)
{
  printf("KreMLin abort at %s:%d\n%s\n", __FILE__, __LINE__, "noextract flag");
  exit(255);
}

Prims_int AEAD_Poly1305_64_selem(void *s)
{
  printf("KreMLin abort at %s:%d\n%s\n", __FILE__, __LINE__, "noextract flag");
  exit(255);
}

void
AEAD_Poly1305_64_mk_state(
  uint64_t *r,
  uint64_t *acc,
  Hacl_Impl_Poly1305_64_State_poly1305_state *ret
)
{
  Hacl_Impl_Poly1305_64_State_poly1305_state ret0;
  Hacl_Impl_Poly1305_64_mk_state(r, acc, &ret0);
  ret[0] = ret0;
}

uint32_t AEAD_Poly1305_64_mul_div_16(uint32_t len1)
{
  return (uint32_t )16 * (len1 >> (uint32_t )4);
}

void
AEAD_Poly1305_64_pad_last(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input,
  uint32_t len1
)
{
  uint8_t b[16];
  if (len1 == (uint32_t )0)
  {
    
  }
  else
  {
    memset(b, 0, (uint32_t )16 * sizeof b[0]);
    memcpy(b, input, len1 * sizeof input[0]);
    uint8_t *b0 = b;
    Hacl_Impl_Poly1305_64_poly1305_update(&st[0], b0);
  }
}

void
AEAD_Poly1305_64_poly1305_blocks_init(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input,
  uint32_t len1,
  uint8_t *k1
)
{
  uint32_t len_16 = len1 >> (uint32_t )4;
  uint32_t rem_16 = len1 & (uint32_t )15;
  uint8_t *kr = k1;
  uint32_t len_ = (uint32_t )16 * (len1 >> (uint32_t )4);
  uint8_t *part_input = input;
  uint8_t *last_block = input + len_;
  Hacl_Standalone_Poly1305_64_poly1305_partial(&st[0], part_input, (uint64_t )len_16, kr);
  AEAD_Poly1305_64_pad_last(&st[0], last_block, rem_16);
}

void
AEAD_Poly1305_64_poly1305_blocks_continue(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input,
  uint32_t len1
)
{
  uint32_t len_16 = len1 >> (uint32_t )4;
  uint32_t rem_16 = len1 & (uint32_t )15;
  uint32_t len_ = (uint32_t )16 * (len1 >> (uint32_t )4);
  uint8_t *part_input = input;
  uint8_t *last_block = input + len_;
  Hacl_Standalone_Poly1305_64_poly1305_blocks(&st[0], part_input, (uint64_t )len_16);
  AEAD_Poly1305_64_pad_last(&st[0], last_block, rem_16);
}

void
AEAD_Poly1305_64_poly1305_blocks_finish_(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input
)
{
  Hacl_Impl_Poly1305_64_poly1305_update(&st[0], input);
  uint8_t *x2 = input + (uint32_t )16;
  if ((uint64_t )0 == (uint64_t )0)
  {
    
  }
  else
    Hacl_Impl_Poly1305_64_poly1305_process_last_block(&st[0], x2, (uint64_t )0);
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut = st[0];
  uint64_t *h = scrut.h;
  uint64_t *acc = h;
  Hacl_Impl_Poly1305_64_poly1305_last_pass(acc);
}

void
AEAD_Poly1305_64_poly1305_blocks_finish(
  Hacl_Impl_Poly1305_64_State_poly1305_state *st,
  uint8_t *input,
  uint8_t *mac,
  uint8_t *key_s
)
{
  Hacl_Impl_Poly1305_64_poly1305_update(&st[0], input);
  uint8_t *x2 = input + (uint32_t )16;
  if ((uint64_t )0 == (uint64_t )0)
  {
    
  }
  else
    Hacl_Impl_Poly1305_64_poly1305_process_last_block(&st[0], x2, (uint64_t )0);
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut = st[0];
  uint64_t *h = scrut.h;
  uint64_t *acc = h;
  Hacl_Impl_Poly1305_64_poly1305_last_pass(acc);
  Hacl_Impl_Poly1305_64_State_poly1305_state scrut0 = st[0];
  uint64_t *h3 = scrut0.h;
  uint64_t *acc0 = h3;
  FStar_UInt128_uint128 k_;
  load128_le(key_s, &k_);
  uint64_t h0 = acc0[0];
  uint64_t h1 = acc0[1];
  uint64_t h2 = acc0[2];
  FStar_UInt128_uint128 ret0;
  FStar_UInt128_uint128 ret1;
  FStar_Int_Cast_Full_uint64_to_uint128(h1 << (uint32_t )44 | h0, &ret1);
  FStar_UInt128_uint128 s1 = ret1;
  FStar_UInt128_uint128 ret2;
  FStar_UInt128_uint128 ret;
  FStar_Int_Cast_Full_uint64_to_uint128(h2 << (uint32_t )24 | h1 >> (uint32_t )20, &ret);
  FStar_UInt128_uint128 s0 = ret;
  FStar_UInt128_shift_left(&s0, (uint32_t )64, &ret2);
  FStar_UInt128_uint128 s00 = ret2;
  FStar_UInt128_logor(&s00, &s1, &ret0);
  FStar_UInt128_uint128 acc_ = ret0;
  FStar_UInt128_uint128 mac_;
  FStar_UInt128_add_mod(&acc_, &k_, &mac_);
  store128_le(mac, &mac_);
}

back to top