xref: /aosp_15_r20/external/llvm/test/Assembler/getelementptr_vec_idx2.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: not llvm-as < %s >/dev/null 2> %t
2*9880d681SAndroid Build Coastguard Worker; RUN: FileCheck %s < %t
3*9880d681SAndroid Build Coastguard Worker; Test that a vector pointer may be used with a scalar index.
4*9880d681SAndroid Build Coastguard Worker; Test that a vector pointer and vector index should have the same vector width
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker; This code is correct
7*9880d681SAndroid Build Coastguard Workerdefine <2 x i32*> @test2(<2 x i32*> %a) {
8*9880d681SAndroid Build Coastguard Worker  %w = getelementptr i32, <2 x i32*> %a, i32 2
9*9880d681SAndroid Build Coastguard Worker  ret <2 x i32*> %w
10*9880d681SAndroid Build Coastguard Worker}
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker; This code is correct
13*9880d681SAndroid Build Coastguard Workerdefine <2 x i32*> @test3(i32* %a) {
14*9880d681SAndroid Build Coastguard Worker  %w = getelementptr i32, i32* %a, <2 x i32> <i32 2, i32 2>
15*9880d681SAndroid Build Coastguard Worker  ret <2 x i32*> %w
16*9880d681SAndroid Build Coastguard Worker}
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Worker; CHECK: getelementptr vector index has a wrong number of elements
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Workerdefine <2 x i32> @test1(<2 x i32*> %a) {
21*9880d681SAndroid Build Coastguard Worker  %w = getelementptr i32, <2 x i32*> %a, <4 x i32><i32 2, i32 2, i32 2, i32 2>
22*9880d681SAndroid Build Coastguard Worker  ret <2 x i32> %w
23*9880d681SAndroid Build Coastguard Worker}
24*9880d681SAndroid Build Coastguard Worker
25