Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view test/CodeGen/NVPTX/branch-fold.ll @ 100:7d135dc70f03
LLVM 3.9
author | Miyagi Mitsuki <e135756@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 26 Jan 2016 22:53:40 +0900 |
parents | afa8332a0e37 |
children |
line wrap: on
line source
; RUN: llc < %s -march=nvptx64 -mcpu=sm_35 -disable-cgp | FileCheck %s ; Disable CGP which also folds branches, so that only BranchFolding is under ; the spotlight. target datalayout = "e-i64:64-v16:16-v32:32-n16:32:64" target triple = "nvptx64-nvidia-cuda" define void @foo(i32 %x, float* %output) { ; CHECK-LABEL: .visible .func foo( ; CHECK-NOT: bra.uni ; CHECK-NOT: LBB0_ %1 = icmp eq i32 %x, 1 br i1 %1, label %then, label %else then: br label %merge else: br label %merge merge: store float 2.0, float* %output ret void } ; PR24299. no crash define ptx_kernel void @hoge() #0 { ; CHECK-LABEL: .visible .entry hoge( bb: br i1 undef, label %bb1, label %bb4 bb1: ; preds = %bb1, %bb %tmp = phi i64 [ %tmp2, %bb1 ], [ undef, %bb ] %tmp2 = add nsw i64 %tmp, 1 %tmp3 = icmp sle i64 %tmp, 0 br i1 %tmp3, label %bb1, label %bb4 bb4: ; preds = %bb4, %bb1, %bb br label %bb4 }