Here's an example of at least some people in the C++ community thinking about prioritizing 64-bit targets: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2020/p2137r0.html#platforms
The world is certainly easier to deal with if everything is a little-endian 64-bit desktop core :-)
What sort of implications would this actually have though, if the standard still supports platforms with 32-bit pointers?
(I guess I should just read it fully to find out)
In a 64-bit only world, it'd be easier to make techniques where you squirrel extra bits into a pointer portable. It'd be easier to standardize on "LP64" as the only data model, ending decades of needless complexity caused by C data models being a thing. It'd be easier to specify raw-data interchange formats because you only need to know where the pointers are, and not what the offsets to everything are.
I guess the distinction I'm wondering about is between "prefer 64-bit" and "the standard actually says that sizeof(void*) == 8"; it seems to me that a spec usually dictates things like the latter? perhaps the "preference" just means that there will be features that work only for 64-bit pointers?
Yeah, the context for that paper was that they're looking to put out a vision and see what kinds of ideas they can build consensus on before moving forward with actual proposals.
Note that that is just a paper, and not necessarily the view of the committee as a whole.
I just skimmed through the linked section, but I'd like to mention that prioritizing 64-bit targets doesn't necessarily mean just deprioritizing 32-bit or older targets. For example, Arm is researching an 128-bit capability architecture called Morello, which actually doesn't fit neatly into the model because the virtual address space is still 64-bit, but sizeof(void *) == 16
and "squirreling extra bits into a pointer" is probably not going to work (capability bound representation issue).
I know people who are looking forward to wasm64 because they have "standardized on 64-bit" within their C++ codebases, and are planning to use wasm rewriting tools on it to convert it to wasm32 to that it can run in today's wasm engines.
I've talked with people who were surprised that we did wasm32 at all. "Isn't everything 64-bit these days?"
The C++ world is diverse, and not everyone thinks this way, but my impression is that quite a few people are hoping that x86-64 plus aarch64 means they don't have to think about any other pointer size ever again.
Well, depending on how capability architectures evolve, that might be too optimistic, but even in a pure 64-bit world Arm has introduced a couple of technologies that don't play well with arbitrary manipulation of pointer bits (e.g. pointer authentication and memory tagging).
Last updated: Jan 24 2025 at 00:11 UTC