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