-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Add an easy way to get details of a type's size and layout in memory #37623
Comments
|
I suggest you to show exactly what usage/API/output the feature you look for is meant to have. |
We could add a -Z flag for this – we already have a number of |
I was thinking about writing a DWARF-based tool for this. DWARF contains type-layouts, so you can implement this with an external tool. Doing it directly in the compiler might be less work though. |
AIUI that only points out when an enum has significantly size differences between variants. Which is useful, but I'm asking for a lot more detail.
For types like this: struct S {
f: bool,
g: i32,
}
enum E {
A(i64, i32)
B(S)
} I'd like output something like this:
There's a lot of flexibility about the invocation and exact presentation -- e.g. would it do this for all types, or just requested types? -- but this gives a good idea. (I may also have gotten some of those numbers wrong.) Even better would be if it could give suggestions on more efficient orderings. E.g. if the fields in E::A are switched does the discriminant shrink from 8 bytes to 4? I'm not sure about that, but again, you get the ida. |
This should hopefully "soon" become unnecessary thanks to @camlorn's work with struct (and I assume enum) field re-ordering. Most non I would suggest that this information be included in the save-analysis API, perhaps? I think that's the primary information output method from rustc right now, and it can save it in a format that can the be queried for specific types/variants and printed in whatever way is preferred. |
Sure it would be. One way to reduce size of a enum for example, if one On Nov 10, 2016 6:38 AM, "Mark Simulacrum" notifications@github.com wrote:
|
Yeah, the optimizations I'm working on are provably optimal as far as @eddyb and myself could determine, though neither of us came up with a full proof. The only way to do better is if you can interleave structs, but that's got major implementation challenges and isn't worth it in my opinion. What I'm already doing is proving to be hard enough, no need to go make major modifications to LLVM. |
Automatic struct field reordering to reduce padding sounds very useful! And it just adds to the usefulness of the feature this PR is requesting, because it would let you see what field order the compiler chose. |
cc #37770. |
@nnethercote can we close this since #37770 has landed? Or do we want to wait until something more stable than a |
#37770 is very much what I had in mind. Thank you for doing it. |
Multiple times recently, while looking at #36799, I have wanted to know exactly how a type is laid out in memory, including padding and unused bytes. Particular for enums where the variants can vary significantly in size, and shrinking large variants can be a win.
I have successfully shrunk some types (#37445, #37577). I manually worked out their memory layouts by using a combination of
println!
statements and staring at the code. I can usually work out the layout, though not always. (E.g. I know thatRvalue
is 152 bytes on 64-bit platforms, and that theBinaryOp
andCheckedBinaryOp
variants are the largest, but I haven't yet worked out why they take that much space because the nesting of the types within those variants is deep and non-obvious.)But it is a huge pain to do it manually, as well as unreliable. It would be lovely if there was an easy way to get this information. Something like
std::intrinsics::type_name
, perhaps. Such a feature would have wide utility for developers of many Rust programs.The text was updated successfully, but these errors were encountered: