-
Notifications
You must be signed in to change notification settings - Fork 271
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
POC: Retrieve the actual alignment of max_align_t
#554
base: master
Are you sure you want to change the base?
Conversation
The code had a hard-coded maximum alignment of 16 (128 bits) which may have potentially wasted memory and cause memory unsafety if it was ever compiled with larger alignment (unlikely). This change implements a trick to retrieve the actual alignment from C. To achieve this a newly added C file defines a symbol initialized to `_Alignof(max_align_t)`. It is then compiled (as a separate object), the contents of the symbol is extracted and converted to decimal string which is injected into the `AlignedType` definition. The definition is generated as a separate `.rs` file in `OUT_DIR` and included into `types.rs`.
9918dba
to
dbe3a34
Compare
Hah, clever! Do you think we could just make the C code |
We can't because the binary would be produced for target (to have the correct |
Side note, I don't remember what was the reason we decided not to use the |
We stopped using As for this PR, I think it's worth resurrecting. It's pretty simple and I have some experience now doing something similar in rust-simplicity (though what we did there is much less clever; we just export the sizes from C and then use unit tests to check that they're the same as what we hardcoded in Rust -- not sufficient for rust-secp which is a much more mature project and cannot expect anybody to be running the unit tests before using it). |
That's nothing compared to another reason. Click here if you want to be pissed off about `libc` even moreThey recently silently changed MSRV one-past the upcoming Rust version in Debian stable...
I'd love to but I don't remember what the issue with cross compilation was. Will have to dig into it. Also I had an idea that for vendored version we could use the actual alignment of the struct, not the maximum. |
I don't think there was an actual issue, just that the hardcoded 16 is (at best) inefficient. |
IIRC for cross compiling we need different binutils and thus convert Rust toolchain name to the GNU one. |
The code had a hard-coded maximum alignment of 16 (128 bits) which may have potentially wasted memory and cause memory unsafety if it was ever compiled with larger alignment (unlikely).
This change implements a trick to retrieve the actual alignment from C. To achieve this a newly added C file defines a symbol initialized to
_Alignof(max_align_t)
. It is then compiled (as a separate object), the contents of the symbol is extracted and converted to decimal string which is injected into theAlignedType
definition. The definition is generated as a separate.rs
file inOUT_DIR
and included intotypes.rs
.This POC currently doesn't support cross-compilation which I intend to fix, I just wanted to show that it's possible to do this. Do we want to?