cfg_if::cfg_if! {
if #[cfg(sha1_backend = "soft")] {
mod soft;
pub(crate) use soft::compress;
} else if #[cfg(sha1_backend = "aarch64-sha2")] {
mod aarch64_sha2;
#[cfg(not(target_feature = "sha2"))]
compile_error!("aarch64-sha2 backend requires sha2 target feature");
pub(crate) fn compress(state: &mut [u32; 5], blocks: &[[u8; 64]]) {
unsafe { aarch64_sha2::compress(state, blocks) }
}
} else if #[cfg(sha1_backend = "x86-sha")] {
mod x86_sha;
#[cfg(not(all(
target_feature = "sha",
target_feature = "sse2",
target_feature = "ssse3",
target_feature = "sse4.1",
)))]
compile_error!("x86-sha backend requires sha, sse2, ssse3, sse4.1 target features");
pub(crate) fn compress(state: &mut [u32; 5], blocks: &[[u8; 64]]) {
unsafe { x86_sha::compress(state, blocks) }
}
} else if #[cfg(target_arch = "loongarch64")] {
mod loongarch64_asm;
pub(crate) use loongarch64_asm::compress;
} else {
mod soft;
cfg_if::cfg_if! {
if #[cfg(any(target_arch = "x86", target_arch = "x86_64"))] {
mod x86_sha;
cpufeatures::new!(shani_cpuid, "sha", "sse2", "ssse3", "sse4.1");
} else if #[cfg(target_arch = "aarch64")] {
mod aarch64_sha2;
cpufeatures::new!(sha2_hwcap, "sha2");
}
}
pub(crate) fn compress(state: &mut [u32; 5], blocks: &[[u8; 64]]) {
cfg_if::cfg_if! {
if #[cfg(any(target_arch = "x86", target_arch = "x86_64"))] {
if shani_cpuid::get() {
return unsafe { x86_sha::compress(state, blocks) };
}
} else if #[cfg(target_arch = "aarch64")] {
if sha2_hwcap::get() {
return unsafe { aarch64_sha2::compress(state, blocks) };
}
}
}
soft::compress(state, blocks);
}
}
}