Revision 539576ec53104316dacac738fca7bc8fd967de62 authored by Son Ho on 26 February 2021, 12:56:35 UTC, committed by Son Ho on 26 February 2021, 12:56:35 UTC
1 parent 7fc6186
Raw File
Hacl_HMAC.c
/* MIT License
 *
 * Copyright (c) 2016-2020 INRIA, CMU and Microsoft Corporation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */


#include "Hacl_HMAC.h"

void
Hacl_HMAC_legacy_compute_sha1(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)64U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)64U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)20U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)64U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_SHA1_legacy_hash(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint32_t scrut[5];
              uint32_t *s;
              uint8_t *dst1;
              uint8_t *hash1;
              {
                uint32_t i;
                for (i = (uint32_t)0U; i < l; i++)
                {
                  uint8_t xi = opad[i];
                  uint8_t yi = key_block[i];
                  opad[i] = xi ^ yi;
                }
              }
              scrut[0U] = (uint32_t)0x67452301U;
              scrut[1U] = (uint32_t)0xefcdab89U;
              scrut[2U] = (uint32_t)0x98badcfeU;
              scrut[3U] = (uint32_t)0x10325476U;
              scrut[4U] = (uint32_t)0xc3d2e1f0U;
              s = scrut;
              dst1 = ipad;
              Hacl_Hash_Core_SHA1_legacy_init(s);
              if (data_len == (uint32_t)0U)
              {
                Hacl_Hash_SHA1_legacy_update_last(s, (uint64_t)0U, ipad, (uint32_t)64U);
              }
              else
              {
                Hacl_Hash_SHA1_legacy_update_multi(s, ipad, (uint32_t)1U);
                Hacl_Hash_SHA1_legacy_update_last(s, (uint64_t)(uint32_t)64U, data, data_len);
              }
              Hacl_Hash_Core_SHA1_legacy_finish(s, dst1);
              hash1 = ipad;
              Hacl_Hash_Core_SHA1_legacy_init(s);
              if ((uint32_t)20U == (uint32_t)0U)
              {
                Hacl_Hash_SHA1_legacy_update_last(s, (uint64_t)0U, opad, (uint32_t)64U);
              }
              else
              {
                Hacl_Hash_SHA1_legacy_update_multi(s, opad, (uint32_t)1U);
                Hacl_Hash_SHA1_legacy_update_last(s, (uint64_t)(uint32_t)64U, hash1, (uint32_t)20U);
              }
              Hacl_Hash_Core_SHA1_legacy_finish(s, dst);
            }
          }
        }
      }
    }
  }
}

void
Hacl_HMAC_compute_sha2_256(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)64U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)64U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)32U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)64U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_SHA2_hash_256(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint32_t scrut[8];
              uint32_t *s;
              uint8_t *dst1;
              uint8_t *hash1;
              {
                uint32_t i;
                for (i = (uint32_t)0U; i < l; i++)
                {
                  uint8_t xi = opad[i];
                  uint8_t yi = key_block[i];
                  opad[i] = xi ^ yi;
                }
              }
              scrut[0U] = (uint32_t)0x6a09e667U;
              scrut[1U] = (uint32_t)0xbb67ae85U;
              scrut[2U] = (uint32_t)0x3c6ef372U;
              scrut[3U] = (uint32_t)0xa54ff53aU;
              scrut[4U] = (uint32_t)0x510e527fU;
              scrut[5U] = (uint32_t)0x9b05688cU;
              scrut[6U] = (uint32_t)0x1f83d9abU;
              scrut[7U] = (uint32_t)0x5be0cd19U;
              s = scrut;
              dst1 = ipad;
              Hacl_Hash_Core_SHA2_init_256(s);
              if (data_len == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_256(s, (uint64_t)0U, ipad, (uint32_t)64U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_256(s, ipad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_256(s, (uint64_t)(uint32_t)64U, data, data_len);
              }
              Hacl_Hash_Core_SHA2_finish_256(s, dst1);
              hash1 = ipad;
              Hacl_Hash_Core_SHA2_init_256(s);
              if ((uint32_t)32U == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_256(s, (uint64_t)0U, opad, (uint32_t)64U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_256(s, opad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_256(s, (uint64_t)(uint32_t)64U, hash1, (uint32_t)32U);
              }
              Hacl_Hash_Core_SHA2_finish_256(s, dst);
            }
          }
        }
      }
    }
  }
}

