mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-25 07:36:06 +00:00

Currently, the builtins used for implementing `va_list` handling unconditionally take their arguments as unqualified `ptr`s i.e. pointers to AS 0. This does not work for targets where the default AS is not 0 or AS 0 is not a viable AS (for example, a target might choose 0 to represent the constant address space). This patch changes the builtins' signature to take generic `anyptr` args, which corrects this issue. It is noisy due to the number of tests affected. A test for an upstream target which does not use 0 as its default AS (SPIRV for HIP device compilations) is added as well.
88 lines
4.1 KiB
C++
88 lines
4.1 KiB
C++
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
|
|
// RUN: %clang_cc1 -emit-llvm %s -o - -triple x86_64-unknown-linux-gnu | FileCheck %s
|
|
|
|
bool e();
|
|
|
|
void operator delete(void*);
|
|
|
|
// CHECK-LABEL: @_Z1fPiz(
|
|
// CHECK-NEXT: entry:
|
|
// CHECK-NEXT: [[P_ADDR:%.*]] = alloca ptr, align 8
|
|
// CHECK-NEXT: [[L:%.*]] = alloca [1 x %struct.__va_list_tag], align 16
|
|
// CHECK-NEXT: [[L2:%.*]] = alloca [1 x %struct.__va_list_tag], align 16
|
|
// CHECK-NEXT: store ptr [[P:%.*]], ptr [[P_ADDR]], align 8
|
|
// CHECK-NEXT: [[CALL:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL]], label [[COND_TRUE:%.*]], label [[COND_FALSE:%.*]]
|
|
// CHECK: cond.true:
|
|
// CHECK-NEXT: call void @llvm.trap()
|
|
// CHECK-NEXT: br label [[COND_END:%.*]]
|
|
// CHECK: cond.false:
|
|
// CHECK-NEXT: br label [[COND_END]]
|
|
// CHECK: cond.end:
|
|
// CHECK-NEXT: [[CALL1:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL1]], label [[COND_TRUE2:%.*]], label [[COND_FALSE3:%.*]]
|
|
// CHECK: cond.true2:
|
|
// CHECK-NEXT: call void @llvm.debugtrap()
|
|
// CHECK-NEXT: br label [[COND_END4:%.*]]
|
|
// CHECK: cond.false3:
|
|
// CHECK-NEXT: br label [[COND_END4]]
|
|
// CHECK: cond.end4:
|
|
// CHECK-NEXT: [[CALL5:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: [[TMP0:%.*]] = zext i1 [[CALL5]] to i64
|
|
// CHECK-NEXT: call void @llvm.assume(i1 true)
|
|
// CHECK-NEXT: [[CALL6:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL6]], label [[COND_TRUE7:%.*]], label [[COND_FALSE8:%.*]]
|
|
// CHECK: cond.true7:
|
|
// CHECK-NEXT: [[ARRAYDECAY:%.*]] = getelementptr inbounds [1 x %struct.__va_list_tag], ptr [[L]], i64 0, i64 0
|
|
// CHECK-NEXT: call void @llvm.va_start.p0(ptr [[ARRAYDECAY]])
|
|
// CHECK-NEXT: br label [[COND_END9:%.*]]
|
|
// CHECK: cond.false8:
|
|
// CHECK-NEXT: br label [[COND_END9]]
|
|
// CHECK: cond.end9:
|
|
// CHECK-NEXT: [[CALL10:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL10]], label [[COND_TRUE11:%.*]], label [[COND_FALSE14:%.*]]
|
|
// CHECK: cond.true11:
|
|
// CHECK-NEXT: [[ARRAYDECAY12:%.*]] = getelementptr inbounds [1 x %struct.__va_list_tag], ptr [[L]], i64 0, i64 0
|
|
// CHECK-NEXT: [[ARRAYDECAY13:%.*]] = getelementptr inbounds [1 x %struct.__va_list_tag], ptr [[L2]], i64 0, i64 0
|
|
// CHECK-NEXT: call void @llvm.va_copy.p0(ptr [[ARRAYDECAY12]], ptr [[ARRAYDECAY13]])
|
|
// CHECK-NEXT: br label [[COND_END15:%.*]]
|
|
// CHECK: cond.false14:
|
|
// CHECK-NEXT: br label [[COND_END15]]
|
|
// CHECK: cond.end15:
|
|
// CHECK-NEXT: [[CALL16:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL16]], label [[COND_TRUE17:%.*]], label [[COND_FALSE18:%.*]]
|
|
// CHECK: cond.true17:
|
|
// CHECK-NEXT: [[TMP1:%.*]] = load ptr, ptr [[P_ADDR]], align 8
|
|
// CHECK-NEXT: call void @llvm.prefetch.p0(ptr [[TMP1]], i32 0, i32 3, i32 1)
|
|
// CHECK-NEXT: br label [[COND_END19:%.*]]
|
|
// CHECK: cond.false18:
|
|
// CHECK-NEXT: br label [[COND_END19]]
|
|
// CHECK: cond.end19:
|
|
// CHECK-NEXT: [[CALL20:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: br i1 [[CALL20]], label [[COND_TRUE21:%.*]], label [[COND_FALSE22:%.*]]
|
|
// CHECK: cond.true21:
|
|
// CHECK-NEXT: call void @llvm.eh.unwind.init()
|
|
// CHECK-NEXT: br label [[COND_END23:%.*]]
|
|
// CHECK: cond.false22:
|
|
// CHECK-NEXT: br label [[COND_END23]]
|
|
// CHECK: cond.end23:
|
|
// CHECK-NEXT: [[CALL24:%.*]] = call noundef zeroext i1 @_Z1ev()
|
|
// CHECK-NEXT: [[TMP2:%.*]] = zext i1 [[CALL24]] to i64
|
|
// CHECK-NEXT: [[TMP3:%.*]] = load ptr, ptr [[P_ADDR]], align 8
|
|
// CHECK-NEXT: call void @_ZdlPv(ptr noundef [[TMP3]]) #[[ATTR8:[0-9]+]]
|
|
// CHECK-NEXT: ret void
|
|
//
|
|
void f(int* p, ...)
|
|
{
|
|
e() ? __builtin_trap() : void();
|
|
e() ? __builtin_debugtrap() : void();
|
|
e() ? __builtin_assume(true) : void();
|
|
__builtin_va_list l;
|
|
e() ? __builtin_va_start(l, p) : void();
|
|
__builtin_va_list l2;
|
|
e() ? __builtin_va_copy(l, l2) : void();
|
|
e() ? __builtin_prefetch(p) : void();
|
|
e() ? __builtin_unwind_init() : void();
|
|
e() ? __builtin_operator_delete(p) : void();
|
|
}
|