mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-26 05:32:25 +00:00
Make GlobalValue alignment consistent with load, store, and alloca
alignment, fixing silent truncation of alignment values. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@109653 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4c010ec851
commit
6bbe671e1c
@ -74,11 +74,10 @@ public:
|
||||
removeDeadConstantUsers(); // remove any dead constants using this.
|
||||
}
|
||||
|
||||
unsigned getAlignment() const { return Alignment; }
|
||||
void setAlignment(unsigned Align) {
|
||||
assert((Align & (Align-1)) == 0 && "Alignment is not a power of 2!");
|
||||
Alignment = Align;
|
||||
unsigned getAlignment() const {
|
||||
return (1u << Alignment) >> 1;
|
||||
}
|
||||
void setAlignment(unsigned Align);
|
||||
|
||||
VisibilityTypes getVisibility() const { return VisibilityTypes(Visibility); }
|
||||
bool hasDefaultVisibility() const { return Visibility == DefaultVisibility; }
|
||||
|
@ -102,6 +102,13 @@ void GlobalValue::copyAttributesFrom(const GlobalValue *Src) {
|
||||
setVisibility(Src->getVisibility());
|
||||
}
|
||||
|
||||
void GlobalValue::setAlignment(unsigned Align) {
|
||||
assert((Align & (Align-1)) == 0 && "Alignment is not a power of 2!");
|
||||
assert(Align <= MaximumAlignment &&
|
||||
"Alignment is greater than MaximumAlignment!");
|
||||
Alignment = Log2_32(Align) + 1;
|
||||
assert(getAlignment() == Align && "Alignment representation error!");
|
||||
}
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// GlobalVariable Implementation
|
||||
|
@ -1,5 +1,7 @@
|
||||
; RUN: llvm-as %s -o /dev/null
|
||||
|
||||
@A = global i1 0, align 536870912
|
||||
|
||||
define void @foo() {
|
||||
%p = alloca i1, align 536870912
|
||||
load i1* %p, align 536870912
|
||||
|
Loading…
Reference in New Issue
Block a user