[clang] [lld] [llvm] [mlir] [IR] Introduce `T<address space>` to `DataLayout` to represent flat address space if a target supports it (PR #108786)
Eli Friedman via cfe-commits
cfe-commits at lists.llvm.org
Mon Sep 16 14:21:25 PDT 2024
efriedma-quic wrote:
Both in InferAddressSpaces, and in Attributor, you don't really care about whether a flat address-space exists. All you really need to know is whether, for a given pair of address-spaces "A" and "B", `addrspacecast ptr addrspace(A) %x to ptr addrspace(B)` should be optimized to use operations in "A" instead of "B". In this context, the existence of a "flat" address-space is just a statement that we should optimize if "B" is the flat address-space.
Given that, maybe worth clarifying LangRef to be more explicit: start off with a statement of the "should be optimized" property, and then say that GPU targets commonly refer to this kind of address-space as "flat".
I don't know whether anyone needs the generalization to multiple flat address-spaces, or trees of address-spaces with multiple levels of nesting.
https://github.com/llvm/llvm-project/pull/108786
More information about the cfe-commits
mailing list