void
Hacl_HMAC_compute_sha2_384(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)128U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)128U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)48U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)128U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_SHA2_hash_384(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint64_t scrut[8];
              uint64_t *s;
              uint8_t *dst1;
              uint8_t *hash1;
              {
                uint32_t i;
                for (i = (uint32_t)0U; i < l; i++)
                {
                  uint8_t xi = opad[i];
                  uint8_t yi = key_block[i];
                  opad[i] = xi ^ yi;
                }
              }
              scrut[0U] = (uint64_t)0xcbbb9d5dc1059ed8U;
              scrut[1U] = (uint64_t)0x629a292a367cd507U;
              scrut[2U] = (uint64_t)0x9159015a3070dd17U;
              scrut[3U] = (uint64_t)0x152fecd8f70e5939U;
              scrut[4U] = (uint64_t)0x67332667ffc00b31U;
              scrut[5U] = (uint64_t)0x8eb44a8768581511U;
              scrut[6U] = (uint64_t)0xdb0c2e0d64f98fa7U;
              scrut[7U] = (uint64_t)0x47b5481dbefa4fa4U;
              s = scrut;
              dst1 = ipad;
              Hacl_Hash_Core_SHA2_init_384(s);
              if (data_len == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_384(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                  ipad,
                  (uint32_t)128U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_384(s, ipad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_384(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                  data,
                  data_len);
              }
              Hacl_Hash_Core_SHA2_finish_384(s, dst1);
              hash1 = ipad;
              Hacl_Hash_Core_SHA2_init_384(s);
              if ((uint32_t)48U == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_384(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                  opad,
                  (uint32_t)128U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_384(s, opad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_384(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                  hash1,
                  (uint32_t)48U);
              }
              Hacl_Hash_Core_SHA2_finish_384(s, dst);
            }
          }
        }
      }
    }
  }
}

void
Hacl_HMAC_compute_sha2_512(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)128U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)128U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)64U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)128U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_SHA2_hash_512(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint64_t scrut[8];
              uint64_t *s;
              uint8_t *dst1;
              uint8_t *hash1;
              {
                uint32_t i;
                for (i = (uint32_t)0U; i < l; i++)
                {
                  uint8_t xi = opad[i];
                  uint8_t yi = key_block[i];
                  opad[i] = xi ^ yi;
                }
              }
              scrut[0U] = (uint64_t)0x6a09e667f3bcc908U;
              scrut[1U] = (uint64_t)0xbb67ae8584caa73bU;
              scrut[2U] = (uint64_t)0x3c6ef372fe94f82bU;
              scrut[3U] = (uint64_t)0xa54ff53a5f1d36f1U;
              scrut[4U] = (uint64_t)0x510e527fade682d1U;
              scrut[5U] = (uint64_t)0x9b05688c2b3e6c1fU;
              scrut[6U] = (uint64_t)0x1f83d9abfb41bd6bU;
              scrut[7U] = (uint64_t)0x5be0cd19137e2179U;
              s = scrut;
              dst1 = ipad;
              Hacl_Hash_Core_SHA2_init_512(s);
              if (data_len == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_512(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                  ipad,
                  (uint32_t)128U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_512(s, ipad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_512(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                  data,
                  data_len);
              }
              Hacl_Hash_Core_SHA2_finish_512(s, dst1);
              hash1 = ipad;
              Hacl_Hash_Core_SHA2_init_512(s);
              if ((uint32_t)64U == (uint32_t)0U)
              {
                Hacl_Hash_SHA2_update_last_512(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                  opad,
                  (uint32_t)128U);
              }
              else
              {
                Hacl_Hash_SHA2_update_multi_512(s, opad, (uint32_t)1U);
                Hacl_Hash_SHA2_update_last_512(s,
                  FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                  hash1,
                  (uint32_t)64U);
              }
              Hacl_Hash_Core_SHA2_finish_512(s, dst);
            }
          }
        }
      }
    }
  }
}

