; RUN: opt %loadPolly -polly-codegen-ppcg -polly-acc-dump-code \ ; RUN: -polly-invariant-load-hoisting \ ; RUN: -S -polly-acc-codegen-managed-memory < %s | FileCheck %s ; RUN: opt %loadPolly -polly-codegen-ppcg -polly-acc-dump-code \ ; RUN: -polly-invariant-load-hoisting \ ; RUN: -S -polly-acc-codegen-managed-memory -disable-output \ ; RUN: -polly-acc-dump-code < %s | FileCheck %s -check-prefix=CODE ; REQUIRES: pollyacc ; CHECK: @polly_launchKernel ; CHECK: @polly_launchKernel ; CHECK: @polly_launchKernel ; CHECK: @polly_launchKernel ; CHECK: @polly_launchKernel ; CHECK-NOT: @polly_launchKernel ; CODE: if (p_0_loaded_from___data_runcontrol_MOD_lmulti_layer == 0) { ; CODE-NEXT: { ; CODE-NEXT: dim3 k0_dimBlock; ; CODE-NEXT: dim3 k0_dimGrid; ; CODE-NEXT: kernel0 <<>> (dev_MemRef__pn__phi, p_0_loaded_from___data_runcontrol_MOD_lmulti_layer); ; CODE-NEXT: cudaCheckKernel(); ; CODE-NEXT: } ; CODE: } else { ; CODE-NEXT: { ; CODE-NEXT: dim3 k1_dimBlock; ; CODE-NEXT: dim3 k1_dimGrid; ; CODE-NEXT: kernel1 <<>> (dev_MemRef__pn__phi, p_0_loaded_from___data_runcontrol_MOD_lmulti_layer); ; CODE-NEXT: cudaCheckKernel(); ; CODE-NEXT: } ; CHECK that this program is correctly code generated and does not result in ; 'instruction does not dominate use' errors. At an earlier point, such errors ; have been generated as the preparation of the managed memory pointers was ; performed right before kernel0, which does not dominate all other kernels. ; Now the preparation is performed at the very beginning of the scop. source_filename = "bugpoint-output-c78f41e.bc" target datalayout = "e-p:64:64:64-S128-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f16:16:16-f32:32:32-f64:64:64-f128:128:128-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" target triple = "x86_64-unknown-linux-gnu" @__data_radiation_MOD_rad_csalbw = external global [10 x double], align 32 @__data_radiation_MOD_coai = external global [168 x double], align 32 @__data_runcontrol_MOD_lmulti_layer = external global i32 ; Function Attrs: nounwind uwtable define void @__radiation_interface_MOD_radiation_init() #0 { entry: br label %"94" "94": ; preds = %"97", %entry br label %"95" "95": ; preds = %"95", %"94" br i1 undef, label %"97", label %"95" "97": ; preds = %"95" br i1 undef, label %"99", label %"94" "99": ; preds = %"97" br label %"102" "102": ; preds = %"102", %"99" %indvars.iv17 = phi i64 [ %indvars.iv.next18, %"102" ], [ 1, %"99" ] %0 = getelementptr [168 x double], [168 x double]* @__data_radiation_MOD_coai, i64 0, i64 0 store double 1.000000e+00, double* %0, align 8 %1 = icmp eq i64 %indvars.iv17, 3 %indvars.iv.next18 = add nuw nsw i64 %indvars.iv17, 1 br i1 %1, label %"110", label %"102" "110": ; preds = %"102" %2 = load i32, i32* @__data_runcontrol_MOD_lmulti_layer, align 4, !range !0 %3 = icmp eq i32 %2, 0 br i1 %3, label %"112", label %"111" "111": ; preds = %"110" br label %"115" "112": ; preds = %"110" br label %"115" "115": ; preds = %"112", %"111" %.pn = phi double [ undef, %"112" ], [ undef, %"111" ] %4 = fdiv double 1.000000e+00, %.pn br label %"116" "116": ; preds = %"116", %"115" %indvars.iv = phi i64 [ %indvars.iv.next, %"116" ], [ 1, %"115" ] %5 = add nsw i64 %indvars.iv, -1 %6 = fmul double %4, undef %7 = getelementptr [10 x double], [10 x double]* @__data_radiation_MOD_rad_csalbw, i64 0, i64 %5 store double %6, double* %7, align 8 %8 = icmp eq i64 %indvars.iv, 10 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 br i1 %8, label %return, label %"116" return: ; preds = %"116" ret void } attributes #0 = { nounwind uwtable } !0 = !{i32 0, i32 2}