; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd -verify-machineinstrs --show-mc-encoding | FileCheck %s ; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,nf -verify-machineinstrs --show-mc-encoding | FileCheck --check-prefix=NF %s ; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,nf -x86-enable-apx-for-relocation=true -verify-machineinstrs --show-mc-encoding | FileCheck --check-prefix=NF %s define i8 @sub8rr(i8 noundef %a, i8 noundef %b) { ; CHECK-LABEL: sub8rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subb %sil, %dil, %al # encoding: [0x62,0xf4,0x7c,0x18,0x28,0xf7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8rr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subb %sil, %dil, %al # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x28,0xf7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i8 %a, %b ret i8 %sub } define i16 @sub16rr(i16 noundef %a, i16 noundef %b) { ; CHECK-LABEL: sub16rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw %si, %di, %ax # encoding: [0x62,0xf4,0x7d,0x18,0x29,0xf7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16rr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subw %si, %di, %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x29,0xf7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i16 %a, %b ret i16 %sub } define i32 @sub32rr(i32 noundef %a, i32 noundef %b) { ; CHECK-LABEL: sub32rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl %esi, %edi, %eax # encoding: [0x62,0xf4,0x7c,0x18,0x29,0xf7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32rr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subl %esi, %edi, %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x29,0xf7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i32 %a, %b ret i32 %sub } define i64 @sub64rr(i64 noundef %a, i64 noundef %b) { ; CHECK-LABEL: sub64rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq %rsi, %rdi, %rax # encoding: [0x62,0xf4,0xfc,0x18,0x29,0xf7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64rr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq %rsi, %rdi, %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x29,0xf7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i64 %a, %b ret i64 %sub } define i8 @sub8rm(i8 noundef %a, ptr %ptr) { ; CHECK-LABEL: sub8rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subb (%rsi), %dil, %al # encoding: [0x62,0xf4,0x7c,0x18,0x2a,0x3e] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8rm: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subb (%rsi), %dil, %al # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x2a,0x3e] ; NF-NEXT: retq # encoding: [0xc3] entry: %b = load i8, ptr %ptr %sub = sub i8 %a, %b ret i8 %sub } define i16 @sub16rm(i16 noundef %a, ptr %ptr) { ; CHECK-LABEL: sub16rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw (%rsi), %di, %ax # encoding: [0x62,0xf4,0x7d,0x18,0x2b,0x3e] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16rm: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subw (%rsi), %di, %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x2b,0x3e] ; NF-NEXT: retq # encoding: [0xc3] entry: %b = load i16, ptr %ptr %sub = sub i16 %a, %b ret i16 %sub } define i32 @sub32rm(i32 noundef %a, ptr %ptr) { ; CHECK-LABEL: sub32rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl (%rsi), %edi, %eax # encoding: [0x62,0xf4,0x7c,0x18,0x2b,0x3e] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32rm: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subl (%rsi), %edi, %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x2b,0x3e] ; NF-NEXT: retq # encoding: [0xc3] entry: %b = load i32, ptr %ptr %sub = sub i32 %a, %b ret i32 %sub } define i64 @sub64rm(i64 noundef %a, ptr %ptr) { ; CHECK-LABEL: sub64rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq (%rsi), %rdi, %rax # encoding: [0x62,0xf4,0xfc,0x18,0x2b,0x3e] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64rm: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq (%rsi), %rdi, %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x2b,0x3e] ; NF-NEXT: retq # encoding: [0xc3] entry: %b = load i64, ptr %ptr %sub = sub i64 %a, %b ret i64 %sub } define i16 @sub16ri8(i16 noundef %a) { ; CHECK-LABEL: sub16ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw $-128, %di, %ax # encoding: [0x62,0xf4,0x7d,0x18,0x83,0xef,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subw $-128, %di, %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x83,0xef,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i16 %a, -128 ret i16 %sub } define i32 @sub32ri8(i32 noundef %a) { ; CHECK-LABEL: sub32ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl $-128, %edi, %eax # encoding: [0x62,0xf4,0x7c,0x18,0x83,0xef,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subl $-128, %edi, %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x83,0xef,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i32 %a, -128 ret i32 %sub } define i64 @sub64ri8(i64 noundef %a) { ; CHECK-LABEL: sub64ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq $-128, %rdi, %rax # encoding: [0x62,0xf4,0xfc,0x18,0x83,0xef,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq $-128, %rdi, %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x83,0xef,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i64 %a, -128 ret i64 %sub } define i8 @sub8ri(i8 noundef %a) { ; CHECK-LABEL: sub8ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addb $-123, %dil, %al # encoding: [0x62,0xf4,0x7c,0x18,0x80,0xc7,0x85] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8ri: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} addb $-123, %dil, %al # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x80,0xc7,0x85] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i8 %a, 123 ret i8 %sub } define i16 @sub16ri(i16 noundef %a) { ; CHECK-LABEL: sub16ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addw $-1234, %di, %ax # encoding: [0x62,0xf4,0x7d,0x18,0x81,0xc7,0x2e,0xfb] ; CHECK-NEXT: # imm = 0xFB2E ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16ri: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} addw $-1234, %di, %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x81,0xc7,0x2e,0xfb] ; NF-NEXT: # imm = 0xFB2E ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i16 %a, 1234 ret i16 %sub } define i32 @sub32ri(i32 noundef %a) { ; CHECK-LABEL: sub32ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: leal -123456(%rdi), %eax # encoding: [0x8d,0x87,0xc0,0x1d,0xfe,0xff] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32ri: ; NF: # %bb.0: # %entry ; NF-NEXT: leal -123456(%rdi), %eax # encoding: [0x8d,0x87,0xc0,0x1d,0xfe,0xff] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i32 %a, 123456 ret i32 %sub } define i64 @sub64ri(i64 noundef %a) { ; CHECK-LABEL: sub64ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq $-2147483648, %rdi, %rax # encoding: [0x62,0xf4,0xfc,0x18,0x81,0xef,0x00,0x00,0x00,0x80] ; CHECK-NEXT: # imm = 0x80000000 ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64ri: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq $-2147483648, %rdi, %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x81,0xef,0x00,0x00,0x00,0x80] ; NF-NEXT: # imm = 0x80000000 ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = sub i64 %a, -2147483648 ret i64 %sub } define i8 @sub8mr(ptr %a, i8 noundef %b) { ; CHECK-LABEL: sub8mr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subb %sil, (%rdi), %al # encoding: [0x62,0xf4,0x7c,0x18,0x28,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8mr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subb %sil, (%rdi), %al # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x28,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i8, ptr %a %sub = sub nsw i8 %t, %b ret i8 %sub } define i16 @sub16mr(ptr %a, i16 noundef %b) { ; CHECK-LABEL: sub16mr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw %si, (%rdi), %ax # encoding: [0x62,0xf4,0x7d,0x18,0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16mr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subw %si, (%rdi), %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i16, ptr %a %sub = sub nsw i16 %t, %b ret i16 %sub } define i32 @sub32mr(ptr %a, i32 noundef %b) { ; CHECK-LABEL: sub32mr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl %esi, (%rdi), %eax # encoding: [0x62,0xf4,0x7c,0x18,0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32mr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subl %esi, (%rdi), %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i32, ptr %a %sub = sub nsw i32 %t, %b ret i32 %sub } define i64 @sub64mr(ptr %a, i64 noundef %b) { ; CHECK-LABEL: sub64mr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq %rsi, (%rdi), %rax # encoding: [0x62,0xf4,0xfc,0x18,0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64mr: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq %rsi, (%rdi), %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i64, ptr %a %sub = sub nsw i64 %t, %b ret i64 %sub } define i16 @sub16mi8(ptr %a) { ; CHECK-LABEL: sub16mi8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw $-128, (%rdi), %ax # encoding: [0x62,0xf4,0x7d,0x18,0x83,0x2f,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16mi8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subw $-128, (%rdi), %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x83,0x2f,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i16, ptr %a %sub = sub nsw i16 %t, -128 ret i16 %sub } define i32 @sub32mi8(ptr %a) { ; CHECK-LABEL: sub32mi8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl $-128, (%rdi), %eax # encoding: [0x62,0xf4,0x7c,0x18,0x83,0x2f,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32mi8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subl $-128, (%rdi), %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x83,0x2f,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i32, ptr %a %sub = sub nsw i32 %t, -128 ret i32 %sub } define i64 @sub64mi8(ptr %a) { ; CHECK-LABEL: sub64mi8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq $-128, (%rdi), %rax # encoding: [0x62,0xf4,0xfc,0x18,0x83,0x2f,0x80] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64mi8: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq $-128, (%rdi), %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x83,0x2f,0x80] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i64, ptr %a %sub = sub nsw i64 %t, -128 ret i64 %sub } define i8 @sub8mi(ptr %a) { ; CHECK-LABEL: sub8mi: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addb $-123, (%rdi), %al # encoding: [0x62,0xf4,0x7c,0x18,0x80,0x07,0x85] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8mi: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} addb $-123, (%rdi), %al # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x80,0x07,0x85] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i8, ptr %a %sub = sub nsw i8 %t, 123 ret i8 %sub } define i16 @sub16mi(ptr %a) { ; CHECK-LABEL: sub16mi: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addw $-1234, (%rdi), %ax # encoding: [0x62,0xf4,0x7d,0x18,0x81,0x07,0x2e,0xfb] ; CHECK-NEXT: # imm = 0xFB2E ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16mi: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} addw $-1234, (%rdi), %ax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7d,0x1c,0x81,0x07,0x2e,0xfb] ; NF-NEXT: # imm = 0xFB2E ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i16, ptr %a %sub = sub nsw i16 %t, 1234 ret i16 %sub } define i32 @sub32mi(ptr %a) { ; CHECK-LABEL: sub32mi: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addl $-123456, (%rdi), %eax # encoding: [0x62,0xf4,0x7c,0x18,0x81,0x07,0xc0,0x1d,0xfe,0xff] ; CHECK-NEXT: # imm = 0xFFFE1DC0 ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32mi: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} addl $-123456, (%rdi), %eax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0x7c,0x1c,0x81,0x07,0xc0,0x1d,0xfe,0xff] ; NF-NEXT: # imm = 0xFFFE1DC0 ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i32, ptr %a %sub = sub nsw i32 %t, 123456 ret i32 %sub } define i64 @sub64mi(ptr %a) { ; CHECK-LABEL: sub64mi: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq $-2147483648, (%rdi), %rax # encoding: [0x62,0xf4,0xfc,0x18,0x81,0x2f,0x00,0x00,0x00,0x80] ; CHECK-NEXT: # imm = 0x80000000 ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64mi: ; NF: # %bb.0: # %entry ; NF-NEXT: {nf} subq $-2147483648, (%rdi), %rax # EVEX TO EVEX Compression encoding: [0x62,0xf4,0xfc,0x1c,0x81,0x2f,0x00,0x00,0x00,0x80] ; NF-NEXT: # imm = 0x80000000 ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i64, ptr %a %sub = sub nsw i64 %t, -2147483648 ret i64 %sub } declare i8 @llvm.usub.sat.i8(i8, i8) declare i16 @llvm.usub.sat.i16(i16, i16) declare i32 @llvm.usub.sat.i32(i32, i32) declare i64 @llvm.usub.sat.i64(i64, i64) define i8 @subflag8rr(i8 noundef %a, i8 noundef %b) { ; CHECK-LABEL: subflag8rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subb %sil, %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x28,0xf7] ; CHECK-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; CHECK-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; CHECK-NEXT: # kill: def $al killed $al killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag8rr: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subb %sil, %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x28,0xf7] ; NF-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; NF-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; NF-NEXT: # kill: def $al killed $al killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i8 @llvm.usub.sat.i8(i8 %a, i8 %b) ret i8 %sub } define i16 @subflag16rr(i16 noundef %a, i16 noundef %b) { ; CHECK-LABEL: subflag16rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subw %si, %di # EVEX TO LEGACY Compression encoding: [0x66,0x29,0xf7] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: # kill: def $ax killed $ax killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag16rr: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subw %si, %di # EVEX TO LEGACY Compression encoding: [0x66,0x29,0xf7] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: # kill: def $ax killed $ax killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i16 @llvm.usub.sat.i16(i16 %a, i16 %b) ret i16 %sub } define i32 @subflag32rr(i32 noundef %a, i32 noundef %b) { ; CHECK-LABEL: subflag32rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subl %esi, %edi # EVEX TO LEGACY Compression encoding: [0x29,0xf7] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag32rr: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subl %esi, %edi # EVEX TO LEGACY Compression encoding: [0x29,0xf7] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i32 @llvm.usub.sat.i32(i32 %a, i32 %b) ret i32 %sub } define i64 @subflag64rr(i64 noundef %a, i64 noundef %b) { ; CHECK-LABEL: subflag64rr: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subq %rsi, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x29,0xf7] ; CHECK-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag64rr: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subq %rsi, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x29,0xf7] ; NF-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i64 @llvm.usub.sat.i64(i64 %a, i64 %b) ret i64 %sub } define i8 @subflag8rm(i8 noundef %a, ptr %b) { ; CHECK-LABEL: subflag8rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subb (%rsi), %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x2a,0x3e] ; CHECK-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; CHECK-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; CHECK-NEXT: # kill: def $al killed $al killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag8rm: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subb (%rsi), %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x2a,0x3e] ; NF-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; NF-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; NF-NEXT: # kill: def $al killed $al killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %t = load i8, ptr %b %sub = call i8 @llvm.usub.sat.i8(i8 %a, i8 %t) ret i8 %sub } define i16 @subflag16rm(i16 noundef %a, ptr %b) { ; CHECK-LABEL: subflag16rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subw (%rsi), %di # EVEX TO LEGACY Compression encoding: [0x66,0x2b,0x3e] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: # kill: def $ax killed $ax killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag16rm: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subw (%rsi), %di # EVEX TO LEGACY Compression encoding: [0x66,0x2b,0x3e] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: # kill: def $ax killed $ax killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %t = load i16, ptr %b %sub = call i16 @llvm.usub.sat.i16(i16 %a, i16 %t) ret i16 %sub } define i32 @subflag32rm(i32 noundef %a, ptr %b) { ; CHECK-LABEL: subflag32rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subl (%rsi), %edi # EVEX TO LEGACY Compression encoding: [0x2b,0x3e] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag32rm: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subl (%rsi), %edi # EVEX TO LEGACY Compression encoding: [0x2b,0x3e] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %t = load i32, ptr %b %sub = call i32 @llvm.usub.sat.i32(i32 %a, i32 %t) ret i32 %sub } define i64 @subflag64rm(i64 noundef %a, ptr %b) { ; CHECK-LABEL: subflag64rm: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subq (%rsi), %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x2b,0x3e] ; CHECK-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag64rm: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subq (%rsi), %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x2b,0x3e] ; NF-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %t = load i64, ptr %b %sub = call i64 @llvm.usub.sat.i64(i64 %a, i64 %t) ret i64 %sub } define i16 @subflag16ri8(i16 noundef %a) { ; CHECK-LABEL: subflag16ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subw $123, %di # EVEX TO LEGACY Compression encoding: [0x66,0x83,0xef,0x7b] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: # kill: def $ax killed $ax killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag16ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subw $123, %di # EVEX TO LEGACY Compression encoding: [0x66,0x83,0xef,0x7b] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: # kill: def $ax killed $ax killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i16 @llvm.usub.sat.i16(i16 %a, i16 123) ret i16 %sub } define i32 @subflag32ri8(i32 noundef %a) { ; CHECK-LABEL: subflag32ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subl $123, %edi # EVEX TO LEGACY Compression encoding: [0x83,0xef,0x7b] ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag32ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subl $123, %edi # EVEX TO LEGACY Compression encoding: [0x83,0xef,0x7b] ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i32 @llvm.usub.sat.i32(i32 %a, i32 123) ret i32 %sub } define i64 @subflag64ri8(i64 noundef %a) { ; CHECK-LABEL: subflag64ri8: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subq $123, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x83,0xef,0x7b] ; CHECK-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag64ri8: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subq $123, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x83,0xef,0x7b] ; NF-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i64 @llvm.usub.sat.i64(i64 %a, i64 123) ret i64 %sub } define i8 @subflag8ri(i8 noundef %a) { ; CHECK-LABEL: subflag8ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subb $123, %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x80,0xef,0x7b] ; CHECK-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; CHECK-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; CHECK-NEXT: # kill: def $al killed $al killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag8ri: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subb $123, %dil, %cl # encoding: [0x62,0xf4,0x74,0x18,0x80,0xef,0x7b] ; NF-NEXT: movzbl %cl, %ecx # encoding: [0x0f,0xb6,0xc9] ; NF-NEXT: cmovael %ecx, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc1] ; NF-NEXT: # kill: def $al killed $al killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i8 @llvm.usub.sat.i8(i8 %a, i8 123) ret i8 %sub } define i16 @subflag16ri(i16 noundef %a) { ; CHECK-LABEL: subflag16ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subw $1234, %di # EVEX TO LEGACY Compression encoding: [0x66,0x81,0xef,0xd2,0x04] ; CHECK-NEXT: # imm = 0x4D2 ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: # kill: def $ax killed $ax killed $eax ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag16ri: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subw $1234, %di # EVEX TO LEGACY Compression encoding: [0x66,0x81,0xef,0xd2,0x04] ; NF-NEXT: # imm = 0x4D2 ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: # kill: def $ax killed $ax killed $eax ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i16 @llvm.usub.sat.i16(i16 %a, i16 1234) ret i16 %sub } define i32 @subflag32ri(i32 noundef %a) { ; CHECK-LABEL: subflag32ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subl $123456, %edi # EVEX TO LEGACY Compression encoding: [0x81,0xef,0x40,0xe2,0x01,0x00] ; CHECK-NEXT: # imm = 0x1E240 ; CHECK-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag32ri: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subl $123456, %edi # EVEX TO LEGACY Compression encoding: [0x81,0xef,0x40,0xe2,0x01,0x00] ; NF-NEXT: # imm = 0x1E240 ; NF-NEXT: cmovael %edi, %eax # EVEX TO LEGACY Compression encoding: [0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i32 @llvm.usub.sat.i32(i32 %a, i32 123456) ret i32 %sub } define i64 @subflag64ri(i64 noundef %a) { ; CHECK-LABEL: subflag64ri: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; CHECK-NEXT: subq $123456, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x81,0xef,0x40,0xe2,0x01,0x00] ; CHECK-NEXT: # imm = 0x1E240 ; CHECK-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: subflag64ri: ; NF: # %bb.0: # %entry ; NF-NEXT: xorl %eax, %eax # encoding: [0x31,0xc0] ; NF-NEXT: subq $123456, %rdi # EVEX TO LEGACY Compression encoding: [0x48,0x81,0xef,0x40,0xe2,0x01,0x00] ; NF-NEXT: # imm = 0x1E240 ; NF-NEXT: cmovaeq %rdi, %rax # EVEX TO LEGACY Compression encoding: [0x48,0x0f,0x43,0xc7] ; NF-NEXT: retq # encoding: [0xc3] entry: %sub = call i64 @llvm.usub.sat.i64(i64 %a, i64 123456) ret i64 %sub } @val = external hidden global i8 declare void @f() define void @sub64ri_reloc(i64 %val) { ; CHECK-LABEL: sub64ri_reloc: ; CHECK: # %bb.0: ; CHECK-NEXT: cmpq $val, %rdi # encoding: [0x48,0x81,0xff,A,A,A,A] ; CHECK-NEXT: # fixup A - offset: 3, value: val, kind: reloc_signed_4byte ; CHECK-NEXT: jbe .LBB41_2 # encoding: [0x76,A] ; CHECK-NEXT: # fixup A - offset: 1, value: .LBB41_2, kind: FK_PCRel_1 ; CHECK-NEXT: # %bb.1: # %t ; CHECK-NEXT: pushq %rax # encoding: [0x50] ; CHECK-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: callq f@PLT # encoding: [0xe8,A,A,A,A] ; CHECK-NEXT: # fixup A - offset: 1, value: f@PLT, kind: FK_PCRel_4 ; CHECK-NEXT: popq %rax # encoding: [0x58] ; CHECK-NEXT: .cfi_def_cfa_offset 8 ; CHECK-NEXT: .LBB41_2: # %f ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64ri_reloc: ; NF: # %bb.0: ; NF-NEXT: cmpq $val, %rdi # encoding: [0x48,0x81,0xff,A,A,A,A] ; NF-NEXT: # fixup A - offset: 3, value: val, kind: reloc_signed_4byte ; NF-NEXT: jbe .LBB41_2 # encoding: [0x76,A] ; NF-NEXT: # fixup A - offset: 1, value: .LBB41_2, kind: FK_PCRel_1 ; NF-NEXT: # %bb.1: # %t ; NF-NEXT: pushq %rax # encoding: [0x50] ; NF-NEXT: .cfi_def_cfa_offset 16 ; NF-NEXT: callq f@PLT # encoding: [0xe8,A,A,A,A] ; NF-NEXT: # fixup A - offset: 1, value: f@PLT, kind: FK_PCRel_4 ; NF-NEXT: popq %rax # encoding: [0x58] ; NF-NEXT: .cfi_def_cfa_offset 8 ; NF-NEXT: .LBB41_2: # %f ; NF-NEXT: retq # encoding: [0xc3] %cmp = icmp ugt i64 %val, ptrtoint (ptr @val to i64) br i1 %cmp, label %t, label %f t: call void @f() ret void f: ret void } define void @sub8mr_legacy(ptr %a, i8 noundef %b) { ; CHECK-LABEL: sub8mr_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subb %sil, (%rdi) # encoding: [0x40,0x28,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8mr_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: subb %sil, (%rdi) # encoding: [0x40,0x28,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i8, ptr %a %sub = sub i8 %t, %b store i8 %sub, ptr %a ret void } define void @sub16mr_legacy(ptr %a, i16 noundef %b) { ; CHECK-LABEL: sub16mr_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subw %si, (%rdi) # encoding: [0x66,0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16mr_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: subw %si, (%rdi) # encoding: [0x66,0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i16, ptr %a %sub = sub i16 %t, %b store i16 %sub, ptr %a ret void } define void @sub32mr_legacy(ptr %a, i32 noundef %b) { ; CHECK-LABEL: sub32mr_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subl %esi, (%rdi) # encoding: [0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32mr_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: subl %esi, (%rdi) # encoding: [0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i32, ptr %a %sub = sub i32 %t, %b store i32 %sub, ptr %a ret void } define void @sub64mr_legacy(ptr %a, i64 noundef %b) { ; CHECK-LABEL: sub64mr_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: subq %rsi, (%rdi) # encoding: [0x48,0x29,0x37] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64mr_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: subq %rsi, (%rdi) # encoding: [0x48,0x29,0x37] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i64, ptr %a %sub = sub i64 %t, %b store i64 %sub, ptr %a ret void } define void @sub8mi_legacy(ptr %a) { ; CHECK-LABEL: sub8mi_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addb $-123, (%rdi) # encoding: [0x80,0x07,0x85] ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub8mi_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: addb $-123, (%rdi) # encoding: [0x80,0x07,0x85] ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i8, ptr %a %sub = sub nsw i8 %t, 123 store i8 %sub, ptr %a ret void } define void @sub16mi_legacy(ptr %a) { ; CHECK-LABEL: sub16mi_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addw $-1234, (%rdi) # encoding: [0x66,0x81,0x07,0x2e,0xfb] ; CHECK-NEXT: # imm = 0xFB2E ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub16mi_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: addw $-1234, (%rdi) # encoding: [0x66,0x81,0x07,0x2e,0xfb] ; NF-NEXT: # imm = 0xFB2E ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i16, ptr %a %sub = sub nsw i16 %t, 1234 store i16 %sub, ptr %a ret void } define void @sub32mi_legacy(ptr %a) { ; CHECK-LABEL: sub32mi_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addl $-123456, (%rdi) # encoding: [0x81,0x07,0xc0,0x1d,0xfe,0xff] ; CHECK-NEXT: # imm = 0xFFFE1DC0 ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub32mi_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: addl $-123456, (%rdi) # encoding: [0x81,0x07,0xc0,0x1d,0xfe,0xff] ; NF-NEXT: # imm = 0xFFFE1DC0 ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i32, ptr %a %sub = sub nsw i32 %t, 123456 store i32 %sub, ptr %a ret void } define void @sub64mi_legacy(ptr %a) { ; CHECK-LABEL: sub64mi_legacy: ; CHECK: # %bb.0: # %entry ; CHECK-NEXT: addq $-123456, (%rdi) # encoding: [0x48,0x81,0x07,0xc0,0x1d,0xfe,0xff] ; CHECK-NEXT: # imm = 0xFFFE1DC0 ; CHECK-NEXT: retq # encoding: [0xc3] ; ; NF-LABEL: sub64mi_legacy: ; NF: # %bb.0: # %entry ; NF-NEXT: addq $-123456, (%rdi) # encoding: [0x48,0x81,0x07,0xc0,0x1d,0xfe,0xff] ; NF-NEXT: # imm = 0xFFFE1DC0 ; NF-NEXT: retq # encoding: [0xc3] entry: %t= load i64, ptr %a %sub = sub nsw i64 %t, 123456 store i64 %sub, ptr %a ret void }