uweigand commented on Issue #2488:
By defining the endianness in a ternary way (with
native
as an option) I think we can keep the text format and builder interface backward-compatible; we can accept the newbig
/little
options in the text format, and we can acceptMemFlags
with explicit endianness if the client desires. But current code doesn't break or regress in performance. @uweigand has done the hard part of plumbing flags through, so we shouldn't drop them once they reach the backend; and incranelift-wasm
we can carefully audit codegen to ensure we specify little-endianness.Well, I'd be happy to implement that option as well. Just one question to clarify: when adding a
native
option, should that have to be specified explicitly, i.e. something likeMemFlags::new(Endianness::Native)
or should we go back to allowing plainMemFlags::new()
which would implicitly mean native endianness?
bjorn3 commented on Issue #2488:
MemFlags::new()
would look nicer, butMemFlags::new(Endianness::Native)
would make it harder for optimizations to use the wrong endianness.
uweigand commented on Issue #2488:
I've created a new PR #2492 that implements optional endianness markers in MemFlags. This is the
MemFlags::new()
approach for now -- obviously that results in a drastically smaller patch.Let me know if you'd prefer the
MemFlags::new(Endianness::Native)
version instead.
cfallin commented on Issue #2488:
Thanks @uweigand -- I do like the alternative (with-native-option) approach better, I think; anyone else. have thoughts on this (@sunfishcode has thought about determinism I know; @julian-seward1 and maybe others in the last CL call)?
cfallin commented on Issue #2488:
Closed after merging the alternative #2492 (thanks for doing the work on both options and the patience during review!).
Last updated: Jan 24 2025 at 00:11 UTC