-
-
Notifications
You must be signed in to change notification settings - Fork 445
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Put aarch64 simd feature behind nightly feature flag #284
Conversation
Interesting, will have to think about this a bit first. We're already beholden to nightly because our use of cbindgen-with-macros (see #141) and our AArch64 SIMD is already written to do a runtime check. At first thought that steers me towards the |
It looks like the nightly flag for curve25519-dalek doesn't really do anything related to codegen anymore; it only affects rustdoc. (We can't use the vector backends because they don't check for CPU support first; they're either on or off.) Because of that I think I'd pick your second approach of a dedicated |
Interesting with regard to vector backends for Dalek; would a runtime detection feature be something that would interest Signal? I've always wanted to toy with a NEON backend for 25519 at some point, so maybe I should take out two flies with that stone. I'll update this PR to take the second approach later, thanks for the feedback and for coming back to us! |
Hm. On the one hand, it's bad enough that we're diverging from upstream, but on the other we do a lot of Curve25519 operations. You can check out the AES implementation in signal-crypto to see how we're doing runtime detection of both NEON and AVX2 there. |
(Have had a busy week, I'll still come back to this)
I'd mostly be trying to get this upstream with Dalek: implement a NEON backend, and then get them to merge some runtime detection, potentially behind a feature flag. Diverging any more from upstream would be pretty painful, especially for these kind of things ;-) |
#328 will make this job a lot easier! And I guess we should follow RustCrypto's lead in calling this |
I'm opening an new PR with the previous approach at CEST-tomorrow. |
Hi! We've just merged the
libsignal-client
swap inlibsignal-service-rs
. Everything went smooth, except for one thing! Whisperfish'aarch64
target does not compile on Rust stable; all others (armv7hl, i[46]86) work perfectly.Since we have some other requirements w.r.t. Rust compiler versions (Tokio, mostly), I figured I could take a look on how to get
libsignal-client
to compile with stable Rust. Seemingly, the only real place where the nightly-1.49 compiler is required (for the Rust library, that is), is for the aarch64 SIMD optimizations.This pull request models the simplest solution that I could come up with: expose a
nightly
flag from the affected crates (basically all crates), and only enablefeature(stdsimd)
when that feature is enabled.I've also taken the liberty of linking that
nightly
flag to thenightly
flag of the Dalek set of crates. This has a side effect: the Dalek-nightly
flag was previously not enabled as far as I could tell. I've linked it through because I feel it would be more confusing if I did not, with this name.Possible approaches
nightly
flag (this pull request)The approach in this pull request.
Pro
Con
Separate feature flag (e.g.
aarch64simd
)The same idea, but separate flag
Pro
aarch64
Con
If you have more suggestions, I'll add them to the list. I have the current proposal in a separate branch that we can use for now.