1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
https://github.com/briansmith/ring/pull/1007
--- cargo-crates/ring-0.14.6/src/cpu.rs.orig 2019-02-07 21:54:35 UTC
+++ cargo-crates/ring-0.14.6/src/cpu.rs
@@ -52,6 +52,11 @@ pub(crate) fn features() -> Features {
{
arm::fuchsia_setup();
}
+
+ #[cfg(all(target_os = "freebsd", any(target_arch = "aarch64", target_arch = "arm")))]
+ {
+ arm::freebsd_setup();
+ }
});
}
@@ -153,6 +158,83 @@ pub(crate) mod arm {
}
}
+ #[cfg(all(target_os = "freebsd", any(target_arch = "aarch64", target_arch = "arm")))]
+ pub fn freebsd_setup() {
+ extern crate std;
+ use libc::{c_int, c_ulong, c_void};
+
+ extern "C" {
+ fn elf_aux_info(aux: c_int, buf: *mut c_void, buflen: c_int) -> c_int;
+ }
+
+ const AT_HWCAP: c_int = 25;
+
+ #[cfg(target_arch = "aarch64")]
+ const HWCAP_NEON: c_ulong = 1 << 1;
+
+ #[cfg(target_arch = "arm")]
+ const HWCAP_NEON: c_ulong = 1 << 12;
+
+ let caps: c_ulong = 0;
+ let buffer : *mut c_void = { let t: *const c_ulong = ∩︀ t} as *mut c_void;
+
+ unsafe {
+ let _ret = elf_aux_info(
+ AT_HWCAP,
+ buffer,
+ std::mem::size_of_val(&caps) as i32
+ );
+ }
+
+ // We assume NEON is available on AARCH64 because it is a required
+ // feature.
+ #[cfg(target_arch = "aarch64")]
+ debug_assert!(caps & HWCAP_NEON == HWCAP_NEON);
+
+ // OpenSSL and BoringSSL don't enable any other features if NEON isn't
+ // available.
+ if caps & HWCAP_NEON == HWCAP_NEON {
+ let mut features = NEON.mask;
+
+ #[cfg(target_arch = "aarch64")]
+ const OFFSET: c_ulong = 3;
+
+ #[cfg(target_arch = "arm")]
+ const OFFSET: c_ulong = 0;
+ #[cfg(target_arch = "arm")]
+ const AT_HWCAP2: c_int = 26;
+ #[cfg(target_arch = "arm")]
+ let caps: c_ulong = 0;
+ #[cfg(target_arch = "arm")]
+ let buffer : *mut c_void = { let t: *const c_ulong = ∩︀ t} as *mut c_void;
+
+ #[cfg(target_arch = "arm")]
+ unsafe {
+ let _ret = elf_aux_info(
+ AT_HWCAP2,
+ buffer,
+ std::mem::size_of_val(&caps) as i32
+ );
+ };
+
+ const HWCAP_AES: c_ulong = 1 << 0 + OFFSET;
+ const HWCAP_PMULL: c_ulong = 1 << 1 + OFFSET;
+ const HWCAP_SHA2: c_ulong = 1 << 3 + OFFSET;
+
+ if caps & HWCAP_AES == HWCAP_AES {
+ features |= AES.mask;
+ }
+ if caps & HWCAP_PMULL == HWCAP_PMULL {
+ features |= PMULL.mask;
+ }
+ if caps & HWCAP_SHA2 == HWCAP_SHA2 {
+ features |= 1 << 4;
+ }
+
+ unsafe { GFp_armcap_P = features };
+ }
+ }
+
pub(crate) struct Feature {
#[cfg_attr(
any(
@@ -176,7 +258,7 @@ pub(crate) mod arm {
}
#[cfg(all(
- any(target_os = "android", target_os = "linux", target_os = "fuchsia"),
+ any(target_os = "android", target_os = "linux", target_os = "fuchsia", target_os = "freebsd"),
any(target_arch = "arm", target_arch = "aarch64")
))]
{
@@ -210,7 +292,7 @@ pub(crate) mod arm {
};
#[cfg(all(
- any(target_os = "android", target_os = "linux", target_os = "fuchsia"),
+ any(target_os = "android", target_os = "linux", target_os = "fuchsia", target_os = "freebsd"),
any(target_arch = "arm", target_arch = "aarch64")
))]
extern "C" {
|