From 4714f5834dd91bac4342b20277423b68242286d3 Mon Sep 17 00:00:00 2001 From: Dmitry Baryshkov Date: Mon, 13 Apr 2020 17:54:28 +0300 Subject: gost: import _nettle_write_le32 to stop using Nettle's internal symbol Remove another dependency on nettle internal symbol by vendoring in _nettle_write_le32 code Signed-off-by: Dmitry Baryshkov --- lib/nettle/Makefile.am | 2 +- lib/nettle/gost/nettle-write.h | 3 ++ lib/nettle/gost/write-le32.c | 69 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 73 insertions(+), 1 deletion(-) create mode 100644 lib/nettle/gost/write-le32.c diff --git a/lib/nettle/Makefile.am b/lib/nettle/Makefile.am index dcca3caaec..b54568846b 100644 --- a/lib/nettle/Makefile.am +++ b/lib/nettle/Makefile.am @@ -73,7 +73,7 @@ endif if ENABLE_GOST libcrypto_la_SOURCES += \ - gost/nettle-write.h \ + gost/nettle-write.h gost/write-le32.c \ gost/gost28147.c gost/gost28147.h gost/gost-wrap.c \ gost/gosthash94.c gost/gosthash94.h gost/gosthash94-meta.c \ gost/streebog.c gost/streebog.h gost/streebog-meta.c \ diff --git a/lib/nettle/gost/nettle-write.h b/lib/nettle/gost/nettle-write.h index f3d2b74112..ca0c0843eb 100644 --- a/lib/nettle/gost/nettle-write.h +++ b/lib/nettle/gost/nettle-write.h @@ -45,13 +45,16 @@ /* FIXME: Use a macro shortcut to memcpy for native endianness. */ void +#define _nettle_write_be32 _gnutls_nettle_ecc_write_be32 _nettle_write_be32(size_t length, uint8_t *dst, const uint32_t *src); void +#define _nettle_write_le32 _gnutls_nettle_ecc_write_le32 _nettle_write_le32(size_t length, uint8_t *dst, const uint32_t *src); void +#define _nettle_write_le64 _gnutls_nettle_ecc_write_le64 _nettle_write_le64(size_t length, uint8_t *dst, const uint64_t *src); diff --git a/lib/nettle/gost/write-le32.c b/lib/nettle/gost/write-le32.c new file mode 100644 index 0000000000..d9d0482424 --- /dev/null +++ b/lib/nettle/gost/write-le32.c @@ -0,0 +1,69 @@ +/* write-le32.c + + Copyright (C) 2001, 2011 Niels Möller + + This file is part of GNU Nettle. + + GNU Nettle is free software: you can redistribute it and/or + modify it under the terms of either: + + * the GNU Lesser General Public License as published by the Free + Software Foundation; either version 3 of the License, or (at your + option) any later version. + + or + + * the GNU General Public License as published by the Free + Software Foundation; either version 2 of the License, or (at your + option) any later version. + + or both in parallel, as here. + + GNU Nettle is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + General Public License for more details. + + You should have received copies of the GNU General Public License and + the GNU Lesser General Public License along with this program. If + not, see http://www.gnu.org/licenses/. +*/ + +#if HAVE_CONFIG_H +# include "config.h" +#endif + +#include + +#include "nettle-write.h" + +#include + +void +_nettle_write_le32(size_t length, uint8_t *dst, + const uint32_t *src) +{ + size_t i; + size_t words; + unsigned leftover; + + words = length / 4; + leftover = length % 4; + + for (i = 0; i < words; i++, dst += 4) + LE_WRITE_UINT32(dst, src[i]); + + if (leftover) + { + uint32_t word; + + word = src[i]; + + do + { + *dst++ = word & 0xff; + word >>= 8; + } + while (--leftover); + } +} -- cgit v1.2.1