-
Notifications
You must be signed in to change notification settings - Fork 276
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
Make constructors const fn
where possible
#906
Comments
cc @rust-lang/libs @rust-lang/wg-const-eval I think that this functionality can be desirable, however it is an extension to the intrinsics that other compilers don't have. Neither GCC nor Clang allow |
These are not really intrinsics currently in the rustc sense, right? Is there a chance that in the future, they might become intrinsics? If not I see little problem with making these functions |
I cannot possibly imagine why, long term, this wouldn't be the completely obvious move for all floating type constructors as well as all integer type constructors and operations. Even in a cross-compile context, the computation can be done at simply a slightly lower speed by doing the work on an array. The only time that a SIMD function shouldn't be const is if we can't be assured of identical results between compile time and execution time. While it is true that other compilers don't offer this ability, there are a lot of other things they also don't offer, which has never stopped us from adding something to rust. In this specific case, making the functions available as All that said, I think "long term" is key here, because i can imagine all sorts of compiler internal problems as to why we couldn't just mark a function const and get on with the day. Const eval is still fairly early in development. |
I don't think const-eval has any specific issues that would be a problem here, beyond what is listed in rust-lang/rust#57241 (but the hard question there is unrelated to const-eval, it is about what our floating-point semantics are in the first place). |
I was thinking that, for example, to compile time eval an sse2 instruction's usage when you're cross-compiling from an aarch64 device you'd need to have the "runtime code path" where the actual sse2 instruction is inserted, and the "compile time code path" where the sse2 instruction is emulated using an array of [i32;4] values (or whatever values, depending on the operation). But if we can already do something like that, then that's cool. |
@bitshifter also note that you can make compile time consts of SIMD types using the "const union hack": https://github.com/Lokathor/wide/blob/main/src/lib.rs#L246 https://github.com/Lokathor/wide/blob/main/src/f32x4_.rs#L15 (Only works in |
This here is just about the constructor, not any compiler-supported intrinsic. That's why I asked about intrinsics above. For SIMD intrinsics, supporting them in CTFE (or Miri) will require an explicit implementation in the Miri engine -- and there's just so many of them that this is a rather dautning task. This implementation is required no matter the host platform; we never use host SIMD (or floating point) for CTFE. |
You can also use |
I do use the const union hack elsewhere in |
The current situation (since rust-lang/rust#72920 landed) is that both unions and |
The difference is that a A So that's why transmute is stable in |
Definitely sounds like making constructors |
For marking them unstably const, a PR is fine I think. The tracking issue should point out that stabilization is blocked on rust-lang/rust#57241. |
I have a library which wraps SIMD types and it would be a nice feature if users were able to create const values with my wrapper types. There's currently no way of doing this in stable Rust.
It would be convenient if some constructor functions could be made
const fn
so we can create SIMD constants.For example this is not currently possible:
Internally functions like
_mm_set1_ps
are quite straight forward:__m128
is arepr(simd)
tuple struct.I would propose making all of the
_mm_set*
functionsconst fn
and any other construction functions instdarch
for that matter.The text was updated successfully, but these errors were encountered: