diff --git a/0002-Fix-sha1-calculation-on-big-endian-systems.patch b/0002-Fix-sha1-calculation-on-big-endian-systems.patch deleted file mode 100644 index d3ce476..0000000 --- a/0002-Fix-sha1-calculation-on-big-endian-systems.patch +++ /dev/null @@ -1,72 +0,0 @@ -From 52540c1a7816dc8f69e0b6c61b4220a7776e979f Mon Sep 17 00:00:00 2001 -From: Elliott Sales de Andrade -Date: Mon, 7 Sep 2020 02:44:29 -0400 -Subject: [PATCH 2/2] Fix sha1 calculation on big-endian systems. - -Even though there is a check for `WORDS_BIGENDIAN`, this does nothing -because that is defined by R headers, which are not included by this -code. But instead of fixing the #define, it is simpler to load the -`block` workspace from the `buffer` as big-endian `uint32_t` directly. - -Signed-off-by: Elliott Sales de Andrade ---- - src/sha1/sha1.c | 36 ++++++++++++++---------------------- - 1 file changed, 14 insertions(+), 22 deletions(-) - -diff --git a/src/sha1/sha1.c b/src/sha1/sha1.c -index ca9c660..bdedef5 100644 ---- a/src/sha1/sha1.c -+++ b/src/sha1/sha1.c -@@ -94,15 +94,9 @@ void SHA1_Transform(uint32_t state[5], const uint8_t buffer[64]); - - /* blk0() and blk() perform the initial expand. */ - /* I got the idea of expanding during the round function from SSLeay */ --/* FIXME: can we do this in an endian-proof way? */ --#ifdef WORDS_BIGENDIAN --#define blk0(i) block->l[i] --#else --#define blk0(i) (block->l[i] = (rol(block->l[i],24)&0xFF00FF00) \ -- |(rol(block->l[i],8)&0x00FF00FF)) --#endif --#define blk(i) (block->l[i&15] = rol(block->l[(i+13)&15]^block->l[(i+8)&15] \ -- ^block->l[(i+2)&15]^block->l[i&15],1)) -+#define blk0(i) block[i] -+#define blk(i) (block[i&15] = rol(block[(i+13)&15]^block[(i+8)&15] \ -+ ^block[(i+2)&15]^block[i&15],1)) - - /* (R0+R1), R2, R3, R4 are the different operations used in SHA1 */ - #define R0(v,w,x,y,z,i) z+=((w&(x^y))^y)+blk0(i)+0x5A827999+rol(v,5);w=rol(w,30); -@@ -129,19 +123,17 @@ void SHAPrintContext(SHA1_CTX *context, char *msg){ - void SHA1_Transform(uint32_t state[5], const uint8_t buffer[64]) - { - uint32_t a, b, c, d, e; -- typedef union { -- uint8_t c[64]; -- uint32_t l[16]; -- } CHAR64LONG16; -- CHAR64LONG16* block; -- --#ifdef SHA1HANDSOFF -- static uint8_t workspace[64]; -- block = (CHAR64LONG16*)workspace; -- memcpy(block, buffer, 64); --#else -- block = (CHAR64LONG16*)buffer; --#endif -+ typedef uint32_t BLOCK[16]; -+ BLOCK block; -+ -+ /* Load buffer into block as big-endian always. */ -+ for (int i = 0; i < 16; i++) { -+ block[i] = 0; -+ for (int j = 0; j < 4; j++) { -+ block[i] <<= 8; -+ block[i] += buffer[i * 4 + j]; -+ } -+ } - - /* Copy context->state[] to working vars */ - a = state[0]; --- -2.26.2 -