mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Any size of integral indices are allowed in gep for indexing into sequential types. Also adding a test case to check the indices type allowed into struct.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@70134 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
efdb3bc8d0
commit
9341c808ae
@ -3629,7 +3629,7 @@ the pointer before continuing calculation.</p>
|
||||
<p>The type of each index argument depends on the type it is indexing into.
|
||||
When indexing into a (packed) structure, only <tt>i32</tt> integer
|
||||
<b>constants</b> are allowed. When indexing into an array, pointer or vector,
|
||||
only integers of 16, 32 or 64 bits are allowed (also non-constants). 16-bit
|
||||
integers of any width are allowed (also non-constants). 16-bit
|
||||
values will be sign extended to 32-bits if required, and 32-bit values
|
||||
will be sign extended to 64-bits if required.</p>
|
||||
|
||||
|
@ -1410,9 +1410,8 @@ void PointerType::typeBecameConcrete(const DerivedType *AbsTy) {
|
||||
}
|
||||
|
||||
bool SequentialType::indexValid(const Value *V) const {
|
||||
if (const IntegerType *IT = dyn_cast<IntegerType>(V->getType()))
|
||||
return IT->getBitWidth() == 16 || IT->getBitWidth() == 32 ||
|
||||
IT->getBitWidth() == 64;
|
||||
if (isa<IntegerType>(V->getType()))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
|
12
test/Assembler/getelementptr_struct.ll
Normal file
12
test/Assembler/getelementptr_struct.ll
Normal file
@ -0,0 +1,12 @@
|
||||
; RUN: not llvm-as < %s >/dev/null |& grep {invalid getelementptr indices}
|
||||
; Test the case of a incorrect indices type into struct
|
||||
|
||||
%RT = type { i8 , [10 x [20 x i32]], i8 }
|
||||
%ST = type { i32, double, %RT }
|
||||
|
||||
define i32* @foo(%ST* %s) {
|
||||
entry:
|
||||
%reg = getelementptr %ST* %s, i32 1, i64 2, i32 1, i32 5, i32 13
|
||||
ret i32* %reg
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user