summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/fsxor-alignment.ll
blob: 6a8dbcfaa7c3b2b30d1c2c1bb257627032d788a3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
; RUN: llc < %s -march=x86 -mattr=+sse2 -enable-unsafe-fp-math | \
; RUN:  grep -v sp | grep xorps | count 2

; Don't fold the incoming stack arguments into the xorps instructions used
; to do floating-point negations, because the arguments aren't vectors
; and aren't vector-aligned.

define void @foo(float* %p, float* %q, float %s, float %y) {
  %ss = fsub float -0.0, %s
  %yy = fsub float -0.0, %y
  store float %ss, float* %p
  store float %yy, float* %q
  ret void
}