[PATCH] D64083: [OpenCL][Sema] Improve address space support for blocks
John McCall via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 12 10:50:19 PDT 2019
rjmccall added a comment.
In D64083#1583109 <https://reviews.llvm.org/D64083#1583109>, @rjmccall wrote:
> Okay, so it sounds like *from the language perspective* all block pointers are actually pointers into `__generic`, and the thing with literals is just an implementation detail that's been inappropriately expressed in the AST. The better implementation strategy is to make sure that (1) the AST uses the size/alignment of a `__generic` pointer for a block pointer and (2) IRGen implicitly converts block literals to `__generic` pointers when it emits them, and then there's no such thing as a block pointer to a qualified type.
This is actually important to get right in C++ because of `auto` and templates; you really don't want non-generic block pointer types to become an expressible thing in the language.
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64083/new/
https://reviews.llvm.org/D64083
More information about the llvm-commits
mailing list