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 ] }
30 ] "outputs" set-word-prop
32 \ (simd-broadcast) { byte-array } "default-output-classes" set-word-prop
34 \ (simd-gather-2) { byte-array } "default-output-classes" set-word-prop
36 \ (simd-gather-4) { byte-array } "default-output-classes" set-word-prop
39 real [0,inf] <class/interval-info> value-info-intersect
40 ] "outputs" set-word-prop
42 \ alien-vector { byte-array } "default-output-classes" set-word-prop
44 ! If SIMD is not available, inline alien-vector and set-alien-vector
46 : inline-unless-intrinsic ( word -- )
47 dup '[ drop _ dup "intrinsic" word-prop [ drop f ] [ def>> ] if ]
48 "custom-inlining" set-word-prop ;
50 \ alien-vector inline-unless-intrinsic
52 \ set-alien-vector inline-unless-intrinsic