1 ! Copyright (C) 2009 Slava Pestov.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors byte-arrays combinators fry
4 compiler.tree.propagation.info cpu.architecture kernel words math
5 math.intervals math.vectors.simd.intrinsics ;
6 IN: compiler.tree.propagation.simd
8 \ (simd-v+) { byte-array } "default-output-classes" set-word-prop
10 \ (simd-v-) { byte-array } "default-output-classes" set-word-prop
12 \ (simd-v*) { byte-array } "default-output-classes" set-word-prop
14 \ (simd-v/) { byte-array } "default-output-classes" set-word-prop
16 \ (simd-vmin) { byte-array } "default-output-classes" set-word-prop
18 \ (simd-vmax) { byte-array } "default-output-classes" set-word-prop
20 \ (simd-vsqrt) { byte-array } "default-output-classes" set-word-prop
24 literal>> scalar-rep-of {
25 { float-rep [ float ] }
26 { double-rep [ float ] }
27 { int-rep [ integer ] }
31 ] "outputs" set-word-prop
33 \ (simd-broadcast) { byte-array } "default-output-classes" set-word-prop
35 \ (simd-gather-2) { byte-array } "default-output-classes" set-word-prop
37 \ (simd-gather-4) { byte-array } "default-output-classes" set-word-prop
40 real [0,inf] <class/interval-info> value-info-intersect
41 ] "outputs" set-word-prop
43 \ alien-vector { byte-array } "default-output-classes" set-word-prop
45 ! If SIMD is not available, inline alien-vector and set-alien-vector
47 : inline-unless-intrinsic ( word -- )
48 dup '[ drop _ dup "intrinsic" word-prop [ drop f ] [ def>> ] if ]
49 "custom-inlining" set-word-prop ;
51 \ alien-vector inline-unless-intrinsic
53 \ set-alien-vector inline-unless-intrinsic