1*9880d681SAndroid Build Coastguard Worker; RUN: opt -pre-isel-intrinsic-lowering -S -o - %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: opt -passes='pre-isel-intrinsic-lowering' -S -o - %s | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; CHECK: define i8* @foo32(i8* [[P:%.*]], i32 [[O:%.*]]) 5*9880d681SAndroid Build Coastguard Workerdefine i8* @foo32(i8* %p, i32 %o) { 6*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OP:%.*]] = getelementptr i8, i8* [[P]], i32 [[O]] 7*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OPI32:%.*]] = bitcast i8* [[OP]] to i32* 8*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OI32:%.*]] = load i32, i32* [[OPI32]], align 4 9*9880d681SAndroid Build Coastguard Worker ; CHECK: [[R:%.*]] = getelementptr i8, i8* [[P]], i32 [[OI32]] 10*9880d681SAndroid Build Coastguard Worker ; CHECK: ret i8* [[R]] 11*9880d681SAndroid Build Coastguard Worker %l = call i8* @llvm.load.relative.i32(i8* %p, i32 %o) 12*9880d681SAndroid Build Coastguard Worker ret i8* %l 13*9880d681SAndroid Build Coastguard Worker} 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; CHECK: define i8* @foo64(i8* [[P:%.*]], i64 [[O:%.*]]) 16*9880d681SAndroid Build Coastguard Workerdefine i8* @foo64(i8* %p, i64 %o) { 17*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OP:%.*]] = getelementptr i8, i8* [[P]], i64 [[O]] 18*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OPI32:%.*]] = bitcast i8* [[OP]] to i32* 19*9880d681SAndroid Build Coastguard Worker ; CHECK: [[OI32:%.*]] = load i32, i32* [[OPI32]], align 4 20*9880d681SAndroid Build Coastguard Worker ; CHECK: [[R:%.*]] = getelementptr i8, i8* [[P]], i32 [[OI32]] 21*9880d681SAndroid Build Coastguard Worker ; CHECK: ret i8* [[R]] 22*9880d681SAndroid Build Coastguard Worker %l = call i8* @llvm.load.relative.i64(i8* %p, i64 %o) 23*9880d681SAndroid Build Coastguard Worker ret i8* %l 24*9880d681SAndroid Build Coastguard Worker} 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.load.relative.i32(i8*, i32) 27*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.load.relative.i64(i8*, i64) 28