[clang] [llvm] [CodeGen][arm64e] Add methods and data members to Address, which are needed to authenticate signed pointers (PR #86923)

Akira Hatanaka via cfe-commits cfe-commits at lists.llvm.org
Fri Jun 7 14:40:47 PDT 2024


================
@@ -201,14 +211,26 @@ template <> struct DominatingValue<RValue> {
   class saved_type {
     enum Kind { ScalarLiteral, ScalarAddress, AggregateLiteral,
                 AggregateAddress, ComplexAddress };
-
-    llvm::Value *Value;
-    llvm::Type *ElementType;
+    union {
+      struct {
+        DominatingLLVMValue::saved_type first, second;
+      } Vals;
+      DominatingValue<Address>::saved_type AggregateAddr;
+    };
     LLVM_PREFERRED_TYPE(Kind)
     unsigned K : 3;
-    unsigned Align : 29;
-    saved_type(llvm::Value *v, llvm::Type *e, Kind k, unsigned a = 0)
-      : Value(v), ElementType(e), K(k), Align(a) {}
+    unsigned IsVolatile : 1;
----------------
ahatanak wrote:

Prior to this commit, `DominatingValue<RValue>` didn't have any information about whether the saved `RValue` was volatile. I don't think we need that information.

`IsVolatile` should be removed. 

https://github.com/llvm/llvm-project/pull/86923


More information about the cfe-commits mailing list