|
| 1 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fclangir -emit-cir %s -o %t.cir |
| 2 | +// RUN: FileCheck --input-file=%t.cir %s -check-prefix=CIR |
| 3 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fclangir -emit-llvm %s -o %t.ll |
| 4 | +// RUN: FileCheck --input-file=%t.ll %s -check-prefix=LLVM |
| 5 | +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -emit-llvm %s -o %t.ll |
| 6 | +// RUN: FileCheck --input-file=%t.ll %s -check-prefix=LLVM |
| 7 | + |
| 8 | +static int a[10]{}; |
| 9 | +// CIR: cir.global "private" internal dso_local @_ZL1a = #cir.zero : !cir.array<!s32i x 10> {alignment = 16 : i64} |
| 10 | +// LLVM: @_ZL1a = internal global [10 x i32] zeroinitializer, align 16 |
| 11 | + |
| 12 | +struct NonTrivialDestructor { |
| 13 | + ~NonTrivialDestructor(); |
| 14 | +}; |
| 15 | +struct BiggerNonTrivialDestructor { |
| 16 | + int array[12]; |
| 17 | + ~BiggerNonTrivialDestructor(); |
| 18 | +}; |
| 19 | + |
| 20 | +void use() { |
| 21 | + for (int i : a) {} |
| 22 | + // This happens 3x (range + begin + end), but they all use the same code, sox |
| 23 | + // only test it 1x. Ensure the alignment is correct. |
| 24 | + // CIR: %[[GLOBAL_A:.*]] = cir.const #cir.global_view<@_ZL1a> : !cir.ptr<!cir.array<!s32i x 10>> |
| 25 | + // CIR: cir.store align(8) %[[GLOBAL_A]], %{{.*}} : !cir.ptr<!cir.array<!s32i x 10>>, !cir.ptr<!cir.ptr<!cir.array<!s32i x 10>>> |
| 26 | + // LLVM: store ptr getelementptr inbounds nuw (i8, ptr @_ZL1a, i64 40), ptr %{{.*}}, align 8 |
| 27 | + |
| 28 | + // Make sure we get alignment correct here. |
| 29 | + NonTrivialDestructor a; |
| 30 | + // CIR-DAG: cir.call @_ZN20NonTrivialDestructorD1Ev{{.*}}llvm.align = 1 |
| 31 | + // LLVM-DAG: call void @_ZN20NonTrivialDestructorD1Ev(ptr {{.*}}align 1 |
| 32 | + BiggerNonTrivialDestructor b; |
| 33 | + // CIR-DAG: cir.call @_ZN26BiggerNonTrivialDestructorD1Ev{{.*}}llvm.align = 4 |
| 34 | + // LLVM-DAG: call void @_ZN26BiggerNonTrivialDestructorD1Ev(ptr {{.*}}align 4 |
| 35 | +} |
0 commit comments