void
Hacl_HMAC_compute_blake2s_32(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)64U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)64U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)32U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)64U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_Blake2_hash_blake2s_32(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint32_t i;
              for (i = (uint32_t)0U; i < l; i++)
              {
                uint8_t xi = opad[i];
                uint8_t yi = key_block[i];
                opad[i] = xi ^ yi;
              }
            }
            {
              uint32_t s0[16U] = { 0U };
              uint32_t *r00 = s0 + (uint32_t)0U * (uint32_t)4U;
              uint32_t *r10 = s0 + (uint32_t)1U * (uint32_t)4U;
              uint32_t *r20 = s0 + (uint32_t)2U * (uint32_t)4U;
              uint32_t *r30 = s0 + (uint32_t)3U * (uint32_t)4U;
              uint32_t iv00 = Hacl_Impl_Blake2_Constants_ivTable_S[0U];
              uint32_t iv10 = Hacl_Impl_Blake2_Constants_ivTable_S[1U];
              uint32_t iv20 = Hacl_Impl_Blake2_Constants_ivTable_S[2U];
              uint32_t iv30 = Hacl_Impl_Blake2_Constants_ivTable_S[3U];
              uint32_t iv40 = Hacl_Impl_Blake2_Constants_ivTable_S[4U];
              uint32_t iv50 = Hacl_Impl_Blake2_Constants_ivTable_S[5U];
              uint32_t iv60 = Hacl_Impl_Blake2_Constants_ivTable_S[6U];
              uint32_t iv70 = Hacl_Impl_Blake2_Constants_ivTable_S[7U];
              uint32_t kk_shift_80;
              uint32_t iv0_;
              uint64_t es;
              r20[0U] = iv00;
              r20[1U] = iv10;
              r20[2U] = iv20;
              r20[3U] = iv30;
              r30[0U] = iv40;
              r30[1U] = iv50;
              r30[2U] = iv60;
              r30[3U] = iv70;
              kk_shift_80 = (uint32_t)0U;
              iv0_ = iv00 ^ ((uint32_t)0x01010000U ^ (kk_shift_80 ^ (uint32_t)32U));
              r00[0U] = iv0_;
              r00[1U] = iv10;
              r00[2U] = iv20;
              r00[3U] = iv30;
              r10[0U] = iv40;
              r10[1U] = iv50;
              r10[2U] = iv60;
              r10[3U] = iv70;
              es = (uint64_t)0U;
              {
                K____uint32_t__uint64_t scrut;
                uint32_t *s;
                uint8_t *dst1;
                uint32_t *r01;
                uint32_t *r11;
                uint32_t *r21;
                uint32_t *r31;
                uint32_t iv01;
                uint32_t iv11;
                uint32_t iv21;
                uint32_t iv31;
                uint32_t iv41;
                uint32_t iv51;
                uint32_t iv61;
                uint32_t iv71;
                uint32_t kk_shift_81;
                uint32_t iv0_0;
                uint64_t ev0;
                uint64_t ev10;
                uint8_t *hash1;
                uint32_t *r0;
                uint32_t *r1;
                uint32_t *r2;
                uint32_t *r3;
                uint32_t iv0;
                uint32_t iv1;
                uint32_t iv2;
                uint32_t iv3;
                uint32_t iv4;
                uint32_t iv5;
                uint32_t iv6;
                uint32_t iv7;
                uint32_t kk_shift_8;
                uint32_t iv0_1;
                uint64_t ev;
                uint64_t ev11;
                scrut.fst = s0;
                scrut.snd = es;
                s = scrut.fst;
                dst1 = ipad;
                r01 = s + (uint32_t)0U * (uint32_t)4U;
                r11 = s + (uint32_t)1U * (uint32_t)4U;
                r21 = s + (uint32_t)2U * (uint32_t)4U;
                r31 = s + (uint32_t)3U * (uint32_t)4U;
                iv01 = Hacl_Impl_Blake2_Constants_ivTable_S[0U];
                iv11 = Hacl_Impl_Blake2_Constants_ivTable_S[1U];
                iv21 = Hacl_Impl_Blake2_Constants_ivTable_S[2U];
                iv31 = Hacl_Impl_Blake2_Constants_ivTable_S[3U];
                iv41 = Hacl_Impl_Blake2_Constants_ivTable_S[4U];
                iv51 = Hacl_Impl_Blake2_Constants_ivTable_S[5U];
                iv61 = Hacl_Impl_Blake2_Constants_ivTable_S[6U];
                iv71 = Hacl_Impl_Blake2_Constants_ivTable_S[7U];
                r21[0U] = iv01;
                r21[1U] = iv11;
                r21[2U] = iv21;
                r21[3U] = iv31;
                r31[0U] = iv41;
                r31[1U] = iv51;
                r31[2U] = iv61;
                r31[3U] = iv71;
                kk_shift_81 = (uint32_t)0U;
                iv0_0 = iv01 ^ ((uint32_t)0x01010000U ^ (kk_shift_81 ^ (uint32_t)32U));
                r01[0U] = iv0_0;
                r01[1U] = iv11;
                r01[2U] = iv21;
                r01[3U] = iv31;
                r11[0U] = iv41;
                r11[1U] = iv51;
                r11[2U] = iv61;
                r11[3U] = iv71;
                ev0 = (uint64_t)0U;
                if (data_len == (uint32_t)0U)
                {
                  uint64_t
                  ev1 =
                    Hacl_Hash_Blake2_update_last_blake2s_32(s,
                      ev0,
                      (uint64_t)0U,
                      ipad,
                      (uint32_t)64U);
                  ev10 = ev1;
                }
                else
                {
                  uint64_t
                  ev1 = Hacl_Hash_Blake2_update_multi_blake2s_32(s, ev0, ipad, (uint32_t)1U);
                  uint64_t
                  ev2 =
                    Hacl_Hash_Blake2_update_last_blake2s_32(s,
                      ev1,
                      (uint64_t)(uint32_t)64U,
                      data,
                      data_len);
                  ev10 = ev2;
                }
                Hacl_Hash_Core_Blake2_finish_blake2s_32(s, ev10, dst1);
                hash1 = ipad;
                r0 = s + (uint32_t)0U * (uint32_t)4U;
                r1 = s + (uint32_t)1U * (uint32_t)4U;
                r2 = s + (uint32_t)2U * (uint32_t)4U;
                r3 = s + (uint32_t)3U * (uint32_t)4U;
                iv0 = Hacl_Impl_Blake2_Constants_ivTable_S[0U];
                iv1 = Hacl_Impl_Blake2_Constants_ivTable_S[1U];
                iv2 = Hacl_Impl_Blake2_Constants_ivTable_S[2U];
                iv3 = Hacl_Impl_Blake2_Constants_ivTable_S[3U];
                iv4 = Hacl_Impl_Blake2_Constants_ivTable_S[4U];
                iv5 = Hacl_Impl_Blake2_Constants_ivTable_S[5U];
                iv6 = Hacl_Impl_Blake2_Constants_ivTable_S[6U];
                iv7 = Hacl_Impl_Blake2_Constants_ivTable_S[7U];
                r2[0U] = iv0;
                r2[1U] = iv1;
                r2[2U] = iv2;
                r2[3U] = iv3;
                r3[0U] = iv4;
                r3[1U] = iv5;
                r3[2U] = iv6;
                r3[3U] = iv7;
                kk_shift_8 = (uint32_t)0U;
                iv0_1 = iv0 ^ ((uint32_t)0x01010000U ^ (kk_shift_8 ^ (uint32_t)32U));
                r0[0U] = iv0_1;
                r0[1U] = iv1;
                r0[2U] = iv2;
                r0[3U] = iv3;
                r1[0U] = iv4;
                r1[1U] = iv5;
                r1[2U] = iv6;
                r1[3U] = iv7;
                ev = (uint64_t)0U;
                if ((uint32_t)32U == (uint32_t)0U)
                {
                  uint64_t
                  ev1 =
                    Hacl_Hash_Blake2_update_last_blake2s_32(s,
                      ev,
                      (uint64_t)0U,
                      opad,
                      (uint32_t)64U);
                  ev11 = ev1;
                }
                else
                {
                  uint64_t
                  ev1 = Hacl_Hash_Blake2_update_multi_blake2s_32(s, ev, opad, (uint32_t)1U);
                  uint64_t
                  ev2 =
                    Hacl_Hash_Blake2_update_last_blake2s_32(s,
                      ev1,
                      (uint64_t)(uint32_t)64U,
                      hash1,
                      (uint32_t)32U);
                  ev11 = ev2;
                }
                Hacl_Hash_Core_Blake2_finish_blake2s_32(s, ev11, dst);
              }
            }
          }
        }
      }
    }
  }
}

