[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