[strict provenance] Provide a way to "create allocations at a fixed address" #98593
Description
This issue is part of the Strict Provenance Experiment - #95228
On some platforms it makes sense to just take a hard-coded address, cast it to a pointer, and starting working with that pointer -- because there are external environment assumptions that say that certain things are provided at certain addresses.
This is perfectly fine for Rust as long as that memory is entirely disjoint from all the memory that Rust understands (static
globals, stack allocations, heap allocations). Basically we can think of there being a single hard-coded provenance for "all the memory that is disjoint from the Abstract Machine", and that is the provenance we would like to use for these pointers created from hard-coded addresses. These restrictions make this operation a lot easier to specify than from_exposed_addr
. (Remember: from_exposed_addr
is outside of Strict Provenance. The goal of this issue is to provide a way to write such code while following Strict Provenance.)
In the spirit of the Strict Provenance APIs, that means we probably want a function that does this, and that we can attach suitable documentation to. There are some open questions for the syntax and semantics of that function:
- What should it be called?
make_alloc
,assume_alloc
,hard_coded_alloc
? I am leaning towards something with "alloc" because this function is basically like an allocator, except that you tell it at which address to allocate and you have to promise that that is Okay To Do. - It should definitely take a
usize
for the address and return*mut T
. Should it also take a size, saying how large this assumed allocation is? - Should each invocation return a fresh provenance, or should they all return the same provenance? Probably the latter; using a fresh provenance comes with a bunch of restrictions that I doubt such low-level code will be happy about.
- (other things I have not thought of)
Cc @Lokathor who keeps mentioning this usecase every time I want to ban int2ptr casts. ;)
Tagging WG-embedded since that's where this kind of stuff mostly happens (AFAIK)
Activity