Much to my surprise, '-disable-llvm-optzns' which I thought was the magical flag I wanted to get at the raw LLVM IR coming out of Clang deosn't do that. It still runs some passes over the IR. I don't want that, I really want the *raw* IR coming out of Clang and I strongly suspect everyone else using it is in the same camp. There is actually a flag that does what I want that I didn't know about called '-disable-llvm-passes'. I suspect many others don't know about it either. It both does what I want and is much simpler. This removes the confusing version and makes that spelling of the flag an alias for '-disable-llvm-passes'. I've also moved everything in Clang to use the 'passes' spelling as it seems both more accurate (*all* LLVM passes are disabled, not just optimizations) and much easier to remember and spell correctly. This is part of simplifying how Clang drives LLVM to make it cleaner to wire up to the new pass manager. Differential Revision: https://reviews.llvm.org/D28047 llvm-svn: 290392
159 lines
6.2 KiB
C
159 lines
6.2 KiB
C
// RUN: %clang_cc1 -verify -fopenmp -x c -emit-llvm %s -triple %itanium_abi_triple -o - -femit-all-decls -disable-llvm-passes | FileCheck %s
|
|
// RUN: %clang_cc1 -fopenmp -x c -triple %itanium_abi_triple -emit-pch -o %t %s -femit-all-decls -disable-llvm-passes
|
|
// RUN: %clang_cc1 -fopenmp -x c -triple %itanium_abi_triple -include-pch %t -verify %s -emit-llvm -o - -femit-all-decls -disable-llvm-passes | FileCheck --check-prefix=CHECK-LOAD %s
|
|
// expected-no-diagnostics
|
|
|
|
#ifndef HEADER
|
|
#define HEADER
|
|
|
|
// CHECK: [[SSS_INT:.+]] = type { i32 }
|
|
// CHECK-LOAD: [[SSS_INT:.+]] = type { i32 }
|
|
|
|
#pragma omp declare reduction(+ : int, char : omp_out *= omp_in)
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(i32* noalias, i32* noalias)
|
|
// CHECK: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-NEXT: store i32 [[MUL]], i32*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(i32* noalias, i32* noalias)
|
|
// CHECK-LOAD: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-LOAD-NEXT: store i32 [[MUL]], i32*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(i8* noalias, i8* noalias)
|
|
// CHECK: sext i8
|
|
// CHECK: sext i8
|
|
// CHECK: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-NEXT: [[TRUNC:%.+]] = trunc i32 [[MUL]] to i8
|
|
// CHECK-NEXT: store i8 [[TRUNC]], i8*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(i8* noalias, i8* noalias)
|
|
// CHECK-LOAD: sext i8
|
|
// CHECK-LOAD: sext i8
|
|
// CHECK-LOAD: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-LOAD-NEXT: [[TRUNC:%.+]] = trunc i32 [[MUL]] to i8
|
|
// CHECK-LOAD-NEXT: store i8 [[TRUNC]], i8*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
|
|
#pragma omp declare reduction(fun : float : omp_out += omp_in) initializer(omp_priv = 15 + omp_orig)
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(float* noalias, float* noalias)
|
|
// CHECK: [[ADD:%.+]] = fadd float
|
|
// CHECK-NEXT: store float [[ADD]], float*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(float* noalias, float* noalias)
|
|
// CHECK: [[ADD:%.+]] = fadd float 1.5
|
|
// CHECK-NEXT: store float [[ADD]], float*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(float* noalias, float* noalias)
|
|
// CHECK-LOAD: [[ADD:%.+]] = fadd float
|
|
// CHECK-LOAD-NEXT: store float [[ADD]], float*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(float* noalias, float* noalias)
|
|
// CHECK-LOAD: [[ADD:%.+]] = fadd float 1.5
|
|
// CHECK-LOAD-NEXT: store float [[ADD]], float*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
|
|
struct SSS {
|
|
int field;
|
|
#pragma omp declare reduction(+ : int, char : omp_out *= omp_in)
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(i32* noalias, i32* noalias)
|
|
// CHECK: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-NEXT: store i32 [[MUL]], i32*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}(i8* noalias, i8* noalias)
|
|
// CHECK: sext i8
|
|
// CHECK: sext i8
|
|
// CHECK: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-NEXT: [[TRUNC:%.+]] = trunc i32 [[MUL]] to i8
|
|
// CHECK-NEXT: store i8 [[TRUNC]], i8*
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
};
|
|
|
|
void init(struct SSS *priv, struct SSS orig);
|
|
|
|
#pragma omp declare reduction(fun : struct SSS : omp_out = omp_in) initializer(init(&omp_priv, omp_orig))
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @llvm.memcpy
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @init(
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @llvm.memcpy
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @init(
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
|
|
// CHECK-LABEL: @main
|
|
// CHECK-LOAD-LABEL: @main
|
|
int main() {
|
|
#pragma omp declare reduction(fun : struct SSS : omp_out = omp_in) initializer(init(&omp_priv, omp_orig))
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @llvm.memcpy
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @init(
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @llvm.memcpy
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @init(
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
{
|
|
#pragma omp declare reduction(fun : struct SSS : omp_out = omp_in) initializer(init(&omp_priv, omp_orig))
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @llvm.memcpy
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK: call void @init(
|
|
// CHECK-NEXT: ret void
|
|
// CHECK-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @llvm.memcpy
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}([[SSS_INT]]* noalias, [[SSS_INT]]* noalias)
|
|
// CHECK-LOAD: call void @init(
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(i32* noalias, i32* noalias)
|
|
// CHECK-LOAD: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-LOAD-NEXT: store i32 [[MUL]], i32*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
|
|
// CHECK-LOAD: define internal {{.*}}void @{{[^(]+}}(i8* noalias, i8* noalias)
|
|
// CHECK-LOAD: sext i8
|
|
// CHECK-LOAD: sext i8
|
|
// CHECK-LOAD: [[MUL:%.+]] = mul nsw i32
|
|
// CHECK-LOAD-NEXT: [[TRUNC:%.+]] = trunc i32 [[MUL]] to i8
|
|
// CHECK-LOAD-NEXT: store i8 [[TRUNC]], i8*
|
|
// CHECK-LOAD-NEXT: ret void
|
|
// CHECK-LOAD-NEXT: }
|
|
#endif
|