void
Hacl_HMAC_compute_blake2b_32(
  uint8_t *dst,
  uint8_t *key,
  uint32_t key_len,
  uint8_t *data,
  uint32_t data_len
)
{
  uint32_t l = (uint32_t)128U;
  KRML_CHECK_SIZE(sizeof (uint8_t), l);
  {
    uint8_t key_block[l];
    memset(key_block, 0U, l * sizeof (uint8_t));
    {
      uint32_t i0;
      if (key_len <= (uint32_t)128U)
      {
        i0 = key_len;
      }
      else
      {
        i0 = (uint32_t)64U;
      }
      {
        uint8_t *nkey = key_block;
        if (key_len <= (uint32_t)128U)
        {
          memcpy(nkey, key, key_len * sizeof (uint8_t));
        }
        else
        {
          Hacl_Hash_Blake2_hash_blake2b_32(key, key_len, nkey);
        }
        KRML_CHECK_SIZE(sizeof (uint8_t), l);
        {
          uint8_t ipad[l];
          memset(ipad, (uint8_t)0x36U, l * sizeof (uint8_t));
          {
            uint32_t i;
            for (i = (uint32_t)0U; i < l; i++)
            {
              uint8_t xi = ipad[i];
              uint8_t yi = key_block[i];
              ipad[i] = xi ^ yi;
            }
          }
          KRML_CHECK_SIZE(sizeof (uint8_t), l);
          {
            uint8_t opad[l];
            memset(opad, (uint8_t)0x5cU, l * sizeof (uint8_t));
            {
              uint32_t i;
              for (i = (uint32_t)0U; i < l; i++)
              {
                uint8_t xi = opad[i];
                uint8_t yi = key_block[i];
                opad[i] = xi ^ yi;
              }
            }
            {
              uint64_t s0[16U] = { 0U };
              uint64_t *r00 = s0 + (uint32_t)0U * (uint32_t)4U;
              uint64_t *r10 = s0 + (uint32_t)1U * (uint32_t)4U;
              uint64_t *r20 = s0 + (uint32_t)2U * (uint32_t)4U;
              uint64_t *r30 = s0 + (uint32_t)3U * (uint32_t)4U;
              uint64_t iv00 = Hacl_Impl_Blake2_Constants_ivTable_B[0U];
              uint64_t iv10 = Hacl_Impl_Blake2_Constants_ivTable_B[1U];
              uint64_t iv20 = Hacl_Impl_Blake2_Constants_ivTable_B[2U];
              uint64_t iv30 = Hacl_Impl_Blake2_Constants_ivTable_B[3U];
              uint64_t iv40 = Hacl_Impl_Blake2_Constants_ivTable_B[4U];
              uint64_t iv50 = Hacl_Impl_Blake2_Constants_ivTable_B[5U];
              uint64_t iv60 = Hacl_Impl_Blake2_Constants_ivTable_B[6U];
              uint64_t iv70 = Hacl_Impl_Blake2_Constants_ivTable_B[7U];
              uint64_t kk_shift_80;
              uint64_t iv0_;
              FStar_UInt128_uint128 es;
              r20[0U] = iv00;
              r20[1U] = iv10;
              r20[2U] = iv20;
              r20[3U] = iv30;
              r30[0U] = iv40;
              r30[1U] = iv50;
              r30[2U] = iv60;
              r30[3U] = iv70;
              kk_shift_80 = (uint64_t)(uint32_t)0U << (uint32_t)8U;
              iv0_ = iv00 ^ ((uint64_t)0x01010000U ^ (kk_shift_80 ^ (uint64_t)(uint32_t)64U));
              r00[0U] = iv0_;
              r00[1U] = iv10;
              r00[2U] = iv20;
              r00[3U] = iv30;
              r10[0U] = iv40;
              r10[1U] = iv50;
              r10[2U] = iv60;
              r10[3U] = iv70;
              es = FStar_UInt128_uint64_to_uint128((uint64_t)0U);
              {
                K____uint64_t__FStar_UInt128_uint128 scrut;
                uint64_t *s;
                uint8_t *dst1;
                uint64_t *r01;
                uint64_t *r11;
                uint64_t *r21;
                uint64_t *r31;
                uint64_t iv01;
                uint64_t iv11;
                uint64_t iv21;
                uint64_t iv31;
                uint64_t iv41;
                uint64_t iv51;
                uint64_t iv61;
                uint64_t iv71;
                uint64_t kk_shift_81;
                uint64_t iv0_0;
                FStar_UInt128_uint128 ev0;
                FStar_UInt128_uint128 ev10;
                uint8_t *hash1;
                uint64_t *r0;
                uint64_t *r1;
                uint64_t *r2;
                uint64_t *r3;
                uint64_t iv0;
                uint64_t iv1;
                uint64_t iv2;
                uint64_t iv3;
                uint64_t iv4;
                uint64_t iv5;
                uint64_t iv6;
                uint64_t iv7;
                uint64_t kk_shift_8;
                uint64_t iv0_1;
                FStar_UInt128_uint128 ev;
                FStar_UInt128_uint128 ev11;
                scrut.fst = s0;
                scrut.snd = es;
                s = scrut.fst;
                dst1 = ipad;
                r01 = s + (uint32_t)0U * (uint32_t)4U;
                r11 = s + (uint32_t)1U * (uint32_t)4U;
                r21 = s + (uint32_t)2U * (uint32_t)4U;
                r31 = s + (uint32_t)3U * (uint32_t)4U;
                iv01 = Hacl_Impl_Blake2_Constants_ivTable_B[0U];
                iv11 = Hacl_Impl_Blake2_Constants_ivTable_B[1U];
                iv21 = Hacl_Impl_Blake2_Constants_ivTable_B[2U];
                iv31 = Hacl_Impl_Blake2_Constants_ivTable_B[3U];
                iv41 = Hacl_Impl_Blake2_Constants_ivTable_B[4U];
                iv51 = Hacl_Impl_Blake2_Constants_ivTable_B[5U];
                iv61 = Hacl_Impl_Blake2_Constants_ivTable_B[6U];
                iv71 = Hacl_Impl_Blake2_Constants_ivTable_B[7U];
                r21[0U] = iv01;
                r21[1U] = iv11;
                r21[2U] = iv21;
                r21[3U] = iv31;
                r31[0U] = iv41;
                r31[1U] = iv51;
                r31[2U] = iv61;
                r31[3U] = iv71;
                kk_shift_81 = (uint64_t)(uint32_t)0U << (uint32_t)8U;
                iv0_0 = iv01 ^ ((uint64_t)0x01010000U ^ (kk_shift_81 ^ (uint64_t)(uint32_t)64U));
                r01[0U] = iv0_0;
                r01[1U] = iv11;
                r01[2U] = iv21;
                r01[3U] = iv31;
                r11[0U] = iv41;
                r11[1U] = iv51;
                r11[2U] = iv61;
                r11[3U] = iv71;
                ev0 = FStar_UInt128_uint64_to_uint128((uint64_t)0U);
                if (data_len == (uint32_t)0U)
                {
                  FStar_UInt128_uint128
                  ev1 =
                    Hacl_Hash_Blake2_update_last_blake2b_32(s,
                      ev0,
                      FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                      ipad,
                      (uint32_t)128U);
                  ev10 = ev1;
                }
                else
                {
                  FStar_UInt128_uint128
                  ev1 = Hacl_Hash_Blake2_update_multi_blake2b_32(s, ev0, ipad, (uint32_t)1U);
                  FStar_UInt128_uint128
                  ev2 =
                    Hacl_Hash_Blake2_update_last_blake2b_32(s,
                      ev1,
                      FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                      data,
                      data_len);
                  ev10 = ev2;
                }
                Hacl_Hash_Core_Blake2_finish_blake2b_32(s, ev10, dst1);
                hash1 = ipad;
                r0 = s + (uint32_t)0U * (uint32_t)4U;
                r1 = s + (uint32_t)1U * (uint32_t)4U;
                r2 = s + (uint32_t)2U * (uint32_t)4U;
                r3 = s + (uint32_t)3U * (uint32_t)4U;
                iv0 = Hacl_Impl_Blake2_Constants_ivTable_B[0U];
                iv1 = Hacl_Impl_Blake2_Constants_ivTable_B[1U];
                iv2 = Hacl_Impl_Blake2_Constants_ivTable_B[2U];
                iv3 = Hacl_Impl_Blake2_Constants_ivTable_B[3U];
                iv4 = Hacl_Impl_Blake2_Constants_ivTable_B[4U];
                iv5 = Hacl_Impl_Blake2_Constants_ivTable_B[5U];
                iv6 = Hacl_Impl_Blake2_Constants_ivTable_B[6U];
                iv7 = Hacl_Impl_Blake2_Constants_ivTable_B[7U];
                r2[0U] = iv0;
                r2[1U] = iv1;
                r2[2U] = iv2;
                r2[3U] = iv3;
                r3[0U] = iv4;
                r3[1U] = iv5;
                r3[2U] = iv6;
                r3[3U] = iv7;
                kk_shift_8 = (uint64_t)(uint32_t)0U << (uint32_t)8U;
                iv0_1 = iv0 ^ ((uint64_t)0x01010000U ^ (kk_shift_8 ^ (uint64_t)(uint32_t)64U));
                r0[0U] = iv0_1;
                r0[1U] = iv1;
                r0[2U] = iv2;
                r0[3U] = iv3;
                r1[0U] = iv4;
                r1[1U] = iv5;
                r1[2U] = iv6;
                r1[3U] = iv7;
                ev = FStar_UInt128_uint64_to_uint128((uint64_t)0U);
                if ((uint32_t)64U == (uint32_t)0U)
                {
                  FStar_UInt128_uint128
                  ev1 =
                    Hacl_Hash_Blake2_update_last_blake2b_32(s,
                      ev,
                      FStar_UInt128_uint64_to_uint128((uint64_t)0U),
                      opad,
                      (uint32_t)128U);
                  ev11 = ev1;
                }
                else
                {
                  FStar_UInt128_uint128
                  ev1 = Hacl_Hash_Blake2_update_multi_blake2b_32(s, ev, opad, (uint32_t)1U);
                  FStar_UInt128_uint128
                  ev2 =
                    Hacl_Hash_Blake2_update_last_blake2b_32(s,
                      ev1,
                      FStar_UInt128_uint64_to_uint128((uint64_t)(uint32_t)128U),
                      hash1,
                      (uint32_t)64U);
                  ev11 = ev2;
                }
                Hacl_Hash_Core_Blake2_finish_blake2b_32(s, ev11, dst);
              }
            }
          }
        }
      }
    }
  }
}

back to top