diff --git a/llvm/include/llvm/CodeGen/MachineMemOperand.h b/llvm/include/llvm/CodeGen/MachineMemOperand.h --- a/llvm/include/llvm/CodeGen/MachineMemOperand.h +++ b/llvm/include/llvm/CodeGen/MachineMemOperand.h @@ -169,7 +169,7 @@ MachinePointerInfo PtrInfo; uint64_t Size; Flags FlagVals; - uint16_t BaseAlignLog2; // log_2(base_alignment) + 1 + MaybeAlign BaseAlign; MachineAtomicInfo AtomicInfo; AAMDNodes AAInfo; const MDNode *Ranges; @@ -229,7 +229,9 @@ /// Return the minimum known alignment in bytes of the base address, without /// the offset. - uint64_t getBaseAlignment() const { return (1ull << BaseAlignLog2) >> 1; } + uint64_t getBaseAlignment() const { + return BaseAlign ? BaseAlign->value() : 0; + } /// Return the AA tags for the memory reference. AAMDNodes getAAInfo() const { return AAInfo; } diff --git a/llvm/lib/CodeGen/MachineOperand.cpp b/llvm/lib/CodeGen/MachineOperand.cpp --- a/llvm/lib/CodeGen/MachineOperand.cpp +++ b/llvm/lib/CodeGen/MachineOperand.cpp @@ -1009,8 +1009,8 @@ const MDNode *Ranges, SyncScope::ID SSID, AtomicOrdering Ordering, AtomicOrdering FailureOrdering) - : PtrInfo(ptrinfo), Size(s), FlagVals(f), BaseAlignLog2(Log2_32(a) + 1), - AAInfo(AAInfo), Ranges(Ranges) { + : PtrInfo(ptrinfo), Size(s), FlagVals(f), BaseAlign(a), AAInfo(AAInfo), + Ranges(Ranges) { assert((PtrInfo.V.isNull() || PtrInfo.V.is() || isa(PtrInfo.V.get()->getType())) && "invalid pointer value"); @@ -1043,7 +1043,7 @@ if (MMO->getBaseAlignment() >= getBaseAlignment()) { // Update the alignment value. - BaseAlignLog2 = Log2_32(MMO->getBaseAlignment()) + 1; + BaseAlign = MaybeAlign(MMO->getBaseAlignment()); // Also update the base and offset, because the new alignment may // not be applicable with the old ones. PtrInfo = MMO->PtrInfo;