; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4 ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=0 < %s | FileCheck %s --check-prefix=CHECK-SD ; RUN: llc -mtriple=aarch64-linux-gnu -global-isel=1 < %s | FileCheck %s --check-prefix=CHECK-GI define i1 @ule_11111111(i32 noundef %in) { ; CHECK-SD-LABEL: ule_11111111: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #4370 // =0x1112 ; CHECK-SD-NEXT: movk w8, #4369, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_11111111: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #286331153 // =0x11111111 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 286331154 ret i1 %out } define i1 @ule_22222222(i32 noundef %in) { ; CHECK-SD-LABEL: ule_22222222: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #8739 // =0x2223 ; CHECK-SD-NEXT: movk w8, #8738, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_22222222: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #572662306 // =0x22222222 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 572662307 ret i1 %out } define i1 @ule_33333333(i32 noundef %in) { ; CHECK-SD-LABEL: ule_33333333: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #13108 // =0x3334 ; CHECK-SD-NEXT: movk w8, #13107, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_33333333: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #858993459 // =0x33333333 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 858993460 ret i1 %out } define i1 @ule_44444444(i32 noundef %in) { ; CHECK-SD-LABEL: ule_44444444: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #17477 // =0x4445 ; CHECK-SD-NEXT: movk w8, #17476, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_44444444: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1145324612 // =0x44444444 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 1145324613 ret i1 %out } define i1 @ule_55555555(i32 noundef %in) { ; CHECK-SD-LABEL: ule_55555555: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #21846 // =0x5556 ; CHECK-SD-NEXT: movk w8, #21845, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_55555555: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1431655765 // =0x55555555 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 1431655766 ret i1 %out } define i1 @ule_66666666(i32 noundef %in) { ; CHECK-SD-LABEL: ule_66666666: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #26215 // =0x6667 ; CHECK-SD-NEXT: movk w8, #26214, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_66666666: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1717986918 // =0x66666666 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 1717986919 ret i1 %out } define i1 @ule_77777777(i32 noundef %in) { ; CHECK-SD-LABEL: ule_77777777: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #30584 // =0x7778 ; CHECK-SD-NEXT: movk w8, #30583, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_77777777: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #2004318071 // =0x77777777 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, 2004318072 ret i1 %out } define i1 @ule_88888888(i32 noundef %in) { ; CHECK-SD-LABEL: ule_88888888: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #34953 // =0x8889 ; CHECK-SD-NEXT: movk w8, #34952, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_88888888: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-2004318072 // =0x88888888 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, -2004318071 ret i1 %out } define i1 @ule_99999999(i32 noundef %in) { ; CHECK-SD-LABEL: ule_99999999: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #39322 // =0x999a ; CHECK-SD-NEXT: movk w8, #39321, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: ule_99999999: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-1717986919 // =0x99999999 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, -1717986918 ret i1 %out } define i1 @uge_11111111(i32 noundef %in) { ; CHECK-SD-LABEL: uge_11111111: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #4368 // =0x1110 ; CHECK-SD-NEXT: movk w8, #4369, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_11111111: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #286331153 // =0x11111111 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 286331152 ret i1 %out } define i1 @uge_22222222(i32 noundef %in) { ; CHECK-SD-LABEL: uge_22222222: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #8737 // =0x2221 ; CHECK-SD-NEXT: movk w8, #8738, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_22222222: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #572662306 // =0x22222222 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 572662305 ret i1 %out } define i1 @uge_33333333(i32 noundef %in) { ; CHECK-SD-LABEL: uge_33333333: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #13106 // =0x3332 ; CHECK-SD-NEXT: movk w8, #13107, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_33333333: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #858993459 // =0x33333333 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 858993458 ret i1 %out } define i1 @uge_44444444(i32 noundef %in) { ; CHECK-SD-LABEL: uge_44444444: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #17475 // =0x4443 ; CHECK-SD-NEXT: movk w8, #17476, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_44444444: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1145324612 // =0x44444444 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 1145324611 ret i1 %out } define i1 @uge_55555555(i32 noundef %in) { ; CHECK-SD-LABEL: uge_55555555: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #21844 // =0x5554 ; CHECK-SD-NEXT: movk w8, #21845, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_55555555: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1431655765 // =0x55555555 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 1431655764 ret i1 %out } define i1 @uge_66666666(i32 noundef %in) { ; CHECK-SD-LABEL: uge_66666666: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #26213 // =0x6665 ; CHECK-SD-NEXT: movk w8, #26214, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_66666666: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1717986918 // =0x66666666 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 1717986917 ret i1 %out } define i1 @uge_77777777(i32 noundef %in) { ; CHECK-SD-LABEL: uge_77777777: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #30582 // =0x7776 ; CHECK-SD-NEXT: movk w8, #30583, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_77777777: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #2004318071 // =0x77777777 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, 2004318070 ret i1 %out } define i1 @uge_88888888(i32 noundef %in) { ; CHECK-SD-LABEL: uge_88888888: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #34951 // =0x8887 ; CHECK-SD-NEXT: movk w8, #34952, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_88888888: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-2004318072 // =0x88888888 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, -2004318073 ret i1 %out } define i1 @uge_99999999(i32 noundef %in) { ; CHECK-SD-LABEL: uge_99999999: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #39320 // =0x9998 ; CHECK-SD-NEXT: movk w8, #39321, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: uge_99999999: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-1717986919 // =0x99999999 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, -1717986920 ret i1 %out } define i1 @sle_11111111(i32 noundef %in) { ; CHECK-SD-LABEL: sle_11111111: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #4370 // =0x1112 ; CHECK-SD-NEXT: movk w8, #4369, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_11111111: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #286331153 // =0x11111111 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 286331154 ret i1 %out } define i1 @sle_22222222(i32 noundef %in) { ; CHECK-SD-LABEL: sle_22222222: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #8739 // =0x2223 ; CHECK-SD-NEXT: movk w8, #8738, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_22222222: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #572662306 // =0x22222222 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 572662307 ret i1 %out } define i1 @sle_33333333(i32 noundef %in) { ; CHECK-SD-LABEL: sle_33333333: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #13108 // =0x3334 ; CHECK-SD-NEXT: movk w8, #13107, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_33333333: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #858993459 // =0x33333333 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 858993460 ret i1 %out } define i1 @sle_44444444(i32 noundef %in) { ; CHECK-SD-LABEL: sle_44444444: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #17477 // =0x4445 ; CHECK-SD-NEXT: movk w8, #17476, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_44444444: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1145324612 // =0x44444444 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 1145324613 ret i1 %out } define i1 @sle_55555555(i32 noundef %in) { ; CHECK-SD-LABEL: sle_55555555: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #21846 // =0x5556 ; CHECK-SD-NEXT: movk w8, #21845, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_55555555: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1431655765 // =0x55555555 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 1431655766 ret i1 %out } define i1 @sle_66666666(i32 noundef %in) { ; CHECK-SD-LABEL: sle_66666666: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #26215 // =0x6667 ; CHECK-SD-NEXT: movk w8, #26214, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_66666666: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1717986918 // =0x66666666 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 1717986919 ret i1 %out } define i1 @sle_77777777(i32 noundef %in) { ; CHECK-SD-LABEL: sle_77777777: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #30584 // =0x7778 ; CHECK-SD-NEXT: movk w8, #30583, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_77777777: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #2004318071 // =0x77777777 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, le ; CHECK-GI-NEXT: ret %out = icmp slt i32 %in, 2004318072 ret i1 %out } define i1 @sle_88888888(i32 noundef %in) { ; CHECK-SD-LABEL: sle_88888888: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #34953 // =0x8889 ; CHECK-SD-NEXT: movk w8, #34952, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_88888888: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-2004318072 // =0x88888888 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, -2004318071 ret i1 %out } define i1 @sle_99999999(i32 noundef %in) { ; CHECK-SD-LABEL: sle_99999999: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #39322 // =0x999a ; CHECK-SD-NEXT: movk w8, #39321, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, lo ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sle_99999999: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-1717986919 // =0x99999999 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ls ; CHECK-GI-NEXT: ret %out = icmp ult i32 %in, -1717986918 ret i1 %out } define i1 @sge_11111111(i32 noundef %in) { ; CHECK-SD-LABEL: sge_11111111: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #4368 // =0x1110 ; CHECK-SD-NEXT: movk w8, #4369, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_11111111: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #286331153 // =0x11111111 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 286331152 ret i1 %out } define i1 @sge_22222222(i32 noundef %in) { ; CHECK-SD-LABEL: sge_22222222: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #8737 // =0x2221 ; CHECK-SD-NEXT: movk w8, #8738, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_22222222: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #572662306 // =0x22222222 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 572662305 ret i1 %out } define i1 @sge_33333333(i32 noundef %in) { ; CHECK-SD-LABEL: sge_33333333: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #13106 // =0x3332 ; CHECK-SD-NEXT: movk w8, #13107, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_33333333: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #858993459 // =0x33333333 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 858993458 ret i1 %out } define i1 @sge_44444444(i32 noundef %in) { ; CHECK-SD-LABEL: sge_44444444: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #17475 // =0x4443 ; CHECK-SD-NEXT: movk w8, #17476, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_44444444: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1145324612 // =0x44444444 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 1145324611 ret i1 %out } define i1 @sge_55555555(i32 noundef %in) { ; CHECK-SD-LABEL: sge_55555555: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #21844 // =0x5554 ; CHECK-SD-NEXT: movk w8, #21845, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_55555555: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1431655765 // =0x55555555 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 1431655764 ret i1 %out } define i1 @sge_66666666(i32 noundef %in) { ; CHECK-SD-LABEL: sge_66666666: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #26213 // =0x6665 ; CHECK-SD-NEXT: movk w8, #26214, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_66666666: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #1717986918 // =0x66666666 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 1717986917 ret i1 %out } define i1 @sge_77777777(i32 noundef %in) { ; CHECK-SD-LABEL: sge_77777777: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #30582 // =0x7776 ; CHECK-SD-NEXT: movk w8, #30583, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, gt ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_77777777: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #2004318071 // =0x77777777 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, ge ; CHECK-GI-NEXT: ret %out = icmp sgt i32 %in, 2004318070 ret i1 %out } define i1 @sge_88888888(i32 noundef %in) { ; CHECK-SD-LABEL: sge_88888888: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #34951 // =0x8887 ; CHECK-SD-NEXT: movk w8, #34952, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_88888888: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-2004318072 // =0x88888888 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, -2004318073 ret i1 %out } define i1 @sge_99999999(i32 noundef %in) { ; CHECK-SD-LABEL: sge_99999999: ; CHECK-SD: // %bb.0: ; CHECK-SD-NEXT: mov w8, #39320 // =0x9998 ; CHECK-SD-NEXT: movk w8, #39321, lsl #16 ; CHECK-SD-NEXT: cmp w0, w8 ; CHECK-SD-NEXT: cset w0, hi ; CHECK-SD-NEXT: ret ; ; CHECK-GI-LABEL: sge_99999999: ; CHECK-GI: // %bb.0: ; CHECK-GI-NEXT: mov w8, #-1717986919 // =0x99999999 ; CHECK-GI-NEXT: cmp w0, w8 ; CHECK-GI-NEXT: cset w0, hs ; CHECK-GI-NEXT: ret %out = icmp ugt i32 %in, -1717986920 ret i1 %out }