[llvm] [IR] Introduce captures attribute (PR #116990)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri Dec 20 00:31:56 PST 2024
================
@@ -273,6 +273,107 @@ raw_ostream &operator<<(raw_ostream &OS, MemoryEffects RMRB);
// Legacy alias.
using FunctionModRefBehavior = MemoryEffects;
+/// Components of the pointer that may be captured.
+enum class CaptureComponents : uint8_t {
+ None = 0,
+ AddressIsNull = (1 << 0),
+ Address = (1 << 1) | AddressIsNull,
+ ReadProvenance = (1 << 2),
+ Provenance = (1 << 3) | ReadProvenance,
+ All = Address | Provenance,
+ LLVM_MARK_AS_BITMASK_ENUM(Provenance),
+};
+
+inline bool capturesNothing(CaptureComponents CC) {
----------------
nikic wrote:
I haven't worked on the following commits yet, so I expect the API here to change a good bit once I get around to the inference + CaptureTracking changes.
I could wrap this in a struct, but then I'd have to reimplement the functionality that BitMaskEnum provides :(
https://github.com/llvm/llvm-project/pull/116990
More information about the llvm-commits
mailing list