xref: /llvm-project/llvm/test/Transforms/SampleProfile/pseudo-probe-twoaddr.ll (revision c81a121f3f230cfe468b6def6d2904b4aefb855b)
13a5f8a3eSHongtao Yu; REQUIRES: x86_64-linux
21cb47a06SHongtao Yu; RUN: llc -stop-after=twoaddressinstruction -mtriple=x86_64-- -o - %s | FileCheck %s
31cb47a06SHongtao Yu
41cb47a06SHongtao Yu
525450788SNikita Popovdefine dso_local double @twoaddressinstruction(i1 %c) local_unnamed_addr {
61cb47a06SHongtao Yufor.end:
70271ae65SFangrui Song  %0 = load i64, ptr undef, align 8
81cb47a06SHongtao Yu  br label %for.body14.preheader
91cb47a06SHongtao Yu
101cb47a06SHongtao Yufor.body14.preheader:                             ; preds = %for.end
1125450788SNikita Popov  br i1 %c, label %for.cond25.preheader.loopexit.unr-lcssa, label %for.body14.preheader.new
121cb47a06SHongtao Yu
131cb47a06SHongtao Yufor.body14.preheader.new:                         ; preds = %for.body14.preheader
141cb47a06SHongtao Yu  %unroll_iter136 = and i64 %0, -4
151cb47a06SHongtao Yu  br label %for.body14
161cb47a06SHongtao Yu
171cb47a06SHongtao Yufor.cond25.preheader.loopexit.unr-lcssa:          ; preds = %for.body14, %for.body14.preheader
181cb47a06SHongtao Yu  %indvars.iv127.unr = phi i64 [ 1, %for.body14.preheader ], [ %indvars.iv.next128.3, %for.body14 ]
191cb47a06SHongtao Yu  ret double undef
201cb47a06SHongtao Yu
211cb47a06SHongtao Yufor.body14:                                       ; preds = %for.body14, %for.body14.preheader.new
221cb47a06SHongtao Yu  %indvars.iv127 = phi i64 [ 1, %for.body14.preheader.new ], [ %indvars.iv.next128.3, %for.body14 ]
231cb47a06SHongtao Yu  %niter137 = phi i64 [ %unroll_iter136, %for.body14.preheader.new ], [ %niter137.nsub.3, %for.body14 ]
241cb47a06SHongtao Yu  %indvars.iv.next128.3 = add nuw nsw i64 %indvars.iv127, 4
251cb47a06SHongtao Yu; CHECK: PSEUDO_PROBE -6878943695821059507, 9, 0, 0
261cb47a06SHongtao Yu  call void @llvm.pseudoprobe(i64 -6878943695821059507, i64 9, i32 0, i64 -1)
271cb47a06SHongtao Yu;; Check an opeq form of instruction is created.
281cb47a06SHongtao Yu; CHECK: %[[#REG:]]:gr64_nosp = COPY killed %[[#]]
29*c81a121fSShengchen Kan; CHECK: %[[#REG]]:gr64_nosp = nuw ADD64ri32 %[[#REG]], 4, implicit-def dead $eflags
301cb47a06SHongtao Yu  %niter137.nsub.3 = add i64 %niter137, -4
311cb47a06SHongtao Yu  %niter137.ncmp.3 = icmp eq i64 %niter137.nsub.3, 0
321cb47a06SHongtao Yu  br i1 %niter137.ncmp.3, label %for.cond25.preheader.loopexit.unr-lcssa, label %for.body14
331cb47a06SHongtao Yu}
341cb47a06SHongtao Yu
351cb47a06SHongtao Yu; Function Attrs: inaccessiblememonly nounwind willreturn
361cb47a06SHongtao Yudeclare void @llvm.pseudoprobe(i64, i64, i32, i64) #0
371cb47a06SHongtao Yu
381cb47a06SHongtao Yuattributes #0 = { inaccessiblememonly nounwind willreturn }
39