1 ; RUN: llc -mtriple thumbv7-windows-gnu -filetype asm -o - %s
3 define i32 @divsoverflow32(i32 %a, i32 %b) {
4 %1 = alloca i32, align 4
5 %2 = alloca i32, align 4
6 %3 = load i32, i32* %1, align 4
7 %4 = load i32, i32* %2, align 4
9 %6 = sdiv i32 -2147483647, %3
10 %7 = icmp sgt i32 %5, %6
11 br i1 %7, label %8, label %9
12 call void (...) @abort_simpl32()
14 %10 = load i32, i32* %1, align 4
15 %11 = load i32, i32* %2, align 4
16 %12 = mul nsw i32 %10, %11
20 declare void @abort_simpl32(...)
22 define i64 @divsoverflow64(i64 %a, i64 %b) {
23 %1 = alloca i64, align 8
24 %2 = alloca i64, align 8
25 %3 = load i64, i64* %1, align 8
26 %4 = load i64, i64* %2, align 8
27 %5 = sub nsw i64 0, %4
28 %6 = sdiv i64 -9223372036854775808, %3
29 %7 = icmp sgt i64 %5, %6
30 br i1 %7, label %8, label %9
31 call void (...) @abort_simpl64()
33 %10 = load i64, i64* %1, align 8
34 %11 = load i64, i64* %2, align 8
35 %12 = mul nsw i64 %10, %11
39 declare void @abort_simpl64(...)
41 define i32 @divuoverflow32(i32 %a, i32 %b) {
42 %1 = alloca i32, align 4
43 %2 = alloca i32, align 4
44 %3 = load i32, i32* %1, align 4
45 %4 = load i32, i32* %2, align 4
46 %5 = sub nsw i32 0, %4
47 %6 = udiv i32 4294967296, %3
48 %7 = icmp sgt i32 %5, %6
49 br i1 %7, label %8, label %9
50 call void (...) @abort_uimpl32()
52 %10 = load i32, i32* %1, align 4
53 %11 = load i32, i32* %2, align 4
54 %12 = mul nsw i32 %10, %11
58 declare void @abort_uimpl32(...)
60 define i64 @divuoverflow64(i64 %a, i64 %b) {
61 %1 = alloca i64, align 8
62 %2 = alloca i64, align 8
63 %3 = load i64, i64* %1, align 8
64 %4 = load i64, i64* %2, align 8
65 %5 = sub nsw i64 0, %4
66 %6 = udiv i64 18446744073709551616, %3
67 %7 = icmp sgt i64 %5, %6
68 br i1 %7, label %8, label %9
69 call void (...) @abort_uimpl64()
71 %10 = load i64, i64* %1, align 8
72 %11 = load i64, i64* %2, align 8
73 %12 = mul nsw i64 %10, %11
77 declare void @abort_uimpl64(...)