From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id CE475C433F5 for ; Tue, 25 Jan 2022 02:20:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S3419745AbiAYCUK (ORCPT ); Mon, 24 Jan 2022 21:20:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55764 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S3415338AbiAYBpS (ORCPT ); Mon, 24 Jan 2022 20:45:18 -0500 Received: from mail-ua1-x94a.google.com (mail-ua1-x94a.google.com [IPv6:2607:f8b0:4864:20::94a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3F935C0A8876 for ; Mon, 24 Jan 2022 17:45:18 -0800 (PST) Received: by mail-ua1-x94a.google.com with SMTP id i28-20020a9f305c000000b00305923be96aso11346580uab.9 for ; Mon, 24 Jan 2022 17:45:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc:content-transfer-encoding; bh=A79nkcZwBR0NLt8+NnfzgPYKFdLcz7PnLt3dca6foZw=; b=WSkq+D+gecDAojURQZAiZRJui8bvUQ/90EBrAkv5BlxFU0N1gd/QbMbWdx4J4zmNMo wjmkmi9hPG5hhxGLT7ANm/lMLZMImplGYjknXXGpK7N6JSmgQrRDxf6BRxc3/URSdCdN YqzAfE502cgbVTTnDFD+iy2n3sjnupfwL3Urwd2bpGdolRuNQmw9QgclhEBTAfEHZ4Vt Zax2BGWJBCmNFd+5eXkfEU+oMtmDm8NR5DA/8gHynXPQreIGJZBbBfSJ5ewIYcJ71O7+ 9ydzVj6yMhpUzOdZ0kyZXYCQtcNVvyfjW7ImqccxebHnIXeV50gPLIX/2vQ4I9zWgRY4 sVOw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc:content-transfer-encoding; bh=A79nkcZwBR0NLt8+NnfzgPYKFdLcz7PnLt3dca6foZw=; b=BNLJWEHlc1dGCM/put/JDOc0mL87XnI6rXnTbFdepuLXtTytImH1Bom3kBU9lCIx3S 0eat56+oknuDyPimChfvqbMemxyQNW56LcxYMqbZxDgKeG0OfZpsCTwhXgI6aVBB24uO X6P8u4tTzaBKX8pgXg6nqTLBBWl28dn4uJtSIT7UwlGL12HUCVk4k7vQxeoyLhn6KQDj +0AwFdtf5pwSMxnwtGG0VRquPB8kbOVRDs4eeluFZCrGj90k+cWJwbUybTDNtDywWu/Q mWcnyZqme0jHxH0ilGkmsOkNKJynEh2AowJGkxriqQsK7ugteP2j+rwAexxWzkehkV7Q ERJA== X-Gm-Message-State: AOAM531rC35NqHOZGatWfjMbvepZ9lqITXApuzInVbQHhRE/OpyTKpi/ alqQtV5CaiSaSn7WsL1n8qGimf44VZc3pkUvPspe4cKqWVlbDZKca+3hydVkCI3YirpGnJ9eW7I Y2Cxi1BdeG9w4W8Mvq7UqDt/lwKvE68Y6N20zqU3ROELc/b8sx+eSEtLUWBxHRc9hmQ8= X-Google-Smtp-Source: ABdhPJwWasivCuAnDdlKcsFnLRLpKMMy6E8EmA2PPfF47SW0EXUslagzCWHriWl65MLLjyw3kIgx7GL2hg== X-Received: from nhuck.c.googlers.com ([fda3:e722:ac3:cc00:14:4d90:c0a8:39cc]) (user=nhuck job=sendgmr) by 2002:a67:df8e:: with SMTP id x14mr6969862vsk.80.1643075117363; Mon, 24 Jan 2022 17:45:17 -0800 (PST) Date: Mon, 24 Jan 2022 19:44:17 -0600 In-Reply-To: <20220125014422.80552-1-nhuck@google.com> Message-Id: <20220125014422.80552-3-nhuck@google.com> Mime-Version: 1.0 References: <20220125014422.80552-1-nhuck@google.com> X-Mailer: git-send-email 2.35.0.rc0.227.g00780c9af4-goog Subject: [RFC PATCH 2/7] crypto: polyval - Add POLYVAL support From: Nathan Huckleberry To: linux-crypto@vger.kernel.org Cc: Herbert Xu , "David S. Miller" , linux-arm-kernel@lists.infradead.org, Paul Crowley , Eric Biggers , Sami Tolvanen , Nathan Huckleberry Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org Add support for POLYVAL, an =CE=B5-universal hash function similar to GHASH= . POLYVAL is used as a component to implement HCTR2 mode. POLYVAL is implemented as an shash algorithm. The implementation is modified from ghash-generic.c. More information on POLYVAL can be found in the HCTR2 paper: https://eprint.iacr.org/2021/1441.pdf Signed-off-by: Nathan Huckleberry --- crypto/Kconfig | 8 ++ crypto/Makefile | 1 + crypto/polyval-generic.c | 183 +++++++++++++++++++++++++ crypto/tcrypt.c | 4 + crypto/testmgr.c | 6 + crypto/testmgr.h | 284 +++++++++++++++++++++++++++++++++++++++ include/crypto/polyval.h | 22 +++ 7 files changed, 508 insertions(+) create mode 100644 crypto/polyval-generic.c create mode 100644 include/crypto/polyval.h diff --git a/crypto/Kconfig b/crypto/Kconfig index b00de5f22eaf..051060cd5e21 100644 --- a/crypto/Kconfig +++ b/crypto/Kconfig @@ -760,6 +760,14 @@ config CRYPTO_GHASH GHASH is the hash function used in GCM (Galois/Counter Mode). It is not a general-purpose cryptographic hash function. =20 +config CRYPTO_POLYVAL + tristate + select CRYPTO_GF128MUL + select CRYPTO_HASH + help + POLYVAL is the hash function used in HCTR2. It is not a general-purpos= e + cryptographic hash function. + config CRYPTO_POLY1305 tristate "Poly1305 authenticator algorithm" select CRYPTO_HASH diff --git a/crypto/Makefile b/crypto/Makefile index 6b3fe3df1489..561f901a91d4 100644 --- a/crypto/Makefile +++ b/crypto/Makefile @@ -169,6 +169,7 @@ UBSAN_SANITIZE_jitterentropy.o =3D n jitterentropy_rng-y :=3D jitterentropy.o jitterentropy-kcapi.o obj-$(CONFIG_CRYPTO_TEST) +=3D tcrypt.o obj-$(CONFIG_CRYPTO_GHASH) +=3D ghash-generic.o +obj-$(CONFIG_CRYPTO_POLYVAL) +=3D polyval-generic.o obj-$(CONFIG_CRYPTO_USER_API) +=3D af_alg.o obj-$(CONFIG_CRYPTO_USER_API_HASH) +=3D algif_hash.o obj-$(CONFIG_CRYPTO_USER_API_SKCIPHER) +=3D algif_skcipher.o diff --git a/crypto/polyval-generic.c b/crypto/polyval-generic.c new file mode 100644 index 000000000000..63e908697ea0 --- /dev/null +++ b/crypto/polyval-generic.c @@ -0,0 +1,183 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * POLYVAL: hash function for HCTR2. + * + * Copyright (c) 2007 Nokia Siemens Networks - Mikko Herranen + * Copyright (c) 2009 Intel Corp. + * Author: Huang Ying + * Copyright 2021 Google LLC + */ + +/* + * Code based on crypto/ghash-generic.c + * + * POLYVAL is a keyed hash function similar to GHASH. POLYVAL uses a + * different modulus for finite field multiplication which makes hardware + * accelerated implementations on little-endian machines faster. + * + * Like GHASH, POLYVAL is not a cryptographic hash function and should + * not be used outside of crypto modes explicitly designed to use POLYVAL. + * + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +struct polyval_tfm_ctx { + struct gf128mul_4k *gf128; +}; + +static int polyval_init(struct shash_desc *desc) +{ + struct polyval_desc_ctx *dctx =3D shash_desc_ctx(desc); + + memset(dctx, 0, sizeof(*dctx)); + + return 0; +} + +static void reverse_block(u8 block[POLYVAL_BLOCK_SIZE]) +{ + u64 *p1 =3D (u64 *)block; + u64 *p2 =3D (u64 *)&block[8]; + u64 a =3D get_unaligned(p1); + u64 b =3D get_unaligned(p2); + + put_unaligned(swab64(a), p2); + put_unaligned(swab64(b), p1); +} + +static int polyval_setkey(struct crypto_shash *tfm, + const u8 *key, unsigned int keylen) +{ + struct polyval_tfm_ctx *ctx =3D crypto_shash_ctx(tfm); + be128 k; + + if (keylen !=3D POLYVAL_BLOCK_SIZE) + return -EINVAL; + + gf128mul_free_4k(ctx->gf128); + + BUILD_BUG_ON(sizeof(k) !=3D POLYVAL_BLOCK_SIZE); + memcpy(&k, key, POLYVAL_BLOCK_SIZE); /* avoid violating alignment rules *= / + + reverse_block((u8 *)&k); + gf128mul_x_lle(&k, &k); + + ctx->gf128 =3D gf128mul_init_4k_lle(&k); + memzero_explicit(&k, POLYVAL_BLOCK_SIZE); + + if (!ctx->gf128) + return -ENOMEM; + + return 0; +} + +static int polyval_update(struct shash_desc *desc, + const u8 *src, unsigned int srclen) +{ + struct polyval_desc_ctx *dctx =3D shash_desc_ctx(desc); + const struct polyval_tfm_ctx *ctx =3D crypto_shash_ctx(desc->tfm); + u8 *dst =3D dctx->buffer; + u8 *pos; + u8 tmp[POLYVAL_BLOCK_SIZE]; + int n; + + if (dctx->bytes) { + n =3D min(srclen, dctx->bytes); + pos =3D dst + dctx->bytes - 1; + + dctx->bytes -=3D n; + srclen -=3D n; + + while (n--) + *pos-- ^=3D *src++; + + if (!dctx->bytes) + gf128mul_4k_lle((be128 *)dst, ctx->gf128); + } + + while (srclen >=3D POLYVAL_BLOCK_SIZE) { + memcpy(tmp, src, POLYVAL_BLOCK_SIZE); + reverse_block(tmp); + crypto_xor(dst, tmp, POLYVAL_BLOCK_SIZE); + gf128mul_4k_lle((be128 *)dst, ctx->gf128); + src +=3D POLYVAL_BLOCK_SIZE; + srclen -=3D POLYVAL_BLOCK_SIZE; + } + + if (srclen) { + dctx->bytes =3D POLYVAL_BLOCK_SIZE - srclen; + pos =3D dst + POLYVAL_BLOCK_SIZE - 1; + while (srclen--) + *pos-- ^=3D *src++; + } + + return 0; +} + +static int polyval_final(struct shash_desc *desc, u8 *dst) +{ + struct polyval_desc_ctx *dctx =3D shash_desc_ctx(desc); + const struct polyval_tfm_ctx *ctx =3D crypto_shash_ctx(desc->tfm); + u8 *buf =3D dctx->buffer; + + if (dctx->bytes) + gf128mul_4k_lle((be128 *)dst, ctx->gf128); + dctx->bytes =3D 0; + + reverse_block(buf); + memcpy(dst, buf, POLYVAL_BLOCK_SIZE); + + return 0; +} + +static void polyval_exit_tfm(struct crypto_tfm *tfm) +{ + struct polyval_tfm_ctx *ctx =3D crypto_tfm_ctx(tfm); + + gf128mul_free_4k(ctx->gf128); +} + +static struct shash_alg polyval_alg =3D { + .digestsize =3D POLYVAL_DIGEST_SIZE, + .init =3D polyval_init, + .update =3D polyval_update, + .final =3D polyval_final, + .setkey =3D polyval_setkey, + .descsize =3D sizeof(struct polyval_desc_ctx), + .base =3D { + .cra_name =3D "polyval", + .cra_driver_name =3D "polyval-generic", + .cra_priority =3D 100, + .cra_blocksize =3D POLYVAL_BLOCK_SIZE, + .cra_ctxsize =3D sizeof(struct polyval_tfm_ctx), + .cra_module =3D THIS_MODULE, + .cra_exit =3D polyval_exit_tfm, + }, +}; + +static int __init polyval_mod_init(void) +{ + return crypto_register_shash(&polyval_alg); +} + +static void __exit polyval_mod_exit(void) +{ + crypto_unregister_shash(&polyval_alg); +} + +subsys_initcall(polyval_mod_init); +module_exit(polyval_mod_exit); + +MODULE_LICENSE("GPL"); +MODULE_DESCRIPTION("POLYVAL hash function"); +MODULE_ALIAS_CRYPTO("polyval"); +MODULE_ALIAS_CRYPTO("polyval-generic"); diff --git a/crypto/tcrypt.c b/crypto/tcrypt.c index da7848f84d12..b358a5141218 100644 --- a/crypto/tcrypt.c +++ b/crypto/tcrypt.c @@ -1924,6 +1924,10 @@ static int do_test(const char *alg, u32 type, u32 ma= sk, int m, u32 num_mb) ret +=3D tcrypt_test("ccm(sm4)"); break; =20 + case 57: + ret +=3D tcrypt_test("polyval"); + break; + case 100: ret +=3D tcrypt_test("hmac(md5)"); break; diff --git a/crypto/testmgr.c b/crypto/testmgr.c index 5acf92354543..a3a24aa07492 100644 --- a/crypto/testmgr.c +++ b/crypto/testmgr.c @@ -5248,6 +5248,12 @@ static const struct alg_test_desc alg_test_descs[] = =3D { .suite =3D { .hash =3D __VECS(poly1305_tv_template) } + }, { + .alg =3D "polyval", + .test =3D alg_test_hash, + .suite =3D { + .hash =3D __VECS(polyval_tv_template) + } }, { .alg =3D "rfc3686(ctr(aes))", .test =3D alg_test_skcipher, diff --git a/crypto/testmgr.h b/crypto/testmgr.h index e1ebbb3c4d4c..da3736e51982 100644 --- a/crypto/testmgr.h +++ b/crypto/testmgr.h @@ -33346,4 +33346,288 @@ static const struct cipher_testvec aes_xctr_tv_te= mplate[] =3D { }, }; =20 +/* + * Test vectors generated using https://github.com/google/hctr2 + */ +static const struct hash_testvec polyval_tv_template[] =3D { + { + .key =3D "\x31\x07\x28\xd9\x91\x1f\x1f\x38" + "\x37\xb2\x43\x16\xc3\xfa\xb9\xa0", + .plaintext =3D "\x65\x78\x61\x6d\x70\x6c\x65\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x48\x65\x6c\x6c\x6f\x20\x77\x6f" + "\x72\x6c\x64\x00\x00\x00\x00\x00" + "\x38\x00\x00\x00\x00\x00\x00\x00" + "\x58\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\xad\x7f\xcf\x0b\x51\x69\x85\x16" + "\x62\x67\x2f\x3c\x5f\x95\x13\x8f", + .psize =3D 48, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .psize =3D 16, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x40\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\xeb\x93\xb7\x74\x09\x62\xc5\xe4" + "\x9d\x2a\x90\xa7\xdc\x5c\xec\x74", + .psize =3D 32, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x60\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\x48\xeb\x6c\x6c\x5a\x2d\xbe\x4a" + "\x1d\xde\x50\x8f\xee\x06\x36\x1b", + .psize =3D 32, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x01\x00\x00\x00\x00\x00\x00", + .digest =3D "\xce\x6e\xdc\x9a\x50\xb3\x6d\x9a" + "\x98\x98\x6b\xbf\x6a\x26\x1c\x3b", + .psize =3D 48, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x03\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x80\x01\x00\x00\x00\x00\x00\x00", + .digest =3D "\x81\x38\x87\x46\xbc\x22\xd2\x6b" + "\x2a\xbc\x3d\xcb\x15\x75\x42\x22", + .psize =3D 64, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x03\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x04\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x02\x00\x00\x00\x00\x00\x00", + .digest =3D "\x1e\x39\xb6\xd3\x34\x4d\x34\x8f" + "\x60\x44\xf8\x99\x35\xd1\xcf\x78", + .psize =3D 80, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x03\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x08\x00\x00\x00\x00\x00\x00\x00" + "\x00\x01\x00\x00\x00\x00\x00\x00", + .digest =3D "\x2c\xe7\xda\xaf\x7c\x89\x49\x08" + "\x22\x05\x12\x55\xb1\x2e\xca\x6b", + .psize =3D 64, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x03\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x04\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x08\x00\x00\x00\x00\x00\x00\x00" + "\x80\x01\x00\x00\x00\x00\x00\x00", + .digest =3D "\x9c\xa9\x87\x71\x5d\x69\xc1\x78" + "\x67\x11\xdf\xcd\x22\xf8\x30\xfc", + .psize =3D 80, + .ksize =3D 16, + }, + { + .key =3D "\xd9\xb3\x60\x27\x96\x94\x94\x1a" + "\xc5\xdb\xc6\x98\x7a\xda\x73\x77", + .plaintext =3D "\x01\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x02\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x03\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x04\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x05\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x08\x00\x00\x00\x00\x00\x00\x00" + "\x00\x02\x00\x00\x00\x00\x00\x00", + .digest =3D "\xff\xcd\x05\xd5\x77\x0f\x34\xad" + "\x92\x67\xf0\xa5\x99\x94\xb1\x5a", + .psize =3D 96, + .ksize =3D 16, + }, + { + .key =3D "\x03\x6e\xe1\xfe\x2d\x79\x26\xaf" + "\x68\x89\x80\x95\xe5\x4e\x7b\x3c", + .plaintext =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .psize =3D 16, + .ksize =3D 16, + }, + { + .key =3D "\x37\x24\xf5\x5f\x1d\x22\xac\x0a" + "\xb8\x30\xda\x0b\x6a\x99\x5d\x74", + .plaintext =3D "\x75\x76\xf7\x02\x8e\xc6\xeb\x5e" + "\xa7\xe2\x98\x34\x2a\x94\xd4\xb2" + "\x02\xb3\x70\xef\x97\x68\xec\x65" + "\x61\xc4\xfe\x6b\x7e\x72\x96\xfa" + "\x85\x9c\x21\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\xe4\x2a\x3c\x02\xc2\x5b\x64\x86" + "\x9e\x14\x6d\x7b\x23\x39\x87\xbd" + "\xdf\xc2\x40\x87\x1d\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x18\x01\x00\x00\x00\x00\x00\x00" + "\xa8\x00\x00\x00\x00\x00\x00\x00", + .digest =3D "\x4c\xbb\xa0\x90\xf0\x3f\x7d\x11" + "\x88\xea\x55\x74\x9f\xa6\xc7\xbd", + .psize =3D 96, + .ksize =3D 16, + }, + { + .key =3D "\x90\xcc\xac\xee\xba\xd7\xd4\x68" + "\x98\xa6\x79\x70\xdf\x66\x15\x6c", + .plaintext =3D "", + .digest =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .psize =3D 0, + .ksize =3D 16, + }, + { + .key =3D "\x89\xc9\x4b\xde\x40\xa6\xf9\x62" + "\x58\x04\x51\x26\xb4\xb1\x14\xe4", + .plaintext =3D "", + .digest =3D "\x00\x00\x00\x00\x00\x00\x00\x00" + "\x00\x00\x00\x00\x00\x00\x00\x00", + .psize =3D 0, + .ksize =3D 16, + }, + { + .key =3D "\x37\xbe\x68\x16\x50\xb9\x4e\xb0" + "\x47\xde\xe2\xbd\xde\xe4\x48\x09", + .plaintext =3D "\x87\xfc\x68\x9f\xff\xf2\x4a\x1e" + "\x82\x3b\x73\x8f\xc1\xb2\x1b\x7a" + "\x6c\x4f\x81\xbc\x88\x9b\x6c\xa3" + "\x9c\xc2\xa5\xbc\x14\x70\x4c\x9b" + "\x0c\x9f\x59\x92\x16\x4b\x91\x3d" + "\x18\x55\x22\x68\x12\x8c\x63\xb2" + "\x51\xcb\x85\x4b\xd2\xae\x0b\x1c" + "\x5d\x28\x9d\x1d\xb1\xc8\xf0\x77" + "\xe9\xb5\x07\x4e\x06\xc8\xee\xf8" + "\x1b\xed\x72\x2a\x55\x7d\x16\xc9" + "\xf2\x54\xe7\xe9\xe0\x44\x5b\x33" + "\xb1\x49\xee\xff\x43\xfb\x82\xcd" + "\x4a\x70\x78\x81\xa4\x34\x36\xe8" + "\x4c\x28\x54\xa6\x6c\xc3\x6b\x78" + "\xe7\xc0\x5d\xc6\x5d\x81\xab\x70" + "\x08\x86\xa1\xfd\xf4\x77\x55\xfd" + "\xa3\xe9\xe2\x1b\xdf\x99\xb7\x80" + "\xf9\x0a\x4f\x72\x4a\xd3\xaf\xbb" + "\xb3\x3b\xeb\x08\x58\x0f\x79\xce" + "\xa5\x99\x05\x12\x34\xd4\xf4\x86" + "\x37\x23\x1d\xc8\x49\xc0\x92\xae" + "\xa6\xac\x9b\x31\x55\xed\x15\xc6" + "\x05\x17\x37\x8d\x90\x42\xe4\x87" + "\x89\x62\x88\x69\x1c\x6a\xfd\xe3" + "\x00\x2b\x47\x1a\x73\xc1\x51\xc2" + "\xc0\x62\x74\x6a\x9e\xb2\xe5\x21" + "\xbe\x90\xb5\xb0\x50\xca\x88\x68" + "\xe1\x9d\x7a\xdf\x6c\xb7\xb9\x98" + "\xee\x28\x62\x61\x8b\xd1\x47\xf9" + "\x04\x7a\x0b\x5d\xcd\x2b\x65\xf5" + "\x12\xa3\xfe\x1a\xaa\x2c\x78\x42" + "\xb8\xbe\x7d\x74\xeb\x59\xba\xba", + .digest =3D "\xae\x11\xd4\x60\x2a\x5f\x9e\x42" + "\x89\x04\xc2\x34\x8d\x55\x94\x0a", + .psize =3D 256, + .ksize =3D 16, + }, + { + .key =3D "\xc8\x53\xde\xaa\xb1\x4b\x6b\xd5" + "\x88\xd6\x4c\xe9\xba\x35\x3d\x5a", + .plaintext =3D "\xc1\xeb\xba\x8d\xb7\x20\x09\xe0" + "\x28\x4f\x29\xf3\xd8\x26\x50\x40" + "\xd9\x06\xa8\xa8\xc0\xbe\xf0\xfb" + "\x75\x7c\x02\x86\x16\x83\x9d\x65" + "\x8f\x5e\xc4\x58\xed\x6a\xb3\x10" + "\xd2\xf7\x23\xc2\x4a\xb0\x00\x6a" + "\x01\x7c\xf7\xf7\x69\x42\xb2\x12" + "\xb0\xeb\x65\x07\xd7\x8e\x2d\x27" + "\x67\xa2\x57\xf0\x49\x0f\x3f\x0e" + "\xc9\xf7\x1b\xe0\x5b\xdd\x87\xfb" + "\x89\xd1\xfa\xb1\x46\xaf\xa2\x93" + "\x01\x65\xb6\x6f\xbe\x29\x7d\x9f" + "\xfa\xf5\x58\xc6\xb5\x92\x55\x25" + "\x4c\xb5\x0c\xc2\x61\x9f\xc4\xb1" + "\x7f\xe3\x61\x18\x3f\x8c\xb2\xd6" + "\xfd\x9f\xd8\xe5\x3d\x03\x05\xa2" + "\x5d\x1a\xa8\xf0\x04\x41\xea\xa6" + "\x07\x67\x86\x00\xe8\x86\xfc\xb1" + "\xc3\x15\x3e\xc8\x84\x2e\x5e\x5f" + "\x7b\x75\x6a\xc4\x48\xb4\xee\x5f" + "\xe9\x76\xdf\xe6\x1a\xd4\x15\x92" + "\x23\x03\x06\xc1\x2d\x0f\x94\xcb" + "\xe6\x5e\x18\xa6\x3b\x38\x1f\xc2" + "\x28\x73\x8a\xbd\x3a\x6f\xb0\x95" + "\x0f\x1c\xc7\xdf\x10\x0b\x2a\x7d" + "\xf9\x6b\xe1\x4a\xfb\xe1\x07\xc9" + "\x69\x7b\x27\x65\xc0\x08\x49\xc0" + "\xf3\x0b\x5b\xa6\x8b\xf7\x1a\xfe" + "\xe3\x9f\x87\x1d\x68\x07\xf4\x53" + "\x8d\x54\xe9\x3f\xd5\x02\x3a\x09" + "\x72\xa9\x84\xdc\x25\xd3\xad\xdb" + "\x4e\x45\x4f\x7f\xe8\x02\x69\x45", + .digest =3D "\x7b\x4f\x29\xb3\x0b\x4d\x2b\xa3" + "\x40\xc8\x56\x5a\x0a\xcf\xbd\x9b", + .psize =3D 256, + .ksize =3D 16, + }, +}; + #endif /* _CRYPTO_TESTMGR_H */ diff --git a/include/crypto/polyval.h b/include/crypto/polyval.h new file mode 100644 index 000000000000..fd0c6e124b65 --- /dev/null +++ b/include/crypto/polyval.h @@ -0,0 +1,22 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * Common values for the Polyval hash algorithm + * + * Copyright 2021 Google LLC + */ + +#ifndef _CRYPTO_POLYVAL_H +#define _CRYPTO_POLYVAL_H + +#include +#include + +#define POLYVAL_BLOCK_SIZE 16 +#define POLYVAL_DIGEST_SIZE 16 + +struct polyval_desc_ctx { + u8 buffer[POLYVAL_BLOCK_SIZE]; + u32 bytes; +}; + +#endif --=20 2.35.0.rc0.227.g00780c9af4-goog From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 3B139C433EF for ; Tue, 25 Jan 2022 01:47:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:Cc:To:From:Subject:References: Mime-Version:Message-Id:In-Reply-To:Date:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=LAMEvcn8HpxNurSyd1OHtxDFp1f+gAM7SgWglkdXNpE=; b=4kmvmxEwcq9HEXpCbUvJXM7MNp D1DzwI8tjiPBuFvnoQktgxm1k/d2Ge2KoEbzSLyRybVorL71j1G5t6yXMXtvhDtyCPsXaKLFiVwhY kDMxIYvFki3g/36skZh42bak0QTTv9m7CGG9PDsVU/pSI7Af+MFmLG/6yEDEEI1BdKMXbHq2qxOCI uBZA0h9r41Y8Tk/tL1mkQvBO3W1y9DvA0fyMlX67MagYXZ4BPg7CtaDmLKtGb7a9LRaiHh0qlrjsD 8MUWjRaYwajS4XAeRWgojz69xL7SYYJiXMM4d0flBl8rMkb6J3p7dGeq3IsedltjEWIWtk+3V6LLe V/Hs3VrQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nCAtu-0066Gn-IL; Tue, 25 Jan 2022 01:45:38 +0000 Received: from mail-ua1-x94a.google.com ([2607:f8b0:4864:20::94a]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nCAtb-0066CE-Fl for linux-arm-kernel@lists.infradead.org; Tue, 25 Jan 2022 01:45:22 +0000 Received: by mail-ua1-x94a.google.com with SMTP id y7-20020ab05607000000b003065444c62dso11336669uaa.13 for ; Mon, 24 Jan 2022 17:45:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc:content-transfer-encoding; bh=A79nkcZwBR0NLt8+NnfzgPYKFdLcz7PnLt3dca6foZw=; b=WSkq+D+gecDAojURQZAiZRJui8bvUQ/90EBrAkv5BlxFU0N1gd/QbMbWdx4J4zmNMo wjmkmi9hPG5hhxGLT7ANm/lMLZMImplGYjknXXGpK7N6JSmgQrRDxf6BRxc3/URSdCdN YqzAfE502cgbVTTnDFD+iy2n3sjnupfwL3Urwd2bpGdolRuNQmw9QgclhEBTAfEHZ4Vt Zax2BGWJBCmNFd+5eXkfEU+oMtmDm8NR5DA/8gHynXPQreIGJZBbBfSJ5ewIYcJ71O7+ 9ydzVj6yMhpUzOdZ0kyZXYCQtcNVvyfjW7ImqccxebHnIXeV50gPLIX/2vQ4I9zWgRY4 sVOw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc:content-transfer-encoding; bh=A79nkcZwBR0NLt8+NnfzgPYKFdLcz7PnLt3dca6foZw=; b=QQBVs7+KcGDIMcBzGRgLOGyWLIFxdfCB05PRW9Bwqo0uA0C1t/F6KppfvizeD6wxQy dNsDGSNB2Iko4bwTJD/4+0XA0nS7FP2DO5IChamtochCc9OPNymQQBMCRng4azDCXeaZ XTgqgqU89Tcsz1t/KFwN5YzxEZgSY/knU3a7dftPN00YcXSrmXlEJKwKrkrRH+BBniXA Dc96KcAf7LMeq9yYBfTvEo9DW3Wv0cdp5rbPsAeHokKkSKO6cgNC3yfObYhkU6cXO079 3Nn/AVSb3OhB35vIfbY6a+jLr2vAeuUuKgreICBthH70Lf42yJ10Yr07Nk58Nk4orwBF 0lhg== X-Gm-Message-State: AOAM5338S2DbykPaM+LmleAwnS+RWBC8Vnc7zFnUL+RrgB5Fu4ZEbd0e rJrfw896/SRXU+Ph0ssVCBYlFxw8RA== X-Google-Smtp-Source: ABdhPJwWasivCuAnDdlKcsFnLRLpKMMy6E8EmA2PPfF47SW0EXUslagzCWHriWl65MLLjyw3kIgx7GL2hg== X-Received: from nhuck.c.googlers.com ([fda3:e722:ac3:cc00:14:4d90:c0a8:39cc]) (user=nhuck job=sendgmr) by 2002:a67:df8e:: with SMTP id x14mr6969862vsk.80.1643075117363; Mon, 24 Jan 2022 17:45:17 -0800 (PST) Date: Mon, 24 Jan 2022 19:44:17 -0600 In-Reply-To: <20220125014422.80552-1-nhuck@google.com> Message-Id: <20220125014422.80552-3-nhuck@google.com> Mime-Version: 1.0 References: <20220125014422.80552-1-nhuck@google.com> X-Mailer: git-send-email 2.35.0.rc0.227.g00780c9af4-goog Subject: [RFC PATCH 2/7] crypto: polyval - Add POLYVAL support From: Nathan Huckleberry To: linux-crypto@vger.kernel.org Cc: Herbert Xu , "David S. Miller" , linux-arm-kernel@lists.infradead.org, Paul Crowley , Eric Biggers , Sami Tolvanen , Nathan Huckleberry X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220124_174519_575860_28FDE023 X-CRM114-Status: GOOD ( 24.74 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org QWRkIHN1cHBvcnQgZm9yIFBPTFlWQUwsIGFuIM61LXVuaXZlcnNhbCBoYXNoIGZ1bmN0aW9uIHNp bWlsYXIgdG8gR0hBU0guClBPTFlWQUwgaXMgdXNlZCBhcyBhIGNvbXBvbmVudCB0byBpbXBsZW1l bnQgSENUUjIgbW9kZS4KClBPTFlWQUwgaXMgaW1wbGVtZW50ZWQgYXMgYW4gc2hhc2ggYWxnb3Jp dGhtLiAgVGhlIGltcGxlbWVudGF0aW9uIGlzCm1vZGlmaWVkIGZyb20gZ2hhc2gtZ2VuZXJpYy5j LgoKTW9yZSBpbmZvcm1hdGlvbiBvbiBQT0xZVkFMIGNhbiBiZSBmb3VuZCBpbiB0aGUgSENUUjIg cGFwZXI6Cmh0dHBzOi8vZXByaW50LmlhY3Iub3JnLzIwMjEvMTQ0MS5wZGYKClNpZ25lZC1vZmYt Ynk6IE5hdGhhbiBIdWNrbGViZXJyeSA8bmh1Y2tAZ29vZ2xlLmNvbT4KLS0tCiBjcnlwdG8vS2Nv bmZpZyAgICAgICAgICAgfCAgIDggKysKIGNyeXB0by9NYWtlZmlsZSAgICAgICAgICB8ICAgMSAr CiBjcnlwdG8vcG9seXZhbC1nZW5lcmljLmMgfCAxODMgKysrKysrKysrKysrKysrKysrKysrKysr KwogY3J5cHRvL3RjcnlwdC5jICAgICAgICAgIHwgICA0ICsKIGNyeXB0by90ZXN0bWdyLmMgICAg ICAgICB8ICAgNiArCiBjcnlwdG8vdGVzdG1nci5oICAgICAgICAgfCAyODQgKysrKysrKysrKysr KysrKysrKysrKysrKysrKysrKysrKysrKysrCiBpbmNsdWRlL2NyeXB0by9wb2x5dmFsLmggfCAg MjIgKysrCiA3IGZpbGVzIGNoYW5nZWQsIDUwOCBpbnNlcnRpb25zKCspCiBjcmVhdGUgbW9kZSAx MDA2NDQgY3J5cHRvL3BvbHl2YWwtZ2VuZXJpYy5jCiBjcmVhdGUgbW9kZSAxMDA2NDQgaW5jbHVk ZS9jcnlwdG8vcG9seXZhbC5oCgpkaWZmIC0tZ2l0IGEvY3J5cHRvL0tjb25maWcgYi9jcnlwdG8v S2NvbmZpZwppbmRleCBiMDBkZTVmMjJlYWYuLjA1MTA2MGNkNWUyMSAxMDA2NDQKLS0tIGEvY3J5 cHRvL0tjb25maWcKKysrIGIvY3J5cHRvL0tjb25maWcKQEAgLTc2MCw2ICs3NjAsMTQgQEAgY29u ZmlnIENSWVBUT19HSEFTSAogCSAgR0hBU0ggaXMgdGhlIGhhc2ggZnVuY3Rpb24gdXNlZCBpbiBH Q00gKEdhbG9pcy9Db3VudGVyIE1vZGUpLgogCSAgSXQgaXMgbm90IGEgZ2VuZXJhbC1wdXJwb3Nl IGNyeXB0b2dyYXBoaWMgaGFzaCBmdW5jdGlvbi4KIAorY29uZmlnIENSWVBUT19QT0xZVkFMCisJ dHJpc3RhdGUKKwlzZWxlY3QgQ1JZUFRPX0dGMTI4TVVMCisJc2VsZWN0IENSWVBUT19IQVNICisJ aGVscAorCSAgUE9MWVZBTCBpcyB0aGUgaGFzaCBmdW5jdGlvbiB1c2VkIGluIEhDVFIyLiAgSXQg aXMgbm90IGEgZ2VuZXJhbC1wdXJwb3NlCisJICBjcnlwdG9ncmFwaGljIGhhc2ggZnVuY3Rpb24u CisKIGNvbmZpZyBDUllQVE9fUE9MWTEzMDUKIAl0cmlzdGF0ZSAiUG9seTEzMDUgYXV0aGVudGlj YXRvciBhbGdvcml0aG0iCiAJc2VsZWN0IENSWVBUT19IQVNICmRpZmYgLS1naXQgYS9jcnlwdG8v TWFrZWZpbGUgYi9jcnlwdG8vTWFrZWZpbGUKaW5kZXggNmIzZmUzZGYxNDg5Li41NjFmOTAxYTkx ZDQgMTAwNjQ0Ci0tLSBhL2NyeXB0by9NYWtlZmlsZQorKysgYi9jcnlwdG8vTWFrZWZpbGUKQEAg LTE2OSw2ICsxNjksNyBAQCBVQlNBTl9TQU5JVElaRV9qaXR0ZXJlbnRyb3B5Lm8gPSBuCiBqaXR0 ZXJlbnRyb3B5X3JuZy15IDo9IGppdHRlcmVudHJvcHkubyBqaXR0ZXJlbnRyb3B5LWtjYXBpLm8K IG9iai0kKENPTkZJR19DUllQVE9fVEVTVCkgKz0gdGNyeXB0Lm8KIG9iai0kKENPTkZJR19DUllQ VE9fR0hBU0gpICs9IGdoYXNoLWdlbmVyaWMubworb2JqLSQoQ09ORklHX0NSWVBUT19QT0xZVkFM KSArPSBwb2x5dmFsLWdlbmVyaWMubwogb2JqLSQoQ09ORklHX0NSWVBUT19VU0VSX0FQSSkgKz0g YWZfYWxnLm8KIG9iai0kKENPTkZJR19DUllQVE9fVVNFUl9BUElfSEFTSCkgKz0gYWxnaWZfaGFz aC5vCiBvYmotJChDT05GSUdfQ1JZUFRPX1VTRVJfQVBJX1NLQ0lQSEVSKSArPSBhbGdpZl9za2Np cGhlci5vCmRpZmYgLS1naXQgYS9jcnlwdG8vcG9seXZhbC1nZW5lcmljLmMgYi9jcnlwdG8vcG9s eXZhbC1nZW5lcmljLmMKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAwMDAwMDAwMDAwLi42 M2U5MDg2OTdlYTAKLS0tIC9kZXYvbnVsbAorKysgYi9jcnlwdG8vcG9seXZhbC1nZW5lcmljLmMK QEAgLTAsMCArMSwxODMgQEAKKy8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBHUEwtMi4wLW9u bHkKKy8qCisgKiBQT0xZVkFMOiBoYXNoIGZ1bmN0aW9uIGZvciBIQ1RSMi4KKyAqCisgKiBDb3B5 cmlnaHQgKGMpIDIwMDcgTm9raWEgU2llbWVucyBOZXR3b3JrcyAtIE1pa2tvIEhlcnJhbmVuIDxt aDFAaWtpLmZpPgorICogQ29weXJpZ2h0IChjKSAyMDA5IEludGVsIENvcnAuCisgKiAgIEF1dGhv cjogSHVhbmcgWWluZyA8eWluZy5odWFuZ0BpbnRlbC5jb20+CisgKiBDb3B5cmlnaHQgMjAyMSBH b29nbGUgTExDCisgKi8KKworLyoKKyAqIENvZGUgYmFzZWQgb24gY3J5cHRvL2doYXNoLWdlbmVy aWMuYworICoKKyAqIFBPTFlWQUwgaXMgYSBrZXllZCBoYXNoIGZ1bmN0aW9uIHNpbWlsYXIgdG8g R0hBU0guIFBPTFlWQUwgdXNlcyBhCisgKiBkaWZmZXJlbnQgbW9kdWx1cyBmb3IgZmluaXRlIGZp ZWxkIG11bHRpcGxpY2F0aW9uIHdoaWNoIG1ha2VzIGhhcmR3YXJlCisgKiBhY2NlbGVyYXRlZCBp bXBsZW1lbnRhdGlvbnMgb24gbGl0dGxlLWVuZGlhbiBtYWNoaW5lcyBmYXN0ZXIuCisgKgorICog TGlrZSBHSEFTSCwgUE9MWVZBTCBpcyBub3QgYSBjcnlwdG9ncmFwaGljIGhhc2ggZnVuY3Rpb24g YW5kIHNob3VsZAorICogbm90IGJlIHVzZWQgb3V0c2lkZSBvZiBjcnlwdG8gbW9kZXMgZXhwbGlj aXRseSBkZXNpZ25lZCB0byB1c2UgUE9MWVZBTC4KKyAqCisgKi8KKworI2luY2x1ZGUgPGFzbS91 bmFsaWduZWQuaD4KKyNpbmNsdWRlIDxjcnlwdG8vYWxnYXBpLmg+CisjaW5jbHVkZSA8Y3J5cHRv L2dmMTI4bXVsLmg+CisjaW5jbHVkZSA8Y3J5cHRvL3BvbHl2YWwuaD4KKyNpbmNsdWRlIDxjcnlw dG8vaW50ZXJuYWwvaGFzaC5oPgorI2luY2x1ZGUgPGxpbnV4L2NyeXB0by5oPgorI2luY2x1ZGUg PGxpbnV4L2luaXQuaD4KKyNpbmNsdWRlIDxsaW51eC9rZXJuZWwuaD4KKyNpbmNsdWRlIDxsaW51 eC9tb2R1bGUuaD4KKworc3RydWN0IHBvbHl2YWxfdGZtX2N0eCB7CisJc3RydWN0IGdmMTI4bXVs XzRrICpnZjEyODsKK307CisKK3N0YXRpYyBpbnQgcG9seXZhbF9pbml0KHN0cnVjdCBzaGFzaF9k ZXNjICpkZXNjKQoreworCXN0cnVjdCBwb2x5dmFsX2Rlc2NfY3R4ICpkY3R4ID0gc2hhc2hfZGVz Y19jdHgoZGVzYyk7CisKKwltZW1zZXQoZGN0eCwgMCwgc2l6ZW9mKCpkY3R4KSk7CisKKwlyZXR1 cm4gMDsKK30KKworc3RhdGljIHZvaWQgcmV2ZXJzZV9ibG9jayh1OCBibG9ja1tQT0xZVkFMX0JM T0NLX1NJWkVdKQoreworCXU2NCAqcDEgPSAodTY0ICopYmxvY2s7CisJdTY0ICpwMiA9ICh1NjQg KikmYmxvY2tbOF07CisJdTY0IGEgPSBnZXRfdW5hbGlnbmVkKHAxKTsKKwl1NjQgYiA9IGdldF91 bmFsaWduZWQocDIpOworCisJcHV0X3VuYWxpZ25lZChzd2FiNjQoYSksIHAyKTsKKwlwdXRfdW5h bGlnbmVkKHN3YWI2NChiKSwgcDEpOworfQorCitzdGF0aWMgaW50IHBvbHl2YWxfc2V0a2V5KHN0 cnVjdCBjcnlwdG9fc2hhc2ggKnRmbSwKKwkJCWNvbnN0IHU4ICprZXksIHVuc2lnbmVkIGludCBr ZXlsZW4pCit7CisJc3RydWN0IHBvbHl2YWxfdGZtX2N0eCAqY3R4ID0gY3J5cHRvX3NoYXNoX2N0 eCh0Zm0pOworCWJlMTI4IGs7CisKKwlpZiAoa2V5bGVuICE9IFBPTFlWQUxfQkxPQ0tfU0laRSkK KwkJcmV0dXJuIC1FSU5WQUw7CisKKwlnZjEyOG11bF9mcmVlXzRrKGN0eC0+Z2YxMjgpOworCisJ QlVJTERfQlVHX09OKHNpemVvZihrKSAhPSBQT0xZVkFMX0JMT0NLX1NJWkUpOworCW1lbWNweSgm aywga2V5LCBQT0xZVkFMX0JMT0NLX1NJWkUpOyAvKiBhdm9pZCB2aW9sYXRpbmcgYWxpZ25tZW50 IHJ1bGVzICovCisKKwlyZXZlcnNlX2Jsb2NrKCh1OCAqKSZrKTsKKwlnZjEyOG11bF94X2xsZSgm aywgJmspOworCisJY3R4LT5nZjEyOCA9IGdmMTI4bXVsX2luaXRfNGtfbGxlKCZrKTsKKwltZW16 ZXJvX2V4cGxpY2l0KCZrLCBQT0xZVkFMX0JMT0NLX1NJWkUpOworCisJaWYgKCFjdHgtPmdmMTI4 KQorCQlyZXR1cm4gLUVOT01FTTsKKworCXJldHVybiAwOworfQorCitzdGF0aWMgaW50IHBvbHl2 YWxfdXBkYXRlKHN0cnVjdCBzaGFzaF9kZXNjICpkZXNjLAorCQkJIGNvbnN0IHU4ICpzcmMsIHVu c2lnbmVkIGludCBzcmNsZW4pCit7CisJc3RydWN0IHBvbHl2YWxfZGVzY19jdHggKmRjdHggPSBz aGFzaF9kZXNjX2N0eChkZXNjKTsKKwljb25zdCBzdHJ1Y3QgcG9seXZhbF90Zm1fY3R4ICpjdHgg PSBjcnlwdG9fc2hhc2hfY3R4KGRlc2MtPnRmbSk7CisJdTggKmRzdCA9IGRjdHgtPmJ1ZmZlcjsK Kwl1OCAqcG9zOworCXU4IHRtcFtQT0xZVkFMX0JMT0NLX1NJWkVdOworCWludCBuOworCisJaWYg KGRjdHgtPmJ5dGVzKSB7CisJCW4gPSBtaW4oc3JjbGVuLCBkY3R4LT5ieXRlcyk7CisJCXBvcyA9 IGRzdCArIGRjdHgtPmJ5dGVzIC0gMTsKKworCQlkY3R4LT5ieXRlcyAtPSBuOworCQlzcmNsZW4g LT0gbjsKKworCQl3aGlsZSAobi0tKQorCQkJKnBvcy0tIF49ICpzcmMrKzsKKworCQlpZiAoIWRj dHgtPmJ5dGVzKQorCQkJZ2YxMjhtdWxfNGtfbGxlKChiZTEyOCAqKWRzdCwgY3R4LT5nZjEyOCk7 CisJfQorCisJd2hpbGUgKHNyY2xlbiA+PSBQT0xZVkFMX0JMT0NLX1NJWkUpIHsKKwkJbWVtY3B5 KHRtcCwgc3JjLCBQT0xZVkFMX0JMT0NLX1NJWkUpOworCQlyZXZlcnNlX2Jsb2NrKHRtcCk7CisJ CWNyeXB0b194b3IoZHN0LCB0bXAsIFBPTFlWQUxfQkxPQ0tfU0laRSk7CisJCWdmMTI4bXVsXzRr X2xsZSgoYmUxMjggKilkc3QsIGN0eC0+Z2YxMjgpOworCQlzcmMgKz0gUE9MWVZBTF9CTE9DS19T SVpFOworCQlzcmNsZW4gLT0gUE9MWVZBTF9CTE9DS19TSVpFOworCX0KKworCWlmIChzcmNsZW4p IHsKKwkJZGN0eC0+Ynl0ZXMgPSBQT0xZVkFMX0JMT0NLX1NJWkUgLSBzcmNsZW47CisJCXBvcyA9 IGRzdCArIFBPTFlWQUxfQkxPQ0tfU0laRSAtIDE7CisJCXdoaWxlIChzcmNsZW4tLSkKKwkJCSpw b3MtLSBePSAqc3JjKys7CisJfQorCisJcmV0dXJuIDA7Cit9CisKK3N0YXRpYyBpbnQgcG9seXZh bF9maW5hbChzdHJ1Y3Qgc2hhc2hfZGVzYyAqZGVzYywgdTggKmRzdCkKK3sKKwlzdHJ1Y3QgcG9s eXZhbF9kZXNjX2N0eCAqZGN0eCA9IHNoYXNoX2Rlc2NfY3R4KGRlc2MpOworCWNvbnN0IHN0cnVj dCBwb2x5dmFsX3RmbV9jdHggKmN0eCA9IGNyeXB0b19zaGFzaF9jdHgoZGVzYy0+dGZtKTsKKwl1 OCAqYnVmID0gZGN0eC0+YnVmZmVyOworCisJaWYgKGRjdHgtPmJ5dGVzKQorCQlnZjEyOG11bF80 a19sbGUoKGJlMTI4ICopZHN0LCBjdHgtPmdmMTI4KTsKKwlkY3R4LT5ieXRlcyA9IDA7CisKKwly ZXZlcnNlX2Jsb2NrKGJ1Zik7CisJbWVtY3B5KGRzdCwgYnVmLCBQT0xZVkFMX0JMT0NLX1NJWkUp OworCisJcmV0dXJuIDA7Cit9CisKK3N0YXRpYyB2b2lkIHBvbHl2YWxfZXhpdF90Zm0oc3RydWN0 IGNyeXB0b190Zm0gKnRmbSkKK3sKKwlzdHJ1Y3QgcG9seXZhbF90Zm1fY3R4ICpjdHggPSBjcnlw dG9fdGZtX2N0eCh0Zm0pOworCisJZ2YxMjhtdWxfZnJlZV80ayhjdHgtPmdmMTI4KTsKK30KKwor c3RhdGljIHN0cnVjdCBzaGFzaF9hbGcgcG9seXZhbF9hbGcgPSB7CisJLmRpZ2VzdHNpemUJPSBQ T0xZVkFMX0RJR0VTVF9TSVpFLAorCS5pbml0CQk9IHBvbHl2YWxfaW5pdCwKKwkudXBkYXRlCQk9 IHBvbHl2YWxfdXBkYXRlLAorCS5maW5hbAkJPSBwb2x5dmFsX2ZpbmFsLAorCS5zZXRrZXkJCT0g cG9seXZhbF9zZXRrZXksCisJLmRlc2NzaXplCT0gc2l6ZW9mKHN0cnVjdCBwb2x5dmFsX2Rlc2Nf Y3R4KSwKKwkuYmFzZQkJPSB7CisJCS5jcmFfbmFtZQkJPSAicG9seXZhbCIsCisJCS5jcmFfZHJp dmVyX25hbWUJPSAicG9seXZhbC1nZW5lcmljIiwKKwkJLmNyYV9wcmlvcml0eQkJPSAxMDAsCisJ CS5jcmFfYmxvY2tzaXplCQk9IFBPTFlWQUxfQkxPQ0tfU0laRSwKKwkJLmNyYV9jdHhzaXplCQk9 IHNpemVvZihzdHJ1Y3QgcG9seXZhbF90Zm1fY3R4KSwKKwkJLmNyYV9tb2R1bGUJCT0gVEhJU19N T0RVTEUsCisJCS5jcmFfZXhpdAkJPSBwb2x5dmFsX2V4aXRfdGZtLAorCX0sCit9OworCitzdGF0 aWMgaW50IF9faW5pdCBwb2x5dmFsX21vZF9pbml0KHZvaWQpCit7CisJcmV0dXJuIGNyeXB0b19y ZWdpc3Rlcl9zaGFzaCgmcG9seXZhbF9hbGcpOworfQorCitzdGF0aWMgdm9pZCBfX2V4aXQgcG9s eXZhbF9tb2RfZXhpdCh2b2lkKQoreworCWNyeXB0b191bnJlZ2lzdGVyX3NoYXNoKCZwb2x5dmFs X2FsZyk7Cit9CisKK3N1YnN5c19pbml0Y2FsbChwb2x5dmFsX21vZF9pbml0KTsKK21vZHVsZV9l eGl0KHBvbHl2YWxfbW9kX2V4aXQpOworCitNT0RVTEVfTElDRU5TRSgiR1BMIik7CitNT0RVTEVf REVTQ1JJUFRJT04oIlBPTFlWQUwgaGFzaCBmdW5jdGlvbiIpOworTU9EVUxFX0FMSUFTX0NSWVBU TygicG9seXZhbCIpOworTU9EVUxFX0FMSUFTX0NSWVBUTygicG9seXZhbC1nZW5lcmljIik7CmRp ZmYgLS1naXQgYS9jcnlwdG8vdGNyeXB0LmMgYi9jcnlwdG8vdGNyeXB0LmMKaW5kZXggZGE3ODQ4 Zjg0ZDEyLi5iMzU4YTUxNDEyMTggMTAwNjQ0Ci0tLSBhL2NyeXB0by90Y3J5cHQuYworKysgYi9j cnlwdG8vdGNyeXB0LmMKQEAgLTE5MjQsNiArMTkyNCwxMCBAQCBzdGF0aWMgaW50IGRvX3Rlc3Qo Y29uc3QgY2hhciAqYWxnLCB1MzIgdHlwZSwgdTMyIG1hc2ssIGludCBtLCB1MzIgbnVtX21iKQog CQlyZXQgKz0gdGNyeXB0X3Rlc3QoImNjbShzbTQpIik7CiAJCWJyZWFrOwogCisJY2FzZSA1NzoK KwkJcmV0ICs9IHRjcnlwdF90ZXN0KCJwb2x5dmFsIik7CisJCWJyZWFrOworCiAJY2FzZSAxMDA6 CiAJCXJldCArPSB0Y3J5cHRfdGVzdCgiaG1hYyhtZDUpIik7CiAJCWJyZWFrOwpkaWZmIC0tZ2l0 IGEvY3J5cHRvL3Rlc3RtZ3IuYyBiL2NyeXB0by90ZXN0bWdyLmMKaW5kZXggNWFjZjkyMzU0NTQz Li5hM2EyNGFhMDc0OTIgMTAwNjQ0Ci0tLSBhL2NyeXB0by90ZXN0bWdyLmMKKysrIGIvY3J5cHRv L3Rlc3RtZ3IuYwpAQCAtNTI0OCw2ICs1MjQ4LDEyIEBAIHN0YXRpYyBjb25zdCBzdHJ1Y3QgYWxn X3Rlc3RfZGVzYyBhbGdfdGVzdF9kZXNjc1tdID0gewogCQkuc3VpdGUgPSB7CiAJCQkuaGFzaCA9 IF9fVkVDUyhwb2x5MTMwNV90dl90ZW1wbGF0ZSkKIAkJfQorCX0sIHsKKwkJLmFsZyA9ICJwb2x5 dmFsIiwKKwkJLnRlc3QgPSBhbGdfdGVzdF9oYXNoLAorCQkuc3VpdGUgPSB7CisJCQkuaGFzaCA9 IF9fVkVDUyhwb2x5dmFsX3R2X3RlbXBsYXRlKQorCQl9CiAJfSwgewogCQkuYWxnID0gInJmYzM2 ODYoY3RyKGFlcykpIiwKIAkJLnRlc3QgPSBhbGdfdGVzdF9za2NpcGhlciwKZGlmZiAtLWdpdCBh L2NyeXB0by90ZXN0bWdyLmggYi9jcnlwdG8vdGVzdG1nci5oCmluZGV4IGUxZWJiYjNjNGQ0Yy4u ZGEzNzM2ZTUxOTgyIDEwMDY0NAotLS0gYS9jcnlwdG8vdGVzdG1nci5oCisrKyBiL2NyeXB0by90 ZXN0bWdyLmgKQEAgLTMzMzQ2LDQgKzMzMzQ2LDI4OCBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IGNp cGhlcl90ZXN0dmVjIGFlc194Y3RyX3R2X3RlbXBsYXRlW10gPSB7CiAJfSwKIH07CiAKKy8qCisg KiBUZXN0IHZlY3RvcnMgZ2VuZXJhdGVkIHVzaW5nIGh0dHBzOi8vZ2l0aHViLmNvbS9nb29nbGUv aGN0cjIKKyAqLworc3RhdGljIGNvbnN0IHN0cnVjdCBoYXNoX3Rlc3R2ZWMgcG9seXZhbF90dl90 ZW1wbGF0ZVtdID0geworCXsKKwkJLmtleQk9ICJceDMxXHgwN1x4MjhceGQ5XHg5MVx4MWZceDFm XHgzOCIKKwkJCSAgIlx4MzdceGIyXHg0M1x4MTZceGMzXHhmYVx4YjlceGEwIiwKKwkJLnBsYWlu dGV4dAk9ICJceDY1XHg3OFx4NjFceDZkXHg3MFx4NmNceDY1XHgwMCIKKwkJCSAgIlx4MDBceDAw XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHg0OFx4NjVceDZjXHg2Y1x4NmZceDIw XHg3N1x4NmYiCisJCQkgICJceDcyXHg2Y1x4NjRceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAg Ilx4MzhceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHg1OFx4MDBceDAwXHgw MFx4MDBceDAwXHgwMFx4MDAiLAorCQkuZGlnZXN0CT0gIlx4YWRceDdmXHhjZlx4MGJceDUxXHg2 OVx4ODVceDE2IgorCQkJICAiXHg2Mlx4NjdceDJmXHgzY1x4NWZceDk1XHgxM1x4OGYiLAorCQku cHNpemUJPSA0OCwKKwkJLmtzaXplCT0gMTYsCisJfSwKKwl7CisJCS5rZXkJPSAiXHhkOVx4YjNc eDYwXHgyN1x4OTZceDk0XHg5NFx4MWEiCisJCQkgICJceGM1XHhkYlx4YzZceDk4XHg3YVx4ZGFc eDczXHg3NyIsCisJCS5wbGFpbnRleHQJPSAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4 MDAiCisJCQkgICJceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJ PSAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgwMFx4MDBc eDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5wc2l6ZQk9IDE2LAorCQkua3NpemUJPSAxNiwKKwl9 LAorCXsKKwkJLmtleQk9ICJceGQ5XHhiM1x4NjBceDI3XHg5Nlx4OTRceDk0XHgxYSIKKwkJCSAg Ilx4YzVceGRiXHhjNlx4OThceDdhXHhkYVx4NzNceDc3IiwKKwkJLnBsYWludGV4dAk9ICJceDAx XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAw XHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJ CQkgICJceDQwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJPSAiXHhl Ylx4OTNceGI3XHg3NFx4MDlceDYyXHhjNVx4ZTQiCisJCQkgICJceDlkXHgyYVx4OTBceGE3XHhk Y1x4NWNceGVjXHg3NCIsCisJCS5wc2l6ZQk9IDMyLAorCQkua3NpemUJPSAxNiwKKwl9LAorCXsK KwkJLmtleQk9ICJceGQ5XHhiM1x4NjBceDI3XHg5Nlx4OTRceDk0XHgxYSIKKwkJCSAgIlx4YzVc eGRiXHhjNlx4OThceDdhXHhkYVx4NzNceDc3IiwKKwkJLnBsYWludGV4dAk9ICJceDAxXHgwMFx4 MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4 MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJc eDYwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJPSAiXHg0OFx4ZWJc eDZjXHg2Y1x4NWFceDJkXHhiZVx4NGEiCisJCQkgICJceDFkXHhkZVx4NTBceDhmXHhlZVx4MDZc eDM2XHgxYiIsCisJCS5wc2l6ZQk9IDMyLAorCQkua3NpemUJPSAxNiwKKwl9LAorCXsKKwkJLmtl eQk9ICJceGQ5XHhiM1x4NjBceDI3XHg5Nlx4OTRceDk0XHgxYSIKKwkJCSAgIlx4YzVceGRiXHhj Nlx4OThceDdhXHhkYVx4NzNceDc3IiwKKwkJLnBsYWludGV4dAk9ICJceDAxXHgwMFx4MDBceDAw XHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAw IgorCQkJICAiXHgwMlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgw MFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgw MFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDFceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiLAorCQku ZGlnZXN0CT0gIlx4Y2VceDZlXHhkY1x4OWFceDUwXHhiM1x4NmRceDlhIgorCQkJICAiXHg5OFx4 OThceDZiXHhiZlx4NmFceDI2XHgxY1x4M2IiLAorCQkucHNpemUJPSA0OCwKKwkJLmtzaXplCT0g MTYsCisJfSwKKwl7CisJCS5rZXkJPSAiXHhkOVx4YjNceDYwXHgyN1x4OTZceDk0XHg5NFx4MWEi CisJCQkgICJceGM1XHhkYlx4YzZceDk4XHg3YVx4ZGFceDczXHg3NyIsCisJCS5wbGFpbnRleHQJ PSAiXHgwMVx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgwMFx4MDBc eDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDJceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBc eDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAz XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAw XHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJ CQkgICJceDgwXHgwMVx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJPSAiXHg4 MVx4MzhceDg3XHg0Nlx4YmNceDIyXHhkMlx4NmIiCisJCQkgICJceDJhXHhiY1x4M2RceGNiXHgx NVx4NzVceDQyXHgyMiIsCisJCS5wc2l6ZQk9IDY0LAorCQkua3NpemUJPSAxNiwKKwl9LAorCXsK KwkJLmtleQk9ICJceGQ5XHhiM1x4NjBceDI3XHg5Nlx4OTRceDk0XHgxYSIKKwkJCSAgIlx4YzVc eGRiXHhjNlx4OThceDdhXHhkYVx4NzNceDc3IiwKKwkJLnBsYWludGV4dAk9ICJceDAxXHgwMFx4 MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4 MDBceDAwIgorCQkJICAiXHgwMlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJc eDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDNceDAwXHgwMFx4MDBc eDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAi CisJCQkgICJceDA0XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAw XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAw XHgwMFx4MDAiCisJCQkgICJceDAwXHgwMlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5k aWdlc3QJPSAiXHgxZVx4MzlceGI2XHhkM1x4MzRceDRkXHgzNFx4OGYiCisJCQkgICJceDYwXHg0 NFx4ZjhceDk5XHgzNVx4ZDFceGNmXHg3OCIsCisJCS5wc2l6ZQk9IDgwLAorCQkua3NpemUJPSAx NiwKKwl9LAorCXsKKwkJLmtleQk9ICJceGQ5XHhiM1x4NjBceDI3XHg5Nlx4OTRceDk0XHgxYSIK KwkJCSAgIlx4YzVceGRiXHhjNlx4OThceDdhXHhkYVx4NzNceDc3IiwKKwkJLnBsYWludGV4dAk9 ICJceDAxXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4 MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4 MDAiCisJCQkgICJceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDNc eDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBc eDAwXHgwMFx4MDAiCisJCQkgICJceDA4XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJ CSAgIlx4MDBceDAxXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIiwKKwkJLmRpZ2VzdAk9ICJceDJj XHhlN1x4ZGFceGFmXHg3Y1x4ODlceDQ5XHgwOCIKKwkJCSAgIlx4MjJceDA1XHgxMlx4NTVceGIx XHgyZVx4Y2FceDZiIiwKKwkJLnBzaXplCT0gNjQsCisJCS5rc2l6ZQk9IDE2LAorCX0sCisJewor CQkua2V5CT0gIlx4ZDlceGIzXHg2MFx4MjdceDk2XHg5NFx4OTRceDFhIgorCQkJICAiXHhjNVx4 ZGJceGM2XHg5OFx4N2FceGRhXHg3M1x4NzciLAorCQkucGxhaW50ZXh0CT0gIlx4MDFceDAwXHgw MFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgw MFx4MDAiCisJCQkgICJceDAyXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4 MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwM1x4MDBceDAwXHgwMFx4 MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIK KwkJCSAgIlx4MDRceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBc eDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDA4XHgwMFx4MDBceDAwXHgwMFx4MDBc eDAwXHgwMCIKKwkJCSAgIlx4ODBceDAxXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIiwKKwkJLmRp Z2VzdAk9ICJceDljXHhhOVx4ODdceDcxXHg1ZFx4NjlceGMxXHg3OCIKKwkJCSAgIlx4NjdceDEx XHhkZlx4Y2RceDIyXHhmOFx4MzBceGZjIiwKKwkJLnBzaXplCT0gODAsCisJCS5rc2l6ZQk9IDE2 LAorCX0sCisJeworCQkua2V5CT0gIlx4ZDlceGIzXHg2MFx4MjdceDk2XHg5NFx4OTRceDFhIgor CQkJICAiXHhjNVx4ZGJceGM2XHg5OFx4N2FceGRhXHg3M1x4NzciLAorCQkucGxhaW50ZXh0CT0g Ilx4MDFceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAwXHgw MFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAyXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgw MCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwM1x4 MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgwMFx4MDBceDAwXHgwMFx4 MDBceDAwXHgwMCIKKwkJCSAgIlx4MDRceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJ ICAiXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDA1XHgwMFx4MDBc eDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBc eDAwIgorCQkJICAiXHgwOFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAw XHgwMlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJPSAiXHhmZlx4Y2RceDA1 XHhkNVx4NzdceDBmXHgzNFx4YWQiCisJCQkgICJceDkyXHg2N1x4ZjBceGE1XHg5OVx4OTRceGIx XHg1YSIsCisJCS5wc2l6ZQk9IDk2LAorCQkua3NpemUJPSAxNiwKKwl9LAorCXsKKwkJLmtleQk9 ICJceDAzXHg2ZVx4ZTFceGZlXHgyZFx4NzlceDI2XHhhZiIKKwkJCSAgIlx4NjhceDg5XHg4MFx4 OTVceGU1XHg0ZVx4N2JceDNjIiwKKwkJLnBsYWludGV4dAk9ICJceDAwXHgwMFx4MDBceDAwXHgw MFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIiwK KwkJLmRpZ2VzdAk9ICJceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4 MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIiwKKwkJLnBzaXplCT0gMTYsCisJCS5rc2l6 ZQk9IDE2LAorCX0sCisJeworCQkua2V5CT0gIlx4MzdceDI0XHhmNVx4NWZceDFkXHgyMlx4YWNc eDBhIgorCQkJICAiXHhiOFx4MzBceGRhXHgwYlx4NmFceDk5XHg1ZFx4NzQiLAorCQkucGxhaW50 ZXh0CT0gIlx4NzVceDc2XHhmN1x4MDJceDhlXHhjNlx4ZWJceDVlIgorCQkJICAiXHhhN1x4ZTJc eDk4XHgzNFx4MmFceDk0XHhkNFx4YjIiCisJCQkgICJceDAyXHhiM1x4NzBceGVmXHg5N1x4Njhc eGVjXHg2NSIKKwkJCSAgIlx4NjFceGM0XHhmZVx4NmJceDdlXHg3Mlx4OTZceGZhIgorCQkJICAi XHg4NVx4OWNceDIxXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkgICJceDAwXHgwMFx4MDBceDAw XHgwMFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4ZTRceDJhXHgzY1x4MDJceGMyXHg1Ylx4NjRceDg2 IgorCQkJICAiXHg5ZVx4MTRceDZkXHg3Ylx4MjNceDM5XHg4N1x4YmQiCisJCQkgICJceGRmXHhj Mlx4NDBceDg3XHgxZFx4MDBceDAwXHgwMCIKKwkJCSAgIlx4MDBceDAwXHgwMFx4MDBceDAwXHgw MFx4MDBceDAwIgorCQkJICAiXHgxOFx4MDFceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiCisJCQkg ICJceGE4XHgwMFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMCIsCisJCS5kaWdlc3QJPSAiXHg0Y1x4 YmJceGEwXHg5MFx4ZjBceDNmXHg3ZFx4MTEiCisJCQkgICJceDg4XHhlYVx4NTVceDc0XHg5Zlx4 YTZceGM3XHhiZCIsCisJCS5wc2l6ZQk9IDk2LAorCQkua3NpemUJPSAxNiwKKwl9LAorCXsKKwkJ LmtleQk9ICJceDkwXHhjY1x4YWNceGVlXHhiYVx4ZDdceGQ0XHg2OCIKKwkJCSAgIlx4OThceGE2 XHg3OVx4NzBceGRmXHg2Nlx4MTVceDZjIiwKKwkJLnBsYWludGV4dAk9ICIiLAorCQkuZGlnZXN0 CT0gIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgwMFx4MDBceDAw XHgwMFx4MDBceDAwXHgwMFx4MDAiLAorCQkucHNpemUJPSAwLAorCQkua3NpemUJPSAxNiwKKwl9 LAorCXsKKwkJLmtleQk9ICJceDg5XHhjOVx4NGJceGRlXHg0MFx4YTZceGY5XHg2MiIKKwkJCSAg Ilx4NThceDA0XHg1MVx4MjZceGI0XHhiMVx4MTRceGU0IiwKKwkJLnBsYWludGV4dAk9ICIiLAor CQkuZGlnZXN0CT0gIlx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDBceDAwIgorCQkJICAiXHgw MFx4MDBceDAwXHgwMFx4MDBceDAwXHgwMFx4MDAiLAorCQkucHNpemUJPSAwLAorCQkua3NpemUJ PSAxNiwKKwl9LAorCXsKKwkJLmtleQk9ICJceDM3XHhiZVx4NjhceDE2XHg1MFx4YjlceDRlXHhi MCIKKwkJCSAgIlx4NDdceGRlXHhlMlx4YmRceGRlXHhlNFx4NDhceDA5IiwKKwkJLnBsYWludGV4 dAk9ICJceDg3XHhmY1x4NjhceDlmXHhmZlx4ZjJceDRhXHgxZSIKKwkJCSAgIlx4ODJceDNiXHg3 M1x4OGZceGMxXHhiMlx4MWJceDdhIgorCQkJICAiXHg2Y1x4NGZceDgxXHhiY1x4ODhceDliXHg2 Y1x4YTMiCisJCQkgICJceDljXHhjMlx4YTVceGJjXHgxNFx4NzBceDRjXHg5YiIKKwkJCSAgIlx4 MGNceDlmXHg1OVx4OTJceDE2XHg0Ylx4OTFceDNkIgorCQkJICAiXHgxOFx4NTVceDIyXHg2OFx4 MTJceDhjXHg2M1x4YjIiCisJCQkgICJceDUxXHhjYlx4ODVceDRiXHhkMlx4YWVceDBiXHgxYyIK KwkJCSAgIlx4NWRceDI4XHg5ZFx4MWRceGIxXHhjOFx4ZjBceDc3IgorCQkJICAiXHhlOVx4YjVc eDA3XHg0ZVx4MDZceGM4XHhlZVx4ZjgiCisJCQkgICJceDFiXHhlZFx4NzJceDJhXHg1NVx4N2Rc eDE2XHhjOSIKKwkJCSAgIlx4ZjJceDU0XHhlN1x4ZTlceGUwXHg0NFx4NWJceDMzIgorCQkJICAi XHhiMVx4NDlceGVlXHhmZlx4NDNceGZiXHg4Mlx4Y2QiCisJCQkgICJceDRhXHg3MFx4NzhceDgx XHhhNFx4MzRceDM2XHhlOCIKKwkJCSAgIlx4NGNceDI4XHg1NFx4YTZceDZjXHhjM1x4NmJceDc4 IgorCQkJICAiXHhlN1x4YzBceDVkXHhjNlx4NWRceDgxXHhhYlx4NzAiCisJCQkgICJceDA4XHg4 Nlx4YTFceGZkXHhmNFx4NzdceDU1XHhmZCIKKwkJCSAgIlx4YTNceGU5XHhlMlx4MWJceGRmXHg5 OVx4YjdceDgwIgorCQkJICAiXHhmOVx4MGFceDRmXHg3Mlx4NGFceGQzXHhhZlx4YmIiCisJCQkg ICJceGIzXHgzYlx4ZWJceDA4XHg1OFx4MGZceDc5XHhjZSIKKwkJCSAgIlx4YTVceDk5XHgwNVx4 MTJceDM0XHhkNFx4ZjRceDg2IgorCQkJICAiXHgzN1x4MjNceDFkXHhjOFx4NDlceGMwXHg5Mlx4 YWUiCisJCQkgICJceGE2XHhhY1x4OWJceDMxXHg1NVx4ZWRceDE1XHhjNiIKKwkJCSAgIlx4MDVc eDE3XHgzN1x4OGRceDkwXHg0Mlx4ZTRceDg3IgorCQkJICAiXHg4OVx4NjJceDg4XHg2OVx4MWNc eDZhXHhmZFx4ZTMiCisJCQkgICJceDAwXHgyYlx4NDdceDFhXHg3M1x4YzFceDUxXHhjMiIKKwkJ CSAgIlx4YzBceDYyXHg3NFx4NmFceDllXHhiMlx4ZTVceDIxIgorCQkJICAiXHhiZVx4OTBceGI1 XHhiMFx4NTBceGNhXHg4OFx4NjgiCisJCQkgICJceGUxXHg5ZFx4N2FceGRmXHg2Y1x4YjdceGI5 XHg5OCIKKwkJCSAgIlx4ZWVceDI4XHg2Mlx4NjFceDhiXHhkMVx4NDdceGY5IgorCQkJICAiXHgw NFx4N2FceDBiXHg1ZFx4Y2RceDJiXHg2NVx4ZjUiCisJCQkgICJceDEyXHhhM1x4ZmVceDFhXHhh YVx4MmNceDc4XHg0MiIKKwkJCSAgIlx4YjhceGJlXHg3ZFx4NzRceGViXHg1OVx4YmFceGJhIiwK KwkJLmRpZ2VzdAk9ICJceGFlXHgxMVx4ZDRceDYwXHgyYVx4NWZceDllXHg0MiIKKwkJCSAgIlx4 ODlceDA0XHhjMlx4MzRceDhkXHg1NVx4OTRceDBhIiwKKwkJLnBzaXplCT0gMjU2LAorCQkua3Np emUJPSAxNiwKKwl9LAorCXsKKwkJLmtleQk9ICJceGM4XHg1M1x4ZGVceGFhXHhiMVx4NGJceDZi XHhkNSIKKwkJCSAgIlx4ODhceGQ2XHg0Y1x4ZTlceGJhXHgzNVx4M2RceDVhIiwKKwkJLnBsYWlu dGV4dAk9ICJceGMxXHhlYlx4YmFceDhkXHhiN1x4MjBceDA5XHhlMCIKKwkJCSAgIlx4MjhceDRm XHgyOVx4ZjNceGQ4XHgyNlx4NTBceDQwIgorCQkJICAiXHhkOVx4MDZceGE4XHhhOFx4YzBceGJl XHhmMFx4ZmIiCisJCQkgICJceDc1XHg3Y1x4MDJceDg2XHgxNlx4ODNceDlkXHg2NSIKKwkJCSAg Ilx4OGZceDVlXHhjNFx4NThceGVkXHg2YVx4YjNceDEwIgorCQkJICAiXHhkMlx4ZjdceDIzXHhj Mlx4NGFceGIwXHgwMFx4NmEiCisJCQkgICJceDAxXHg3Y1x4ZjdceGY3XHg2OVx4NDJceGIyXHgx MiIKKwkJCSAgIlx4YjBceGViXHg2NVx4MDdceGQ3XHg4ZVx4MmRceDI3IgorCQkJICAiXHg2N1x4 YTJceDU3XHhmMFx4NDlceDBmXHgzZlx4MGUiCisJCQkgICJceGM5XHhmN1x4MWJceGUwXHg1Ylx4 ZGRceDg3XHhmYiIKKwkJCSAgIlx4ODlceGQxXHhmYVx4YjFceDQ2XHhhZlx4YTJceDkzIgorCQkJ ICAiXHgwMVx4NjVceGI2XHg2Zlx4YmVceDI5XHg3ZFx4OWYiCisJCQkgICJceGZhXHhmNVx4NThc eGM2XHhiNVx4OTJceDU1XHgyNSIKKwkJCSAgIlx4NGNceGI1XHgwY1x4YzJceDYxXHg5Zlx4YzRc eGIxIgorCQkJICAiXHg3Zlx4ZTNceDYxXHgxOFx4M2ZceDhjXHhiMlx4ZDYiCisJCQkgICJceGZk XHg5Zlx4ZDhceGU1XHgzZFx4MDNceDA1XHhhMiIKKwkJCSAgIlx4NWRceDFhXHhhOFx4ZjBceDA0 XHg0MVx4ZWFceGE2IgorCQkJICAiXHgwN1x4NjdceDg2XHgwMFx4ZThceDg2XHhmY1x4YjEiCisJ CQkgICJceGMzXHgxNVx4M2VceGM4XHg4NFx4MmVceDVlXHg1ZiIKKwkJCSAgIlx4N2JceDc1XHg2 YVx4YzRceDQ4XHhiNFx4ZWVceDVmIgorCQkJICAiXHhlOVx4NzZceGRmXHhlNlx4MWFceGQ0XHgx NVx4OTIiCisJCQkgICJceDIzXHgwM1x4MDZceGMxXHgyZFx4MGZceDk0XHhjYiIKKwkJCSAgIlx4 ZTZceDVlXHgxOFx4YTZceDNiXHgzOFx4MWZceGMyIgorCQkJICAiXHgyOFx4NzNceDhhXHhiZFx4 M2FceDZmXHhiMFx4OTUiCisJCQkgICJceDBmXHgxY1x4YzdceGRmXHgxMFx4MGJceDJhXHg3ZCIK KwkJCSAgIlx4ZjlceDZiXHhlMVx4NGFceGZiXHhlMVx4MDdceGM5IgorCQkJICAiXHg2OVx4N2Jc eDI3XHg2NVx4YzBceDA4XHg0OVx4YzAiCisJCQkgICJceGYzXHgwYlx4NWJceGE2XHg4Ylx4Zjdc eDFhXHhmZSIKKwkJCSAgIlx4ZTNceDlmXHg4N1x4MWRceDY4XHgwN1x4ZjRceDUzIgorCQkJICAi XHg4ZFx4NTRceGU5XHgzZlx4ZDVceDAyXHgzYVx4MDkiCisJCQkgICJceDcyXHhhOVx4ODRceGRj XHgyNVx4ZDNceGFkXHhkYiIKKwkJCSAgIlx4NGVceDQ1XHg0Zlx4N2ZceGU4XHgwMlx4NjlceDQ1 IiwKKwkJLmRpZ2VzdAk9ICJceDdiXHg0Zlx4MjlceGIzXHgwYlx4NGRceDJiXHhhMyIKKwkJCSAg Ilx4NDBceGM4XHg1Nlx4NWFceDBhXHhjZlx4YmRceDliIiwKKwkJLnBzaXplCT0gMjU2LAorCQku a3NpemUJPSAxNiwKKwl9LAorfTsKKwogI2VuZGlmCS8qIF9DUllQVE9fVEVTVE1HUl9IICovCmRp ZmYgLS1naXQgYS9pbmNsdWRlL2NyeXB0by9wb2x5dmFsLmggYi9pbmNsdWRlL2NyeXB0by9wb2x5 dmFsLmgKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAwMDAwMDAwMDAwLi5mZDBjNmUxMjRi NjUKLS0tIC9kZXYvbnVsbAorKysgYi9pbmNsdWRlL2NyeXB0by9wb2x5dmFsLmgKQEAgLTAsMCAr MSwyMiBAQAorLyogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEdQTC0yLjAgKi8KKy8qCisgKiBD b21tb24gdmFsdWVzIGZvciB0aGUgUG9seXZhbCBoYXNoIGFsZ29yaXRobQorICoKKyAqIENvcHly aWdodCAyMDIxIEdvb2dsZSBMTEMKKyAqLworCisjaWZuZGVmIF9DUllQVE9fUE9MWVZBTF9ICisj ZGVmaW5lIF9DUllQVE9fUE9MWVZBTF9ICisKKyNpbmNsdWRlIDxsaW51eC90eXBlcy5oPgorI2lu Y2x1ZGUgPGxpbnV4L2NyeXB0by5oPgorCisjZGVmaW5lIFBPTFlWQUxfQkxPQ0tfU0laRQkxNgor I2RlZmluZSBQT0xZVkFMX0RJR0VTVF9TSVpFCTE2CisKK3N0cnVjdCBwb2x5dmFsX2Rlc2NfY3R4 IHsKKwl1OCBidWZmZXJbUE9MWVZBTF9CTE9DS19TSVpFXTsKKwl1MzIgYnl0ZXM7Cit9OworCisj ZW5kaWYKLS0gCjIuMzUuMC5yYzAuMjI3LmcwMDc4MGM5YWY0LWdvb2cKCgpfX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1hcm0ta2VybmVsIG1haWxp bmcgbGlzdApsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xpc3Rz LmluZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51eC1hcm0ta2VybmVsCg==