From b594445f39d99066071d80fc8efeba5c8f72cc35 Mon Sep 17 00:00:00 2001 From: V3n3RiX Date: Sun, 5 May 2024 00:00:45 +0100 Subject: gentoo auto-resync : 05:05:2024 - 00:00:45 --- .../libnvme/files/libnvme-1.9-musl-stdint.patch | 59 ++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 sys-libs/libnvme/files/libnvme-1.9-musl-stdint.patch (limited to 'sys-libs/libnvme/files') diff --git a/sys-libs/libnvme/files/libnvme-1.9-musl-stdint.patch b/sys-libs/libnvme/files/libnvme-1.9-musl-stdint.patch new file mode 100644 index 000000000000..c2319b72bc96 --- /dev/null +++ b/sys-libs/libnvme/files/libnvme-1.9-musl-stdint.patch @@ -0,0 +1,59 @@ +https://github.com/linux-nvme/libnvme/pull/838 + +From b3ca2923affce631bc302f0fdce565093ffe1b5b Mon Sep 17 00:00:00 2001 +From: Sam James +Date: Sat, 4 May 2024 10:59:16 +0100 +Subject: [PATCH] Use C99 types for uint32_t + + provides `uint32_t`, while `u_int_32` is an unofficial/internal +typedef that glibc happens to provide. This fixes the build on musl. + +Bug: https://bugs.gentoo.org/931194 + +Signed-off-by: Sam James +--- a/src/nvme/base64.c ++++ b/src/nvme/base64.c +@@ -7,6 +7,7 @@ + * Author: Hannes Reinecke + */ + ++#include + #include + #include + #include +@@ -29,7 +30,7 @@ static const char base64_table[65] = + int base64_encode(const unsigned char *src, int srclen, char *dst) + { + int i, bits = 0; +- u_int32_t ac = 0; ++ uint32_t ac = 0; + char *cp = dst; + + for (i = 0; i < srclen; i++) { +@@ -64,7 +65,7 @@ int base64_encode(const unsigned char *src, int srclen, char *dst) + */ + int base64_decode(const char *src, int srclen, unsigned char *dst) + { +- u_int32_t ac = 0; ++ uint32_t ac = 0; + int i, bits = 0; + unsigned char *bp = dst; + +--- a/src/nvme/linux.c ++++ b/src/nvme/linux.c +@@ -1513,10 +1513,10 @@ unsigned char *nvme_import_tls_key(const char *encoded_key, int *key_len, + return NULL; + } + crc = crc32(crc, decoded_key, decoded_len); +- key_crc = ((u_int32_t)decoded_key[decoded_len]) | +- ((u_int32_t)decoded_key[decoded_len + 1] << 8) | +- ((u_int32_t)decoded_key[decoded_len + 2] << 16) | +- ((u_int32_t)decoded_key[decoded_len + 3] << 24); ++ key_crc = ((uint32_t)decoded_key[decoded_len]) | ++ ((uint32_t)decoded_key[decoded_len + 1] << 8) | ++ ((uint32_t)decoded_key[decoded_len + 2] << 16) | ++ ((uint32_t)decoded_key[decoded_len + 3] << 24); + if (key_crc != crc) { + nvme_msg(NULL, LOG_ERR, "CRC mismatch (key %08x, crc %08x)", + key_crc, crc); + -- cgit v1.2.3