You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
4.0 KiB
111 lines
4.0 KiB
3 years ago
|
; ModuleID = 'branch2.ll'
|
||
|
source_filename = "branch2.c"
|
||
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
||
|
target triple = "x86_64-unknown-linux-gnu"
|
||
|
|
||
|
; Function Attrs: noinline nounwind optnone uwtable
|
||
|
define dso_local i32 @main() #0 {
|
||
|
entry:
|
||
|
call void @__DSE_Init__()
|
||
|
%retval = alloca i32, align 4
|
||
|
%x = alloca i32, align 4
|
||
|
call void @__DSE_Alloca__(i32 0, i32* %x)
|
||
|
%y = alloca i32, align 4
|
||
|
call void @__DSE_Alloca__(i32 1, i32* %y)
|
||
|
%z = alloca i32, align 4
|
||
|
call void @__DSE_Alloca__(i32 2, i32* %z)
|
||
|
store i32 0, i32* %retval, align 4
|
||
|
call void @__DSE_Const__(i32 0)
|
||
|
call void @__DSE_Store__(i32* %retval)
|
||
|
call void @__DSE_Input__(i32* noundef %x, i32 noundef 0)
|
||
|
call void @__DSE_Input__(i32* noundef %y, i32 noundef 1)
|
||
|
call void @__DSE_Input__(i32* noundef %z, i32 noundef 2)
|
||
|
%0 = load i32, i32* %x, align 4
|
||
|
call void @__DSE_Load__(i32 3, i32* %x)
|
||
|
%1 = load i32, i32* %y, align 4
|
||
|
call void @__DSE_Load__(i32 4, i32* %y)
|
||
|
%cmp = icmp sgt i32 %0, %1
|
||
|
call void @__DSE_Register__(i32 4)
|
||
|
call void @__DSE_Register__(i32 3)
|
||
|
call void @__DSE_ICmp__(i32 5, i32 38)
|
||
|
call void @__DSE_Label__(i32 5, i32 6, i32 1)
|
||
|
call void @__DSE_Label__(i32 5, i32 7, i32 0)
|
||
|
br i1 %cmp, label %land.lhs.true, label %if.end
|
||
|
|
||
|
land.lhs.true: ; preds = %entry
|
||
|
%2 = load i32, i32* %y, align 4
|
||
|
call void @__DSE_Load__(i32 8, i32* %y)
|
||
|
%3 = load i32, i32* %z, align 4
|
||
|
call void @__DSE_Load__(i32 9, i32* %z)
|
||
|
%cmp1 = icmp sgt i32 %2, %3
|
||
|
call void @__DSE_Register__(i32 9)
|
||
|
call void @__DSE_Register__(i32 8)
|
||
|
call void @__DSE_ICmp__(i32 10, i32 38)
|
||
|
call void @__DSE_Label__(i32 10, i32 11, i32 1)
|
||
|
call void @__DSE_Label__(i32 10, i32 7, i32 0)
|
||
|
br i1 %cmp1, label %land.lhs.true2, label %if.end
|
||
|
|
||
|
land.lhs.true2: ; preds = %land.lhs.true
|
||
|
%4 = load i32, i32* %z, align 4
|
||
|
call void @__DSE_Load__(i32 12, i32* %z)
|
||
|
%cmp3 = icmp eq i32 %4, 0
|
||
|
call void @__DSE_Const__(i32 0)
|
||
|
call void @__DSE_Register__(i32 12)
|
||
|
call void @__DSE_ICmp__(i32 13, i32 32)
|
||
|
call void @__DSE_Label__(i32 13, i32 14, i32 1)
|
||
|
call void @__DSE_Label__(i32 13, i32 7, i32 0)
|
||
|
br i1 %cmp3, label %if.then, label %if.end
|
||
|
|
||
|
if.then: ; preds = %land.lhs.true2
|
||
|
call void @__DSE_Branch__(i32 14, i32 1)
|
||
|
%5 = load i32, i32* %x, align 4
|
||
|
call void @__DSE_Load__(i32 15, i32* %x)
|
||
|
%6 = load i32, i32* %z, align 4
|
||
|
call void @__DSE_Load__(i32 16, i32* %z)
|
||
|
%div = sdiv i32 %5, %6
|
||
|
call void @__DSE_Register__(i32 16)
|
||
|
call void @__DSE_Register__(i32 15)
|
||
|
call void @__DSE_BinOp__(i32 17, i32 20)
|
||
|
store i32 %div, i32* %x, align 4
|
||
|
call void @__DSE_Register__(i32 17)
|
||
|
call void @__DSE_Store__(i32* %x)
|
||
|
br label %if.end
|
||
|
|
||
|
if.end: ; preds = %if.then, %land.lhs.true2, %land.lhs.true, %entry
|
||
|
call void @__DSE_Branch__(i32 7, i32 2)
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
declare dso_local void @__DSE_Input__(i32* noundef, i32 noundef) #1
|
||
|
|
||
|
declare void @__DSE_Init__()
|
||
|
|
||
|
declare void @__DSE_Alloca__(i32, i32*)
|
||
|
|
||
|
declare void @__DSE_Store__(i32*)
|
||
|
|
||
|
declare void @__DSE_Load__(i32, i32*)
|
||
|
|
||
|
declare void @__DSE_ICmp__(i32, i32)
|
||
|
|
||
|
declare void @__DSE_Label__(i32, i32, i32)
|
||
|
|
||
|
declare void @__DSE_Branch__(i32, i32)
|
||
|
|
||
|
declare void @__DSE_BinOp__(i32, i32)
|
||
|
|
||
|
declare void @__DSE_Const__(i32)
|
||
|
|
||
|
declare void @__DSE_Register__(i32)
|
||
|
|
||
|
attributes #0 = { noinline nounwind optnone uwtable "frame-pointer"="all" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
|
||
|
attributes #1 = { "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
|
||
|
|
||
|
!llvm.module.flags = !{!0, !1, !2}
|
||
|
!llvm.ident = !{!3}
|
||
|
|
||
|
!0 = !{i32 1, !"wchar_size", i32 4}
|
||
|
!1 = !{i32 7, !"uwtable", i32 1}
|
||
|
!2 = !{i32 7, !"frame-pointer", i32 2}
|
||
|
!3 = !{!"clang version 14.0.0"}
|