diff options
| author | Makoto Kato <m_kato@ga2.so-net.ne.jp> | 2020-03-29 20:28:17 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-03-29 12:28:17 +0100 |
| commit | 09ef01ade10c9d878062eb93f230de8042b4d3ec (patch) | |
| tree | 7871f69ed9f188d3142e1ccf1c8783a328145611 /library/stdarch/crates/std_detect/src | |
| parent | e367bcd7f90ea5e0e655d94e19480fa1eddbc35e (diff) | |
| download | rust-09ef01ade10c9d878062eb93f230de8042b4d3ec.tar.gz rust-09ef01ade10c9d878062eb93f230de8042b4d3ec.zip | |
Add crypto target feature detection to arm32 (#833)
Diffstat (limited to 'library/stdarch/crates/std_detect/src')
| -rw-r--r-- | library/stdarch/crates/std_detect/src/detect/arch/arm.rs | 2 | ||||
| -rw-r--r-- | library/stdarch/crates/std_detect/src/detect/os/linux/arm.rs | 16 |
2 files changed, 18 insertions, 0 deletions
diff --git a/library/stdarch/crates/std_detect/src/detect/arch/arm.rs b/library/stdarch/crates/std_detect/src/detect/arch/arm.rs index 96978b70098..46fd56384be 100644 --- a/library/stdarch/crates/std_detect/src/detect/arch/arm.rs +++ b/library/stdarch/crates/std_detect/src/detect/arch/arm.rs @@ -16,4 +16,6 @@ features! { /// Polynomial Multiply @FEATURE: #[unstable(feature = "stdsimd", issue = "27731")] crc: "crc"; /// CRC32 (Cyclic Redundancy Check) + @FEATURE: #[unstable(feature = "stdsimd", issue = "27731")] crypto: "crypto"; + /// Crypto: AES + PMULL + SHA1 + SHA2 } diff --git a/library/stdarch/crates/std_detect/src/detect/os/linux/arm.rs b/library/stdarch/crates/std_detect/src/detect/os/linux/arm.rs index f55bc30b849..4b0cb586bba 100644 --- a/library/stdarch/crates/std_detect/src/detect/os/linux/arm.rs +++ b/library/stdarch/crates/std_detect/src/detect/os/linux/arm.rs @@ -20,6 +20,14 @@ pub(crate) fn detect_features() -> cache::Initializer { enable_feature(&mut value, Feature::neon, bit::test(auxv.hwcap, 12)); enable_feature(&mut value, Feature::pmull, bit::test(auxv.hwcap2, 1)); enable_feature(&mut value, Feature::crc, bit::test(auxv.hwcap2, 4)); + enable_feature( + &mut value, + Feature::crypto, + bit::test(auxv.hwcap2, 0) + && bit::test(auxv.hwcap2, 1) + && bit::test(auxv.hwcap2, 2) + && bit::test(auxv.hwcap2, 3), + ); return value; } @@ -31,6 +39,14 @@ pub(crate) fn detect_features() -> cache::Initializer { ); enable_feature(&mut value, Feature::pmull, c.field("Features").has("pmull")); enable_feature(&mut value, Feature::crc, c.field("Features").has("crc32")); + enable_feature( + &mut value, + Feature::crypto, + c.field("Features").has("aes") + && c.field("Features").has("pmull") + && c.field("Features").has("sha1") + && c.field("Features").has("sha2"), + ); return value; } value |
