summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/absdiff_256.ll
blob: acc8a1fa51d87eeee669fc22d35e800a2ed52b58 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
; RUN: llc < %s -mtriple=x86_64-unknown-unknown  | FileCheck %s

declare <16 x i16> @llvm.sabsdiff.v16i16(<16 x i16>, <16 x i16>)

define <16 x i16> @test_sabsdiff_v16i16_expand(<16 x i16> %a1, <16 x i16> %a2) {
; CHECK-LABEL: test_sabsdiff_v16i16_expand:
; CHECK:       # BB#0:
; CHECK:         psubw
; CHECK:         pxor
; CHECK:         pcmpgtw
; CHECK:         movdqa
; CHECK:         pandn
; CHECK:         pxor
; CHECK:         psubw
; CHECK:         pcmpeqd
; CHECK:         pxor
; CHECK:         pandn
; CHECK:         por
; CHECK:         pcmpgtw
; CHECK-DAG:     psubw {{%xmm[0-9]+}}, [[SRC:%xmm[0-9]+]]
; CHECK-DAG:     pxor {{%xmm[0-9]+}}, [[DST:%xmm[0-9]+]]
; CHECK:         pandn [[SRC]], [[DST]]
; CHECK:         por
; CHECK:         movdqa
; CHECK:         retq
  %1 = call <16 x i16> @llvm.sabsdiff.v16i16(<16 x i16> %a1, <16 x i16> %a2)
  ret <16 x i16> %1
}

OpenPOWER on IntegriCloud