use crate::ir::DataType;
use crate::ops::Backend;
use crate::ops::{IntrinsicDescriptor, OpSpec};
pub const WGSL: &str = include_str!("wgsl_shaders/sha256.wgsl");
#[must_use]
pub fn hkdf_extract(salt: &[u8], ikm: &[u8]) -> [u32; 8] {
crate::ops::hash::reference::kdf::hkdf_extract_words(salt, ikm)
}
pub const INPUTS: &[DataType] = &[DataType::Bytes, DataType::Bytes];
pub const LAWS: &[crate::ops::AlgebraicLaw] = &[];
pub const OUTPUTS: &[DataType] = &[const { DataType::U32 }; 8];
pub const SPEC: OpSpec = OpSpec::intrinsic(
"hash.hkdf_extract",
INPUTS,
OUTPUTS,
LAWS,
wgsl_only,
IntrinsicDescriptor::new(
"hash.hkdf_extract.wgsl",
"wgsl-hkdf-extract-sha256",
crate::ops::hash::cpu_refs::hkdf_extract,
),
);
pub fn wgsl_only(backend: &Backend) -> bool {
matches!(backend, Backend::Wgsl)
}