// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py // REQUIRES: powerpc-registered-target // RUN: %clang_cc1 -triple powerpc64-unknown-linux-gnu \ // RUN: -emit-llvm %s -o - -target-cpu pwr7 | FileCheck %s // RUN: %clang_cc1 -triple powerpc64le-unknown-linux-gnu \ // RUN: -emit-llvm %s -o - -target-cpu pwr8 | FileCheck %s // The argument expression must not be emitted multiple times // CHECK-LABEL: @test_fric( // CHECK-NEXT: entry: // CHECK-NEXT: [[D:%.*]] = alloca double, align 8 // CHECK-NEXT: [[TMP:%.*]] = alloca double, align 8 // CHECK-NEXT: [[TMP0:%.*]] = load double, ptr [[D]], align 8 // CHECK-NEXT: store double [[TMP0]], ptr [[TMP]], align 8 // CHECK-NEXT: [[TMP1:%.*]] = load double, ptr [[TMP]], align 8 // CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.rint.f64(double [[TMP1]]) // CHECK-NEXT: ret void // void test_fric() { __fric(({double d; d;})); }