Blame apr-1.4.6-strict-aliasing.patch
|
Jan Kaluza |
c0ec88 |
From 9ae65df5802f5f49751c851182ed2a90447c45f5 Mon Sep 17 00:00:00 2001
|
|
Jan Kaluza |
c0ec88 |
From: Jan Kaluza <hanzz.k@gmail.com>
|
|
Jan Kaluza |
c0ec88 |
Date: Tue, 11 Dec 2012 11:07:28 +0100
|
|
Jan Kaluza |
c0ec88 |
Subject: [PATCH 1/2] Fix strict-aliasing gcc warning
|
|
Jan Kaluza |
c0ec88 |
|
|
Jan Kaluza |
c0ec88 |
---
|
|
Jan Kaluza |
c0ec88 |
random/unix/sha2.c | 9 ++++++++-
|
|
Jan Kaluza |
c0ec88 |
1 file changed, 8 insertions(+), 1 deletion(-)
|
|
Jan Kaluza |
c0ec88 |
|
|
Jan Kaluza |
c0ec88 |
diff --git a/random/unix/sha2.c b/random/unix/sha2.c
|
|
Jan Kaluza |
c0ec88 |
index 212c1b7..887ac81 100644
|
|
Jan Kaluza |
c0ec88 |
--- a/random/unix/sha2.c
|
|
Jan Kaluza |
c0ec88 |
+++ b/random/unix/sha2.c
|
|
Jan Kaluza |
c0ec88 |
@@ -537,7 +537,14 @@ void apr__SHA256_Final(sha2_byte digest[], SHA256_CTX* context) {
|
|
Jan Kaluza |
c0ec88 |
*context->buffer = 0x80;
|
|
Jan Kaluza |
c0ec88 |
}
|
|
Jan Kaluza |
c0ec88 |
/* Set the bit count: */
|
|
Jan Kaluza |
c0ec88 |
- *(sha2_word64*)&context->buffer[SHA256_SHORT_BLOCK_LENGTH] = context->bitcount;
|
|
Jan Kaluza |
c0ec88 |
+ {
|
|
Jan Kaluza |
c0ec88 |
+ union {
|
|
Jan Kaluza |
c0ec88 |
+ apr_uint64_t bitcount;
|
|
Jan Kaluza |
c0ec88 |
+ apr_byte_t bytes[8];
|
|
Jan Kaluza |
c0ec88 |
+ } bitcount;
|
|
Jan Kaluza |
c0ec88 |
+ bitcount.bitcount = context->bitcount;
|
|
Jan Kaluza |
c0ec88 |
+ MEMCPY_BCOPY(&context->buffer[SHA256_SHORT_BLOCK_LENGTH], bitcount.bytes, 8);
|
|
Jan Kaluza |
c0ec88 |
+ }
|
|
Jan Kaluza |
c0ec88 |
|
|
Jan Kaluza |
c0ec88 |
/* Final transform: */
|
|
Jan Kaluza |
c0ec88 |
apr__SHA256_Transform(context, (sha2_word32*)context->buffer);
|
|
Jan Kaluza |
c0ec88 |
--
|
|
Jan Kaluza |
c0ec88 |
1.8.0
|
|
Jan Kaluza |
c0ec88 |
|