blob: 77b3f263213a9b916c38c7876e1da1b2fad8fafe [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc < %s -mtriple=i686-linux-gnu -fast-isel | FileCheck %s --check-prefixes=X86,FASTISEL-X86
; RUN: llc < %s -mtriple=i686-linux-gnu -global-isel=0 -fast-isel=0 | FileCheck %s --check-prefixes=X86,SDAG-X86
; DISABLED: llc < %s -mtriple=i686-linux-gnu -global-isel=1 -global-isel-abort=2 | FileCheck %s --check-prefixes=X86,GISEL-X86
; RUN: llc < %s -mtriple=i686-linux-gnu -fast-isel -mattr=+sse | FileCheck %s --check-prefixes=X86,SSE-X86,FASTISEL-SSE-X86
; RUN: llc < %s -mtriple=i686-linux-gnu -global-isel=0 -fast-isel=0 -mattr=+sse | FileCheck %s --check-prefixes=X86,SSE-X86,SDAG-SSE-X86
; DISABLED: llc < %s -mtriple=i686-linux-gnu -global-isel=1 -global-isel-abort=2 -mattr=+sse | FileCheck %s --check-prefixes=X86,SSE-X86,GISEL-SSE-X86
; RUN: llc < %s -mtriple=x86_64-linux-gnu -fast-isel -mattr=+sse | FileCheck %s --check-prefixes=X64,SSE-X64,FASTISEL-SSE-X64
; RUN: llc < %s -mtriple=x86_64-linux-gnu -global-isel=0 -fast-isel=0 -mattr=+sse | FileCheck %s --check-prefixes=X64,SSE-X64,SDAG-SSE-X64
; RUN: llc < %s -mtriple=x86_64-linux-gnu -global-isel=1 -global-isel-abort=2 -mattr=+sse | FileCheck %s --check-prefixes=X64,SSE-X64,GISEL-SSE-X64
define double @fneg_f64(double %x) nounwind {
; X86-LABEL: fneg_f64:
; X86: # %bb.0:
; X86-NEXT: fldl {{[0-9]+}}(%esp)
; X86-NEXT: fchs
; X86-NEXT: retl
;
; FASTISEL-SSE-X64-LABEL: fneg_f64:
; FASTISEL-SSE-X64: # %bb.0:
; FASTISEL-SSE-X64-NEXT: movq %xmm0, %rax
; FASTISEL-SSE-X64-NEXT: movabsq $-9223372036854775808, %rcx # imm = 0x8000000000000000
; FASTISEL-SSE-X64-NEXT: xorq %rax, %rcx
; FASTISEL-SSE-X64-NEXT: movq %rcx, %xmm0
; FASTISEL-SSE-X64-NEXT: retq
;
; SDAG-SSE-X64-LABEL: fneg_f64:
; SDAG-SSE-X64: # %bb.0:
; SDAG-SSE-X64-NEXT: xorps {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
; SDAG-SSE-X64-NEXT: retq
;
; GISEL-SSE-X64-LABEL: fneg_f64:
; GISEL-SSE-X64: # %bb.0:
; GISEL-SSE-X64-NEXT: movabsq $-9223372036854775808, %rax # imm = 0x8000000000000000
; GISEL-SSE-X64-NEXT: movq %xmm0, %rcx
; GISEL-SSE-X64-NEXT: xorq %rax, %rcx
; GISEL-SSE-X64-NEXT: movq %rcx, %xmm0
; GISEL-SSE-X64-NEXT: retq
%y = fneg double %x
ret double %y
}
define float @fneg_f32(float %x) nounwind {
; FASTISEL-X86-LABEL: fneg_f32:
; FASTISEL-X86: # %bb.0:
; FASTISEL-X86-NEXT: flds {{[0-9]+}}(%esp)
; FASTISEL-X86-NEXT: fchs
; FASTISEL-X86-NEXT: retl
;
; SDAG-X86-LABEL: fneg_f32:
; SDAG-X86: # %bb.0:
; SDAG-X86-NEXT: flds {{[0-9]+}}(%esp)
; SDAG-X86-NEXT: fchs
; SDAG-X86-NEXT: retl
;
; SSE-X86-LABEL: fneg_f32:
; SSE-X86: # %bb.0:
; SSE-X86-NEXT: pushl %eax
; SSE-X86-NEXT: movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SSE-X86-NEXT: xorps {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
; SSE-X86-NEXT: movss %xmm0, (%esp)
; SSE-X86-NEXT: flds (%esp)
; SSE-X86-NEXT: popl %eax
; SSE-X86-NEXT: retl
;
; FASTISEL-SSE-X64-LABEL: fneg_f32:
; FASTISEL-SSE-X64: # %bb.0:
; FASTISEL-SSE-X64-NEXT: movd %xmm0, %eax
; FASTISEL-SSE-X64-NEXT: xorl $2147483648, %eax # imm = 0x80000000
; FASTISEL-SSE-X64-NEXT: movd %eax, %xmm0
; FASTISEL-SSE-X64-NEXT: retq
;
; SDAG-SSE-X64-LABEL: fneg_f32:
; SDAG-SSE-X64: # %bb.0:
; SDAG-SSE-X64-NEXT: xorps {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
; SDAG-SSE-X64-NEXT: retq
;
; GISEL-SSE-X64-LABEL: fneg_f32:
; GISEL-SSE-X64: # %bb.0:
; GISEL-SSE-X64-NEXT: movd %xmm0, %eax
; GISEL-SSE-X64-NEXT: addl $-2147483648, %eax # imm = 0x80000000
; GISEL-SSE-X64-NEXT: movd %eax, %xmm0
; GISEL-SSE-X64-NEXT: retq
%y = fneg float %x
ret float %y
}
define void @fneg_f64_mem(ptr %x, ptr %y) nounwind {
; X86-LABEL: fneg_f64_mem:
; X86: # %bb.0:
; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
; X86-NEXT: fldl (%ecx)
; X86-NEXT: fchs
; X86-NEXT: fstpl (%eax)
; X86-NEXT: retl
;
; FASTISEL-SSE-X64-LABEL: fneg_f64_mem:
; FASTISEL-SSE-X64: # %bb.0:
; FASTISEL-SSE-X64-NEXT: movq {{.*#+}} xmm0 = mem[0],zero
; FASTISEL-SSE-X64-NEXT: movq %xmm0, %rax
; FASTISEL-SSE-X64-NEXT: movabsq $-9223372036854775808, %rcx # imm = 0x8000000000000000
; FASTISEL-SSE-X64-NEXT: xorq %rax, %rcx
; FASTISEL-SSE-X64-NEXT: movq %rcx, %xmm0
; FASTISEL-SSE-X64-NEXT: movq %xmm0, (%rsi)
; FASTISEL-SSE-X64-NEXT: retq
;
; SDAG-SSE-X64-LABEL: fneg_f64_mem:
; SDAG-SSE-X64: # %bb.0:
; SDAG-SSE-X64-NEXT: movabsq $-9223372036854775808, %rax # imm = 0x8000000000000000
; SDAG-SSE-X64-NEXT: xorq (%rdi), %rax
; SDAG-SSE-X64-NEXT: movq %rax, (%rsi)
; SDAG-SSE-X64-NEXT: retq
;
; GISEL-SSE-X64-LABEL: fneg_f64_mem:
; GISEL-SSE-X64: # %bb.0:
; GISEL-SSE-X64-NEXT: movabsq $-9223372036854775808, %rax # imm = 0x8000000000000000
; GISEL-SSE-X64-NEXT: xorq (%rdi), %rax
; GISEL-SSE-X64-NEXT: movq %rax, (%rsi)
; GISEL-SSE-X64-NEXT: retq
%a = load double, ptr %x
%b = fneg double %a
store double %b, ptr %y
ret void
}
define void @fneg_f32_mem(ptr %x, ptr %y) nounwind {
; FASTISEL-X86-LABEL: fneg_f32_mem:
; FASTISEL-X86: # %bb.0:
; FASTISEL-X86-NEXT: movl {{[0-9]+}}(%esp), %eax
; FASTISEL-X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
; FASTISEL-X86-NEXT: movl $-2147483648, %edx # imm = 0x80000000
; FASTISEL-X86-NEXT: xorl (%ecx), %edx
; FASTISEL-X86-NEXT: movl %edx, (%eax)
; FASTISEL-X86-NEXT: retl
;
; SDAG-X86-LABEL: fneg_f32_mem:
; SDAG-X86: # %bb.0:
; SDAG-X86-NEXT: movl {{[0-9]+}}(%esp), %eax
; SDAG-X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
; SDAG-X86-NEXT: movl $-2147483648, %edx # imm = 0x80000000
; SDAG-X86-NEXT: xorl (%ecx), %edx
; SDAG-X86-NEXT: movl %edx, (%eax)
; SDAG-X86-NEXT: retl
;
; FASTISEL-SSE-X86-LABEL: fneg_f32_mem:
; FASTISEL-SSE-X86: # %bb.0:
; FASTISEL-SSE-X86-NEXT: movl {{[0-9]+}}(%esp), %eax
; FASTISEL-SSE-X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
; FASTISEL-SSE-X86-NEXT: movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; FASTISEL-SSE-X86-NEXT: xorps {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
; FASTISEL-SSE-X86-NEXT: movss %xmm0, (%eax)
; FASTISEL-SSE-X86-NEXT: retl
;
; SDAG-SSE-X86-LABEL: fneg_f32_mem:
; SDAG-SSE-X86: # %bb.0:
; SDAG-SSE-X86-NEXT: movl {{[0-9]+}}(%esp), %eax
; SDAG-SSE-X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
; SDAG-SSE-X86-NEXT: movl $-2147483648, %edx # imm = 0x80000000
; SDAG-SSE-X86-NEXT: xorl (%ecx), %edx
; SDAG-SSE-X86-NEXT: movl %edx, (%eax)
; SDAG-SSE-X86-NEXT: retl
;
; FASTISEL-SSE-X64-LABEL: fneg_f32_mem:
; FASTISEL-SSE-X64: # %bb.0:
; FASTISEL-SSE-X64-NEXT: movd {{.*#+}} xmm0 = mem[0],zero,zero,zero
; FASTISEL-SSE-X64-NEXT: movd %xmm0, %eax
; FASTISEL-SSE-X64-NEXT: xorl $2147483648, %eax # imm = 0x80000000
; FASTISEL-SSE-X64-NEXT: movd %eax, %xmm0
; FASTISEL-SSE-X64-NEXT: movd %xmm0, (%rsi)
; FASTISEL-SSE-X64-NEXT: retq
;
; SDAG-SSE-X64-LABEL: fneg_f32_mem:
; SDAG-SSE-X64: # %bb.0:
; SDAG-SSE-X64-NEXT: movl $-2147483648, %eax # imm = 0x80000000
; SDAG-SSE-X64-NEXT: xorl (%rdi), %eax
; SDAG-SSE-X64-NEXT: movl %eax, (%rsi)
; SDAG-SSE-X64-NEXT: retq
;
; GISEL-SSE-X64-LABEL: fneg_f32_mem:
; GISEL-SSE-X64: # %bb.0:
; GISEL-SSE-X64-NEXT: movl $-2147483648, %eax # imm = 0x80000000
; GISEL-SSE-X64-NEXT: xorl (%rdi), %eax
; GISEL-SSE-X64-NEXT: movl %eax, (%rsi)
; GISEL-SSE-X64-NEXT: retq
%a = load float, ptr %x
%b = fneg float %a
store float %b, ptr %y
ret void
}
define x86_fp80 @test_fp80(x86_fp80 %a) nounwind {
; X86-LABEL: test_fp80:
; X86: # %bb.0:
; X86-NEXT: fldt {{[0-9]+}}(%esp)
; X86-NEXT: fchs
; X86-NEXT: retl
;
; X64-LABEL: test_fp80:
; X64: # %bb.0:
; X64-NEXT: fldt {{[0-9]+}}(%rsp)
; X64-NEXT: fchs
; X64-NEXT: retq
%1 = fneg x86_fp80 %a
ret x86_fp80 %1
}
;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
; SSE-X64: {{.*}}