; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 4 ; RUN: opt -S -passes=jump-threading < %s | FileCheck %s @f = external global i32 ; Make sure the value of @f is reloaded prior to the final comparison. define i32 @test(i64 %idx, i32 %val) { ; CHECK-LABEL: define i32 @test( ; CHECK-SAME: i64 [[IDX:%.*]], i32 [[VAL:%.*]]) { ; CHECK-NEXT: entry: ; CHECK-NEXT: [[CMP:%.*]] = icmp slt i64 [[IDX]], 1 ; CHECK-NEXT: br i1 [[CMP]], label [[FOR_BODY:%.*]], label [[RETURN:%.*]] ; CHECK: for.body: ; CHECK-NEXT: [[F:%.*]] = load i32, ptr @f, align 4 ; CHECK-NEXT: [[CMP1:%.*]] = icmp eq i32 [[F]], 0 ; CHECK-NEXT: br i1 [[CMP1]], label [[COND_END_THREAD:%.*]], label [[COND_END:%.*]] ; CHECK: cond.end: ; CHECK-NEXT: [[CMP_I:%.*]] = icmp sgt i32 [[VAL]], 0 ; CHECK-NEXT: [[COND_FR:%.*]] = freeze i1 [[CMP_I]] ; CHECK-NEXT: br i1 [[COND_FR]], label [[COND_END_THREAD]], label [[TMP0:%.*]] ; CHECK: cond.end.thread: ; CHECK-NEXT: br label [[TMP0]] ; CHECK: 0: ; CHECK-NEXT: [[TMP1:%.*]] = phi i32 [ 0, [[COND_END_THREAD]] ], [ [[VAL]], [[COND_END]] ] ; CHECK-NEXT: [[F_IDX:%.*]] = getelementptr inbounds i32, ptr @f, i64 [[IDX]] ; CHECK-NEXT: store i32 [[TMP1]], ptr [[F_IDX]], align 4 ; CHECK-NEXT: [[F_RELOAD:%.*]] = load i32, ptr @f, align 4 ; CHECK-NEXT: [[CMP3:%.*]] = icmp slt i32 [[F_RELOAD]], 1 ; CHECK-NEXT: br i1 [[CMP3]], label [[RETURN2:%.*]], label [[RETURN]] ; CHECK: return: ; CHECK-NEXT: ret i32 0 ; CHECK: return2: ; CHECK-NEXT: ret i32 1 ; entry: %cmp = icmp slt i64 %idx, 1 br i1 %cmp, label %for.body, label %return for.body: %f = load i32, ptr @f, align 4 %cmp1 = icmp eq i32 %f, 0 br i1 %cmp1, label %cond.end, label %cond.false cond.false: br label %cond.end cond.end: %phi = phi i32 [ %val, %cond.false ], [ 1, %for.body ] %cmp.i = icmp sgt i32 %phi, 0 %sel = select i1 %cmp.i, i32 0, i32 %phi %f.idx = getelementptr inbounds i32, ptr @f, i64 %idx store i32 %sel, ptr %f.idx, align 4 %f.reload = load i32, ptr @f, align 4 %cmp3 = icmp slt i32 %f.reload, 1 br i1 %cmp3, label %return2, label %return return: ret i32 0 return2: ret i32 1 }