From: David Bolvansky Date: Wed, 14 Aug 2019 11:13:10 +0000 (+0000) Subject: [NFC] Make test more robust X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2332a7c82705b85d8c8c86408ad417a4ed9c24fa;p=clang [NFC] Make test more robust Currently fails on ARMs git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@368828 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGen/struct-copy.c b/test/CodeGen/struct-copy.c index a03bb7d658..029361b0c7 100644 --- a/test/CodeGen/struct-copy.c +++ b/test/CodeGen/struct-copy.c @@ -1,39 +1,17 @@ -// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py // RUN: %clang_cc1 -emit-llvm %s -o - | FileCheck %s struct x { int a[100]; }; -// CHECK-LABEL: @foo( -// CHECK-NEXT: entry: -// CHECK-NEXT: [[P_ADDR:%.*]] = alloca %struct.x*, align 8 -// CHECK-NEXT: [[Q_ADDR:%.*]] = alloca %struct.x*, align 8 -// CHECK-NEXT: store %struct.x* [[P:%.*]], %struct.x** [[P_ADDR]], align 8 -// CHECK-NEXT: store %struct.x* [[Q:%.*]], %struct.x** [[Q_ADDR]], align 8 -// CHECK-NEXT: [[TMP0:%.*]] = load %struct.x*, %struct.x** [[P_ADDR]], align 8 -// CHECK-NEXT: [[TMP1:%.*]] = load %struct.x*, %struct.x** [[Q_ADDR]], align 8 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast %struct.x* [[TMP0]] to i8* -// CHECK-NEXT: [[TMP3:%.*]] = bitcast %struct.x* [[TMP1]] to i8* -// CHECK-NEXT: call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 4 [[TMP2]], i8* align 4 [[TMP3]], i64 400, i1 false) -// CHECK-NEXT: ret void -// + void foo(struct x *P, struct x *Q) { +// CHECK-LABEL: @foo( +// CHECK: call void @llvm.memcpy.p0i8.p0i8.i64 *P = *Q; } // CHECK: declare void @llvm.memcpy.p0i8.p0i8.i64(i8* noalias nocapture writeonly, i8* noalias nocapture readonly, i64, i1 immarg) -// CHECK-LABEL: @bar( -// CHECK-NEXT: entry: -// CHECK-NEXT: [[P_ADDR:%.*]] = alloca %struct.x*, align 8 -// CHECK-NEXT: [[Q_ADDR:%.*]] = alloca %struct.x*, align 8 -// CHECK-NEXT: store %struct.x* [[P:%.*]], %struct.x** [[P_ADDR]], align 8 -// CHECK-NEXT: store %struct.x* [[Q:%.*]], %struct.x** [[Q_ADDR]], align 8 -// CHECK-NEXT: [[TMP0:%.*]] = load %struct.x*, %struct.x** [[P_ADDR]], align 8 -// CHECK-NEXT: [[TMP1:%.*]] = bitcast %struct.x* [[TMP0]] to i8* -// CHECK-NEXT: [[TMP2:%.*]] = load %struct.x*, %struct.x** [[Q_ADDR]], align 8 -// CHECK-NEXT: [[TMP3:%.*]] = bitcast %struct.x* [[TMP2]] to i8* -// CHECK-NEXT: call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 4 [[TMP1]], i8* align 4 [[TMP3]], i64 400, i1 false) -// CHECK-NEXT: ret void -// void bar(struct x *P, struct x *Q) { +// CHECK-LABEL: @bar( +// CHECK: call void @llvm.memcpy.p0i8.p0i8.i64 __builtin_memcpy(P, Q, sizeof(struct x)); }