Merge pull request #285 from qu1x/fix-targets-without-atomic-64

Fix targets without 64-bit atomics.
This commit is contained in:
Alexander Zaitsev 2022-03-25 11:50:07 +03:00 committed by GitHub
commit 4aafe04be6
Signed by: DevComp
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 0 deletions

View file

@ -23,6 +23,9 @@ sha1 = {version = "0.10.1", optional = true }
time = { version = "0.3.7", features = ["formatting", "macros" ], optional = true }
zstd = { version = "0.10.0", optional = true }
[target.'cfg(any(target_arch = "mips", target_arch = "powerpc"))'.dependencies]
crossbeam-utils = "0.8.8"
[dev-dependencies]
bencher = "0.1.5"
getrandom = "0.2.5"

View file

@ -2,8 +2,37 @@
#[cfg(doc)]
use {crate::read::ZipFile, crate::write::FileOptions};
#[cfg(not(any(target_arch = "mips", target_arch = "powerpc")))]
use std::sync::atomic;
#[cfg(any(target_arch = "mips", target_arch = "powerpc"))]
mod atomic {
use crossbeam_utils::sync::ShardedLock;
pub use std::sync::atomic::Ordering;
#[derive(Debug, Default)]
pub struct AtomicU64 {
value: ShardedLock<u64>,
}
impl AtomicU64 {
pub fn new(v: u64) -> Self {
Self {
value: ShardedLock::new(v),
}
}
pub fn get_mut(&mut self) -> &mut u64 {
self.value.get_mut().unwrap()
}
pub fn load(&self, _: Ordering) -> u64 {
*self.value.read().unwrap()
}
pub fn store(&self, value: u64, _: Ordering) {
*self.value.write().unwrap() = value;
}
}
}
#[cfg(feature = "time")]
use time::{error::ComponentRange, Date, Month, OffsetDateTime, PrimitiveDateTime, Time};