You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
51 lines
2.0 KiB
51 lines
2.0 KiB
7 years ago
|
From f578b5f3761f56cb5c5d74ae476006341a5c33c8 Mon Sep 17 00:00:00 2001
|
||
|
From: Diggory Hardy <git@dhardy.name>
|
||
|
Date: Sat, 25 Nov 2017 17:38:40 +0000
|
||
|
Subject: [PATCH] Fix read_u64 for 32-bit platforms
|
||
|
|
||
|
(Why you can't rely on .to_le() being correct I don't understand. If compiler
|
||
|
is mixed-endian then to_le ought still do the correct swaps.)
|
||
|
---
|
||
|
seahash/src/buffer.rs | 4 ++--
|
||
|
seahash/src/helper.rs | 2 +-
|
||
|
2 files changed, 3 insertions(+), 3 deletions(-)
|
||
|
|
||
|
diff --git a/seahash/src/buffer.rs b/seahash/src/buffer.rs
|
||
|
index 573273d..eb2193c 100644
|
||
|
--- a/seahash/src/buffer.rs
|
||
|
+++ b/seahash/src/buffer.rs
|
||
|
@@ -63,7 +63,7 @@ impl State {
|
||
|
|
||
|
// Calculate the number of excessive bytes. These are bytes that could not be handled in
|
||
|
// the loop above.
|
||
|
- let mut excessive = buf.len() as usize + buf.as_ptr() as usize - end_ptr as usize;
|
||
|
+ let mut excessive = buf.len() % 32;
|
||
|
// Handle the excessive bytes.
|
||
|
match excessive {
|
||
|
0 => {},
|
||
|
@@ -71,7 +71,7 @@ impl State {
|
||
|
// 1 or more excessive.
|
||
|
|
||
|
// Write the last excessive bytes (<8 bytes).
|
||
|
- a ^= helper::read_int(slice::from_raw_parts(ptr as *const u8, excessive));
|
||
|
+ a ^= helper::read_int(slice::from_raw_parts(ptr, excessive));
|
||
|
|
||
|
// Diffuse.
|
||
|
a = helper::diffuse(a);
|
||
|
diff --git a/seahash/src/helper.rs b/seahash/src/helper.rs
|
||
|
index a95b89c..d3be89a 100644
|
||
|
--- a/seahash/src/helper.rs
|
||
|
+++ b/seahash/src/helper.rs
|
||
|
@@ -60,7 +60,7 @@ pub unsafe fn read_u64(ptr: *const u8) -> u64 {
|
||
|
{
|
||
|
// We cannot be sure about the memory layout of a potentially emulated 64-bit integer, so
|
||
|
// we read it manually. If possible, the compiler should emit proper instructions.
|
||
|
- (*(ptr as *const u32)).to_le() as u64 | ((*(ptr as *const u32)).to_le() as u64) << 32
|
||
|
+ (*(ptr as *const u32)).to_le() as u64 | ((*(ptr as *const u32).offset(1)).to_le() as u64) << 32
|
||
|
}
|
||
|
|
||
|
#[cfg(target_pointer_width = "64")]
|
||
|
--
|
||
|
2.16.2
|
||
|
|