; ModuleID = 'probe5.9656865b-cgu.0' source_filename = "probe5.9656865b-cgu.0" target datalayout = "e-m:w-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-pc-windows-msvc" @alloc5 = private unnamed_addr constant <{ [77 x i8] }> <{ [77 x i8] c"/rustc/dfe3fe710181738a2cb3060c23ec5efb3c68ca09\\library\\core\\src\\ops\\arith.rs" }>, align 1 @alloc6 = private unnamed_addr constant <{ ptr, [16 x i8] }> <{ ptr @alloc5, [16 x i8] c"M\00\00\00\00\00\00\00\02\03\00\00\01\00\00\00" }>, align 8 @str.0 = internal constant [28 x i8] c"attempt to add with overflow" @alloc3 = private unnamed_addr constant <{ [4 x i8] }> <{ [4 x i8] c"\02\00\00\00" }>, align 4 ; >::add_assign ; Function Attrs: inlinehint uwtable define internal void @"_ZN66_$LT$i32$u20$as$u20$core..ops..arith..AddAssign$LT$$RF$i32$GT$$GT$10add_assign17hebd2f28ec6024604E"(ptr align 4 %self, ptr align 4 %other) unnamed_addr #0 { start: %other1 = load i32, ptr %other, align 4 %0 = load i32, ptr %self, align 4 %1 = call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %0, i32 %other1) %_6.0 = extractvalue { i32, i1 } %1, 0 %_6.1 = extractvalue { i32, i1 } %1, 1 %2 = call i1 @llvm.expect.i1(i1 %_6.1, i1 false) br i1 %2, label %panic, label %bb1 bb1: ; preds = %start store i32 %_6.0, ptr %self, align 4 ret void panic: ; preds = %start ; call core::panicking::panic call void @_ZN4core9panicking5panic17h894df6c92e0d69a9E(ptr align 1 @str.0, i64 28, ptr align 8 @alloc6) #5 unreachable } ; probe5::probe ; Function Attrs: uwtable define void @_ZN6probe55probe17h4d9804eabe818074E() unnamed_addr #1 { start: %x = alloca i32, align 4 store i32 1, ptr %x, align 4 ; call >::add_assign call void @"_ZN66_$LT$i32$u20$as$u20$core..ops..arith..AddAssign$LT$$RF$i32$GT$$GT$10add_assign17hebd2f28ec6024604E"(ptr align 4 %x, ptr align 4 @alloc3) ret void } ; Function Attrs: nocallback nofree nosync nounwind readnone speculatable willreturn declare { i32, i1 } @llvm.sadd.with.overflow.i32(i32, i32) #2 ; Function Attrs: nocallback nofree nosync nounwind readnone willreturn declare i1 @llvm.expect.i1(i1, i1) #3 ; core::panicking::panic ; Function Attrs: cold noinline noreturn uwtable declare void @_ZN4core9panicking5panic17h894df6c92e0d69a9E(ptr align 1, i64, ptr align 8) unnamed_addr #4 attributes #0 = { inlinehint uwtable "target-cpu"="x86-64" } attributes #1 = { uwtable "target-cpu"="x86-64" } attributes #2 = { nocallback nofree nosync nounwind readnone speculatable willreturn } attributes #3 = { nocallback nofree nosync nounwind readnone willreturn } attributes #4 = { cold noinline noreturn uwtable "target-cpu"="x86-64" } attributes #5 = { noreturn } !llvm.module.flags = !{!0} !0 = !{i32 7, !"PIC Level", i32 2}