; RUN: opt -passes=debugify,loop-vectorize \ ; RUN: -prefer-predicate-over-epilogue=predicate-else-scalar-epilogue \ ; RUN: -mtriple=riscv64 -mattr=+v -riscv-v-vector-bits-max=128 -S < %s 2>&1 | FileCheck --check-prefix=DEBUGLOC %s ; Testing the debug locations of the generated vector intrinsic is same as ; its scalar counterpart. define void @vp_select(ptr %a, ptr %b, ptr %c, i64 %N) { ; DEBUGLOC-LABEL: define void @vp_select( ; DEBUGLOC: vector.body: ; DEBUGLOC: = select %{{.+}}, %{{.+}}, %{{.+}}, !dbg ![[SELLOC:[0-9]+]] ; DEBUGLOC: loop: ; DEBUGLOC: = select i1 %{{.+}}, i32 %{{.+}}, i32 %{{.+}}, !dbg ![[SELLOC]] ; entry: br label %loop loop: %iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ] %gep.b = getelementptr inbounds i32, ptr %b, i64 %iv %load.b = load i32, ptr %gep.b, align 4 %gep.c = getelementptr inbounds i32, ptr %c, i64 %iv %load.c = load i32, ptr %gep.c, align 4 %cmp = icmp sgt i32 %load.b, %load.c %neg.c = sub i32 0, %load.c %sel = select i1 %cmp, i32 %load.c, i32 %neg.c %add = add i32 %sel, %load.b %gep.a = getelementptr inbounds i32, ptr %a, i64 %iv store i32 %add, ptr %gep.a, align 4 %iv.next = add nuw nsw i64 %iv, 1 %exitcond = icmp eq i64 %iv.next, %N br i1 %exitcond, label %exit, label %loop exit: ret void } ; DEBUGLOC: [[SELLOC]] = !DILocation(line: 9