/external/llvm/test/CodeGen/PowerPC/ |
D | float-to-int.ll | 2 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 17 ; CHECK-VSX: @foo 18 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1 19 ; CHECK-VSX: stxsdx [[REG]], 20 ; CHECK-VSX: ld 3, 21 ; CHECK-VSX: blr 34 ; CHECK-VSX: @foo2 35 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1 36 ; CHECK-VSX: stxsdx [[REG]], 37 ; CHECK-VSX: ld 3, [all …]
|
D | fma-assoc.ll | 2 …t -mattr=+vsx -mcpu=pwr7 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX %s 16 ; CHECK-VSX-LABEL: test_FMADD_ASSOC1: 17 ; CHECK-VSX: xsmaddmdp 18 ; CHECK-VSX-NEXT: xsmaddadp 19 ; CHECK-VSX-NEXT: fmr 20 ; CHECK-VSX-NEXT: blr 35 ; CHECK-VSX-LABEL: test_FMADD_ASSOC2: 36 ; CHECK-VSX: xsmaddmdp 37 ; CHECK-VSX-NEXT: xsmaddadp 38 ; CHECK-VSX-NEXT: fmr [all …]
|
D | i64-to-float.ll | 2 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 17 ; CHECK-VSX: @foo 18 ; CHECK-VSX: std 3, 19 ; CHECK-VSX: lxsdx [[REG:[0-9]+]], 20 ; CHECK-VSX: fcfids 1, [[REG]] 21 ; CHECK-VSX: blr 35 ; CHECK-VSX: @goo 36 ; CHECK-VSX: std 3, 37 ; CHECK-VSX: lxsdx [[REG:[0-9]+]], 38 ; CHECK-VSX: xscvsxddp 1, [[REG]] [all …]
|
D | fsel.ll | 3 …nable-no-infs-fp-math -enable-no-nans-fp-math -mattr=+vsx | FileCheck -check-prefix=CHECK-FM-VSX %s 21 ; CHECK-FM-VSX: @zerocmp1 22 ; CHECK-FM-VSX: fsel 1, 1, 2, 3 23 ; CHECK-FM-VSX: blr 41 ; CHECK-FM-VSX: @zerocmp2 42 ; CHECK-FM-VSX: xsnegdp [[REG:[0-9]+]], 1 43 ; CHECK-FM-VSX: fsel 1, [[REG]], 3, 2 44 ; CHECK-FM-VSX: blr 63 ; CHECK-FM-VSX: @zerocmp3 64 ; CHECK-FM-VSX: xsnegdp [[REG2:[0-9]+]], 1 [all …]
|
D | unaligned.ll | 3 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 16 ; CHECK-VSX: @foo1 17 ; CHECK-VSX: lhz 18 ; CHECK-VSX: sth 31 ; CHECK-VSX: @foo2 32 ; CHECK-VSX: lwz 33 ; CHECK-VSX: stw 46 ; CHECK-VSX: @foo3 47 ; CHECK-VSX: ld 48 ; CHECK-VSX: std [all …]
|
D | vec_mul.ll | 4 …inux-gnu -march=ppc64 -mattr=+altivec -mattr=+vsx -mcpu=pwr7 | FileCheck %s -check-prefix=CHECK-VSX 5 …tr=+altivec -mattr=+vsx -mcpu=pwr8 -mattr=-power8-altivec | FileCheck %s -check-prefix=CHECK-LE-VSX 19 ; CHECK-VSX-LABEL: test_v4i32: 20 ; CHECK-VSX: vmsumuhm 21 ; CHECK-VSX-NOT: mullw 22 ; CHECK-LE-VSX-LABEL: test_v4i32: 23 ; CHECK-LE-VSX: vmsumuhm 24 ; CHECK-LE-VSX-NOT: mullw 38 ; CHECK-VSX-LABEL: test_v8i16: 39 ; CHECK-VSX: vmladduhm [all …]
|
D | i32-to-float.ll | 4 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 34 ; CHECK-VSX: @foo 35 ; CHECK-VSX: stw 3, 36 ; CHECK-VSX: lfiwax [[REG:[0-9]+]], 37 ; CHECK-VSX: fcfids 1, [[REG]] 38 ; CHECK-VSX: blr 65 ; CHECK-VSX: @goo 66 ; CHECK-VSX: stw 3, 67 ; CHECK-VSX: lfiwax [[REG:[0-9]+]], 68 ; CHECK-VSX: xscvsxddp 1, [[REG]] [all …]
|
D | fma-ext.ll | 2 …t -mattr=+vsx -mcpu=pwr7 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX %s 13 ; CHECK-VSX-LABEL: test_FMADD_EXT1: 14 ; CHECK-VSX: xsmaddmdp 15 ; CHECK-VSX-NEXT: blr 27 ; CHECK-VSX-LABEL: test_FMADD_EXT2: 28 ; CHECK-VSX: xsmaddmdp 29 ; CHECK-VSX-NEXT: blr 41 ; CHECK-VSX-LABEL: test_FMSUB_EXT1: 42 ; CHECK-VSX: xsmsubmdp 43 ; CHECK-VSX-NEXT: blr [all …]
|
D | rounding-ops.ll | 2 …iple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx < %s | FileCheck -check-prefix=CHECK-VSX %s 12 ; CHECK-VSX-LABEL: test1: 13 ; CHECK-VSX: frim 1, 1 24 ; CHECK-VSX-LABEL: test2: 25 ; CHECK-VSX: xsrdpim 1, 1 36 ; CHECK-VSX-LABEL: test3: 37 ; CHECK-VSX: frin 1, 1 48 ; CHECK-VSX-LABEL: test4: 49 ; CHECK-VSX: xsrdpi 1, 1 60 ; CHECK-VSX-LABEL: test5: [all …]
|
D | copysignl.ll | 2 …u=pwr7 -mtriple=powerpc64-unknown-linux-gnu -mattr=+vsx < %s | FileCheck %s -check-prefix=CHECK-VSX 15 ; CHECK-VSX-LABEL: @foo_d_ll 16 ; CHECK-VSX: xscpsgndp 1, 3, 1 17 ; CHECK-VSX: blr 31 ; CHECK-VSX-LABEL: @foo_dl 32 ; CHECK-VSX: xscpsgndp 1, 2, 1 33 ; CHECK-VSX: blr 47 ; CHECK-VSX-LABEL: @foo_ll 48 ; CHECK-VSX: bl copysignl 49 ; CHECK-VSX: blr [all …]
|
D | mcm-4.ll | 2 …wr7 -O0 -code-model=medium -fast-isel=false -mattr=+vsx <%s | FileCheck -check-prefix=MEDIUM-VSX %s 4 …=pwr7 -O0 -code-model=large -fast-isel=false -mattr=+vsx <%s | FileCheck -check-prefix=LARGE-VSX %s 24 ; MEDIUM-VSX: [[VAR:[a-z0-9A-Z_.]+]]: 25 ; MEDIUM-VSX: .quad 4562098671269285104 26 ; MEDIUM-VSX-LABEL: test_double_const: 27 ; MEDIUM-VSX: addis [[REG1:[0-9]+]], 2, [[VAR]]@toc@ha 28 ; MEDIUM-VSX: addi [[REG2:[0-9]+]], [[REG1]], [[VAR]]@toc@l 29 ; MEDIUM-VSX: lxsdx {{[0-9]+}}, 0, [[REG2]] 38 ; LARGE-VSX: [[VAR:[a-z0-9A-Z_.]+]]: 39 ; LARGE-VSX: .quad 4562098671269285104 [all …]
|
D | fcpsgn.ll | 2 …iple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx < %s | FileCheck -check-prefix=CHECK-VSX %s 14 ; CHECK-VSX-LABEL: @foo_dd 15 ; CHECK-VSX: xscpsgndp 1, 2, 1 16 ; CHECK-VSX: blr 29 ; CHECK-VSX-LABEL: @foo_ss 30 ; CHECK-VSX: fcpsgn 1, 2, 1 31 ; CHECK-VSX: blr 45 ; CHECK-VSX-LABEL: @foo_sd 46 ; CHECK-VSX: fcpsgn 1, 2, 1 47 ; CHECK-VSX: blr [all …]
|
/external/swiftshader/third_party/llvm-7.0/llvm/test/CodeGen/PowerPC/ |
D | fma-assoc.ll | 2 …able-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX -check-prefix=CHECK-VSX-SAFE %s 4 …le-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX -check-prefix=CHECK-UNSAFE-VSX %s 24 ; CHECK-VSX-SAFE-LABEL: test_FMADD_ASSOC1: 25 ; CHECK-VSX-SAFE: xsmuldp 26 ; CHECK-VSX-SAFE-NEXT: xsmaddadp 27 ; CHECK-VSX-SAFE-NEXT: xsadddp 28 ; CHECK-VSX-SAFE-NEXT: blr 30 ; CHECK-VSX-UNSAFE-LABEL: test_FMADD_ASSOC1: 31 ; CHECK-VSX-UNSAFE: xsmaddmdp 32 ; CHECK-VSX-UNSAFE-NEXT: xsmaddadp [all …]
|
D | float-to-int.ll | 4 ; RUN: -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 22 ; CHECK-VSX: @foo 23 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1 24 ; CHECK-VSX: stfdx [[REG]], 25 ; CHECK-VSX: ld 3, 26 ; CHECK-VSX: blr 45 ; CHECK-VSX: @foo2 46 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1 47 ; CHECK-VSX: stfdx [[REG]], 48 ; CHECK-VSX: ld 3, [all …]
|
D | fsel.ll | 3 …nable-no-infs-fp-math -enable-no-nans-fp-math -mattr=+vsx | FileCheck -check-prefix=CHECK-FM-VSX %s 21 ; CHECK-FM-VSX: @zerocmp1 22 ; CHECK-FM-VSX: fsel 1, 1, 2, 3 23 ; CHECK-FM-VSX: blr 41 ; CHECK-FM-VSX: @zerocmp2 42 ; CHECK-FM-VSX: xsnegdp [[REG:[0-9]+]], 1 43 ; CHECK-FM-VSX: fsel 1, [[REG]], 3, 2 44 ; CHECK-FM-VSX: blr 63 ; CHECK-FM-VSX: @zerocmp3 64 ; CHECK-FM-VSX: xsnegdp [[REG2:[0-9]+]], 1 [all …]
|
D | unaligned.ll | 3 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 16 ; CHECK-VSX: @foo1 17 ; CHECK-VSX: lhz 18 ; CHECK-VSX: sth 31 ; CHECK-VSX: @foo2 32 ; CHECK-VSX: lwz 33 ; CHECK-VSX: stw 46 ; CHECK-VSX: @foo3 47 ; CHECK-VSX: ld 48 ; CHECK-VSX: std [all …]
|
D | i64-to-float.ll | 4 ; RUN: -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 21 ; CHECK-VSX: @foo 22 ; CHECK-VSX: std 3, 23 ; CHECK-VSX: lfdx [[REG:[0-9]+]], 24 ; CHECK-VSX: fcfids 1, [[REG]] 25 ; CHECK-VSX: blr 45 ; CHECK-VSX: @goo 46 ; CHECK-VSX: std 3, 47 ; CHECK-VSX: lfdx [[REG:[0-9]+]], 48 ; CHECK-VSX: xscvsxddp 1, [[REG]] [all …]
|
D | vec_mul.ll | 4 …c64-unknown-linux-gnu -mattr=+altivec -mattr=+vsx -mcpu=pwr7 | FileCheck %s -check-prefix=CHECK-VSX 5 …tr=+altivec -mattr=+vsx -mcpu=pwr8 -mattr=-power8-altivec | FileCheck %s -check-prefix=CHECK-LE-VSX 19 ; CHECK-VSX-LABEL: test_v4i32: 20 ; CHECK-VSX: vmsumuhm 21 ; CHECK-VSX-NOT: mullw 22 ; CHECK-LE-VSX-LABEL: test_v4i32: 23 ; CHECK-LE-VSX: vmsumuhm 24 ; CHECK-LE-VSX-NOT: mullw 38 ; CHECK-VSX-LABEL: test_v8i16: 39 ; CHECK-VSX: vmladduhm [all …]
|
D | i32-to-float.ll | 4 … -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s 34 ; CHECK-VSX: @foo 35 ; CHECK-VSX: stw 3, 36 ; CHECK-VSX: lfiwax [[REG:[0-9]+]], 37 ; CHECK-VSX: fcfids 1, [[REG]] 38 ; CHECK-VSX: blr 65 ; CHECK-VSX: @goo 66 ; CHECK-VSX: stw 3, 67 ; CHECK-VSX: lfiwax [[REG:[0-9]+]], 68 ; CHECK-VSX: xscvsxddp 1, [[REG]] [all …]
|
D | fma-ext.ll | 2 …t -mattr=+vsx -mcpu=pwr7 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX %s 13 ; CHECK-VSX-LABEL: test_FMADD_EXT1: 14 ; CHECK-VSX: xsmaddmdp 15 ; CHECK-VSX-NEXT: blr 27 ; CHECK-VSX-LABEL: test_FMADD_EXT2: 28 ; CHECK-VSX: xsmaddmdp 29 ; CHECK-VSX-NEXT: blr 41 ; CHECK-VSX-LABEL: test_FMSUB_EXT1: 42 ; CHECK-VSX: xsmsubmdp 43 ; CHECK-VSX-NEXT: blr [all …]
|
D | copysignl.ll | 2 …u=pwr7 -mtriple=powerpc64-unknown-linux-gnu -mattr=+vsx < %s | FileCheck %s -check-prefix=CHECK-VSX 15 ; CHECK-VSX-LABEL: @foo_d_ll 16 ; CHECK-VSX: xscpsgndp 1, 3, 1 17 ; CHECK-VSX: blr 31 ; CHECK-VSX-LABEL: @foo_dl 32 ; CHECK-VSX: xscpsgndp 1, 2, 1 33 ; CHECK-VSX: blr 47 ; CHECK-VSX-LABEL: @foo_ll 48 ; CHECK-VSX: bl copysignl 49 ; CHECK-VSX: blr [all …]
|
D | rounding-ops.ll | 2 …iple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx < %s | FileCheck -check-prefix=CHECK-VSX %s 12 ; CHECK-VSX-LABEL: test1: 13 ; CHECK-VSX: frim 1, 1 24 ; CHECK-VSX-LABEL: test2: 25 ; CHECK-VSX: xsrdpim 1, 1 36 ; CHECK-VSX-LABEL: test3: 37 ; CHECK-VSX: frin 1, 1 48 ; CHECK-VSX-LABEL: test4: 49 ; CHECK-VSX: xsrdpi 1, 1 60 ; CHECK-VSX-LABEL: test5: [all …]
|
D | ppc64-align-long-double.ll | 2 …chineinstrs -mcpu=pwr7 -O2 -fast-isel=false -mattr=+vsx < %s | FileCheck -check-prefix=CHECK-VSX %s 41 ; CHECK-VSX-DAG: std 6, 72(1) 42 ; CHECK-VSX-DAG: std 5, 64(1) 43 ; CHECK-VSX-DAG: std 4, 56(1) 44 ; CHECK-VSX-DAG: std 3, 48(1) 45 ; CHECK-VSX-DAG: std 5, -16(1) 46 ; CHECK-VSX-DAG: std 6, -8(1) 47 ; CHECK-VSX-DAG: addi [[REG1:[0-9]+]], 1, -16 48 ; CHECK-VSX-DAG: addi 3, 1, -8 49 ; CHECK-VSX: lfdx 1, 0, [[REG1]] [all …]
|
D | fcpsgn.ll | 2 …iple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=+vsx < %s | FileCheck -check-prefix=CHECK-VSX %s 14 ; CHECK-VSX-LABEL: @foo_dd 15 ; CHECK-VSX: xscpsgndp 1, 2, 1 16 ; CHECK-VSX: blr 29 ; CHECK-VSX-LABEL: @foo_ss 30 ; CHECK-VSX: fcpsgn 1, 2, 1 31 ; CHECK-VSX: blr 45 ; CHECK-VSX-LABEL: @foo_sd 46 ; CHECK-VSX: fcpsgn 1, 2, 1 47 ; CHECK-VSX: blr [all …]
|
/external/llvm/lib/Target/PowerPC/ |
D | p9-instrs.txt | 4 . Done (Total 155 Instructions: 101 VSX, 54 Altivec) 201 "7.6.1.2.1 VSX Scalar Move Instructions" 202 // VSX Scalar Quad-Precision Move Instructions 204 // VSX Scalar Copy Sign Quad-Precision X-form p.553 207 // VSX Scalar Absolute Quad-Precision X-form 531 208 // VSX Scalar Negate Quad-Precision X-form 627 209 // VSX Scalar Negative Absolute Quad-Precision X-form 626 213 "7.6.1.3 VSX Floating-Point Arithmetic Instructions" 215 // VSX Scalar Quad-Precision Elementary Arithmetic 217 // VSX Scalar Add Quad-Precision [using round to Odd] X-form 539 [all …]
|