blob: aaff438e95ac24ed1e14cc74c3e41e04ecc9e7a5 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,NDD
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,+prefer-ndd-imm -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,IMM,IMMONLY
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,+prefer-ndd-mem -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,MEM,MEMONLY
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,+prefer-ndd-imm,+prefer-ndd-mem -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,IMM,MEM,BOTH
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,nf -verify-machineinstrs | FileCheck --check-prefix=NF %s
; RUN: llc < %s -mtriple=x86_64-unknown -mattr=+ndd,nf -x86-enable-apx-for-relocation=true -verify-machineinstrs | FileCheck --check-prefix=NF %s
define i8 @inc8r(i8 noundef %a) {
; CHECK-LABEL: inc8r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incb %dil, %al
; CHECK-NEXT: retq
;
; NF-LABEL: inc8r:
; NF: # %bb.0: # %entry
; NF-NEXT: {nf} incb %dil, %al
; NF-NEXT: retq
entry:
%inc = add i8 %a, 1
ret i8 %inc
}
define i16 @inc16r(i16 noundef %a) {
; CHECK-LABEL: inc16r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incw %di, %ax
; CHECK-NEXT: retq
;
; NF-LABEL: inc16r:
; NF: # %bb.0: # %entry
; NF-NEXT: {nf} incw %di, %ax
; NF-NEXT: retq
entry:
%inc = add i16 %a, 1
ret i16 %inc
}
define i32 @inc32r(i32 noundef %a) {
; CHECK-LABEL: inc32r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incl %edi, %eax
; CHECK-NEXT: retq
;
; NF-LABEL: inc32r:
; NF: # %bb.0: # %entry
; NF-NEXT: {nf} incl %edi, %eax
; NF-NEXT: retq
entry:
%inc = add i32 %a, 1
ret i32 %inc
}
define i64 @inc64r(i64 noundef %a) {
; NDD-LABEL: inc64r:
; NDD: # %bb.0: # %entry
; NDD-NEXT: leaq 1(%rdi), %rax
; NDD-NEXT: retq
;
; IMM-LABEL: inc64r:
; IMM: # %bb.0: # %entry
; IMM-NEXT: incq %rdi, %rax
; IMM-NEXT: retq
;
; MEMONLY-LABEL: inc64r:
; MEMONLY: # %bb.0: # %entry
; MEMONLY-NEXT: leaq 1(%rdi), %rax
; MEMONLY-NEXT: retq
;
; NF-LABEL: inc64r:
; NF: # %bb.0: # %entry
; NF-NEXT: leaq 1(%rdi), %rax
; NF-NEXT: retq
entry:
%inc = add i64 %a, 1
ret i64 %inc
}
define i8 @inc8m(ptr %ptr) {
; NDD-LABEL: inc8m:
; NDD: # %bb.0: # %entry
; NDD-NEXT: movzbl (%rdi), %eax
; NDD-NEXT: incb %al
; NDD-NEXT: retq
;
; IMMONLY-LABEL: inc8m:
; IMMONLY: # %bb.0: # %entry
; IMMONLY-NEXT: movzbl (%rdi), %eax
; IMMONLY-NEXT: incb %al
; IMMONLY-NEXT: retq
;
; MEM-LABEL: inc8m:
; MEM: # %bb.0: # %entry
; MEM-NEXT: incb (%rdi), %al
; MEM-NEXT: retq
;
; NF-LABEL: inc8m:
; NF: # %bb.0: # %entry
; NF-NEXT: movzbl (%rdi), %eax
; NF-NEXT: incb %al
; NF-NEXT: retq
entry:
%a = load i8, ptr %ptr
%inc = add i8 %a, 1
ret i8 %inc
}
define i16 @inc16m(ptr %ptr) {
; NDD-LABEL: inc16m:
; NDD: # %bb.0: # %entry
; NDD-NEXT: movzwl (%rdi), %eax
; NDD-NEXT: incw %ax
; NDD-NEXT: retq
;
; IMMONLY-LABEL: inc16m:
; IMMONLY: # %bb.0: # %entry
; IMMONLY-NEXT: movzwl (%rdi), %eax
; IMMONLY-NEXT: incw %ax
; IMMONLY-NEXT: retq
;
; MEM-LABEL: inc16m:
; MEM: # %bb.0: # %entry
; MEM-NEXT: incw (%rdi), %ax
; MEM-NEXT: retq
;
; NF-LABEL: inc16m:
; NF: # %bb.0: # %entry
; NF-NEXT: movzwl (%rdi), %eax
; NF-NEXT: incw %ax
; NF-NEXT: retq
entry:
%a = load i16, ptr %ptr
%inc = add i16 %a, 1
ret i16 %inc
}
define i32 @inc32m(ptr %ptr) {
; NDD-LABEL: inc32m:
; NDD: # %bb.0: # %entry
; NDD-NEXT: movl (%rdi), %eax
; NDD-NEXT: incl %eax
; NDD-NEXT: retq
;
; IMMONLY-LABEL: inc32m:
; IMMONLY: # %bb.0: # %entry
; IMMONLY-NEXT: movl (%rdi), %eax
; IMMONLY-NEXT: incl %eax
; IMMONLY-NEXT: retq
;
; MEM-LABEL: inc32m:
; MEM: # %bb.0: # %entry
; MEM-NEXT: incl (%rdi), %eax
; MEM-NEXT: retq
;
; NF-LABEL: inc32m:
; NF: # %bb.0: # %entry
; NF-NEXT: movl (%rdi), %eax
; NF-NEXT: incl %eax
; NF-NEXT: retq
entry:
%a = load i32, ptr %ptr
%inc = add i32 %a, 1
ret i32 %inc
}
define i64 @inc64m(ptr %ptr) {
; NDD-LABEL: inc64m:
; NDD: # %bb.0: # %entry
; NDD-NEXT: movq (%rdi), %rax
; NDD-NEXT: incq %rax
; NDD-NEXT: retq
;
; IMMONLY-LABEL: inc64m:
; IMMONLY: # %bb.0: # %entry
; IMMONLY-NEXT: movq (%rdi), %rax
; IMMONLY-NEXT: incq %rax
; IMMONLY-NEXT: retq
;
; MEMONLY-LABEL: inc64m:
; MEMONLY: # %bb.0: # %entry
; MEMONLY-NEXT: movq (%rdi), %rax
; MEMONLY-NEXT: incq %rax
; MEMONLY-NEXT: retq
;
; BOTH-LABEL: inc64m:
; BOTH: # %bb.0: # %entry
; BOTH-NEXT: incq (%rdi), %rax
; BOTH-NEXT: retq
;
; NF-LABEL: inc64m:
; NF: # %bb.0: # %entry
; NF-NEXT: movq (%rdi), %rax
; NF-NEXT: incq %rax
; NF-NEXT: retq
entry:
%a = load i64, ptr %ptr
%inc = add i64 %a, 1
ret i64 %inc
}
define i8 @uinc8r(i8 noundef %a) {
; CHECK-LABEL: uinc8r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incb %dil, %al
; CHECK-NEXT: movzbl %al, %eax
; CHECK-NEXT: movl $255, %ecx
; CHECK-NEXT: cmovel %ecx, %eax
; CHECK-NEXT: # kill: def $al killed $al killed $eax
; CHECK-NEXT: retq
;
; NF-LABEL: uinc8r:
; NF: # %bb.0: # %entry
; NF-NEXT: incb %dil, %al
; NF-NEXT: movzbl %al, %eax
; NF-NEXT: movl $255, %ecx
; NF-NEXT: cmovel %ecx, %eax
; NF-NEXT: # kill: def $al killed $al killed $eax
; NF-NEXT: retq
entry:
%inc = call i8 @llvm.uadd.sat.i8(i8 %a, i8 1)
ret i8 %inc
}
define i16 @uinc16r(i16 noundef %a) {
; CHECK-LABEL: uinc16r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incw %di, %ax
; CHECK-NEXT: movl $65535, %ecx # imm = 0xFFFF
; CHECK-NEXT: cmovel %ecx, %eax
; CHECK-NEXT: # kill: def $ax killed $ax killed $eax
; CHECK-NEXT: retq
;
; NF-LABEL: uinc16r:
; NF: # %bb.0: # %entry
; NF-NEXT: incw %di, %ax
; NF-NEXT: movl $65535, %ecx # imm = 0xFFFF
; NF-NEXT: cmovel %ecx, %eax
; NF-NEXT: # kill: def $ax killed $ax killed $eax
; NF-NEXT: retq
entry:
%inc = call i16 @llvm.uadd.sat.i16(i16 %a, i16 1)
ret i16 %inc
}
define i32 @uinc32r(i32 noundef %a) {
; CHECK-LABEL: uinc32r:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incl %edi, %eax
; CHECK-NEXT: movl $-1, %ecx
; CHECK-NEXT: cmovel %ecx, %eax
; CHECK-NEXT: retq
;
; NF-LABEL: uinc32r:
; NF: # %bb.0: # %entry
; NF-NEXT: incl %edi, %eax
; NF-NEXT: movl $-1, %ecx
; NF-NEXT: cmovel %ecx, %eax
; NF-NEXT: retq
entry:
%inc = call i32 @llvm.uadd.sat.i32(i32 %a, i32 1)
ret i32 %inc
}
define i64 @uinc64r(i64 noundef %a) {
; NDD-LABEL: uinc64r:
; NDD: # %bb.0: # %entry
; NDD-NEXT: incq %rdi
; NDD-NEXT: movq $-1, %rax
; NDD-NEXT: cmovneq %rdi, %rax
; NDD-NEXT: retq
;
; IMM-LABEL: uinc64r:
; IMM: # %bb.0: # %entry
; IMM-NEXT: incq %rdi, %rax
; IMM-NEXT: movq $-1, %rcx
; IMM-NEXT: cmoveq %rcx, %rax
; IMM-NEXT: retq
;
; MEMONLY-LABEL: uinc64r:
; MEMONLY: # %bb.0: # %entry
; MEMONLY-NEXT: incq %rdi
; MEMONLY-NEXT: movq $-1, %rax
; MEMONLY-NEXT: cmovneq %rdi, %rax
; MEMONLY-NEXT: retq
;
; NF-LABEL: uinc64r:
; NF: # %bb.0: # %entry
; NF-NEXT: incq %rdi
; NF-NEXT: movq $-1, %rax
; NF-NEXT: cmovneq %rdi, %rax
; NF-NEXT: retq
entry:
%inc = call i64 @llvm.uadd.sat.i64(i64 %a, i64 1)
ret i64 %inc
}
declare i8 @llvm.uadd.sat.i8(i8, i8)
declare i16 @llvm.uadd.sat.i16(i16, i16)
declare i32 @llvm.uadd.sat.i32(i32, i32)
declare i64 @llvm.uadd.sat.i64(i64, i64)
define void @inc8m_legacy(ptr %ptr) {
; CHECK-LABEL: inc8m_legacy:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incb (%rdi)
; CHECK-NEXT: retq
;
; NF-LABEL: inc8m_legacy:
; NF: # %bb.0: # %entry
; NF-NEXT: incb (%rdi)
; NF-NEXT: retq
entry:
%a = load i8, ptr %ptr
%inc = add i8 %a, 1
store i8 %inc, ptr %ptr
ret void
}
define void @inc16m_legacy(ptr %ptr) {
; CHECK-LABEL: inc16m_legacy:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incw (%rdi)
; CHECK-NEXT: retq
;
; NF-LABEL: inc16m_legacy:
; NF: # %bb.0: # %entry
; NF-NEXT: incw (%rdi)
; NF-NEXT: retq
entry:
%a = load i16, ptr %ptr
%inc = add i16 %a, 1
store i16 %inc, ptr %ptr
ret void
}
define void @inc32m_legacy(ptr %ptr) {
; CHECK-LABEL: inc32m_legacy:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incl (%rdi)
; CHECK-NEXT: retq
;
; NF-LABEL: inc32m_legacy:
; NF: # %bb.0: # %entry
; NF-NEXT: incl (%rdi)
; NF-NEXT: retq
entry:
%a = load i32, ptr %ptr
%inc = add i32 %a, 1
store i32 %inc, ptr %ptr
ret void
}
define void @inc64m_legacy(ptr %ptr) {
; CHECK-LABEL: inc64m_legacy:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: incq (%rdi)
; CHECK-NEXT: retq
;
; NF-LABEL: inc64m_legacy:
; NF: # %bb.0: # %entry
; NF-NEXT: incq (%rdi)
; NF-NEXT: retq
entry:
%a = load i64, ptr %ptr
%inc = add i64 %a, 1
store i64 %inc, ptr %ptr
ret void
}