blob: f1543800b10745d07a3a655f847008d881580fbc [file] [log] [blame]
#!/bin/sh
# Copyright 2020 Google LLC
#
# This source code is licensed under the BSD-style license found in the
# LICENSE file in the root directory of this source tree.
#################################### Scalar ###################################
### Generic C micro-kernels
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDNE -D BATCH_TILE=1 -o src/f32-vrnd/gen/vrndne-scalar-libm-x1.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDNE -D BATCH_TILE=2 -o src/f32-vrnd/gen/vrndne-scalar-libm-x2.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDNE -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-scalar-libm-x4.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDZ -D BATCH_TILE=1 -o src/f32-vrnd/gen/vrndz-scalar-libm-x1.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDZ -D BATCH_TILE=2 -o src/f32-vrnd/gen/vrndz-scalar-libm-x2.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDZ -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-scalar-libm-x4.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDU -D BATCH_TILE=1 -o src/f32-vrnd/gen/vrndu-scalar-libm-x1.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDU -D BATCH_TILE=2 -o src/f32-vrnd/gen/vrndu-scalar-libm-x2.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDU -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-scalar-libm-x4.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDD -D BATCH_TILE=1 -o src/f32-vrnd/gen/vrndd-scalar-libm-x1.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDD -D BATCH_TILE=2 -o src/f32-vrnd/gen/vrndd-scalar-libm-x2.c
tools/xngen src/f32-vrnd/scalar-libm.c.in -D OP=RNDD -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-scalar-libm-x4.c
################################## WAsm SIMD ##################################
tools/xngen src/f32-vrnd/vrndne-wasmsimd-addsub.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-wasmsimd-addsub-x4.c
tools/xngen src/f32-vrnd/vrndne-wasmsimd-addsub.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-wasmsimd-addsub-x8.c
tools/xngen src/f32-vrnd/vrndz-wasmsimd-addsub.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-wasmsimd-addsub-x4.c
tools/xngen src/f32-vrnd/vrndz-wasmsimd-addsub.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-wasmsimd-addsub-x8.c
tools/xngen src/f32-vrnd/vrndu-wasmsimd-addsub.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-wasmsimd-addsub-x4.c
tools/xngen src/f32-vrnd/vrndu-wasmsimd-addsub.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-wasmsimd-addsub-x8.c
tools/xngen src/f32-vrnd/vrndd-wasmsimd-addsub.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-wasmsimd-addsub-x4.c
tools/xngen src/f32-vrnd/vrndd-wasmsimd-addsub.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-wasmsimd-addsub-x8.c
tools/xngen src/f32-vrnd/vrndz-wasmsimd-cvt.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-wasmsimd-cvt-x4.c
tools/xngen src/f32-vrnd/vrndz-wasmsimd-cvt.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-wasmsimd-cvt-x8.c
tools/xngen src/f32-vrnd/vrndu-wasmsimd-cvt.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-wasmsimd-cvt-x4.c
tools/xngen src/f32-vrnd/vrndu-wasmsimd-cvt.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-wasmsimd-cvt-x8.c
tools/xngen src/f32-vrnd/vrndd-wasmsimd-cvt.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-wasmsimd-cvt-x4.c
tools/xngen src/f32-vrnd/vrndd-wasmsimd-cvt.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-wasmsimd-cvt-x8.c
################################### ARM NEON ##################################
tools/xngen src/f32-vrnd/vrndne-neon.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-neon-x4.c
tools/xngen src/f32-vrnd/vrndne-neon.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-neon-x8.c
tools/xngen src/f32-vrnd/vrndz-neon.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-neon-x4.c
tools/xngen src/f32-vrnd/vrndz-neon.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-neon-x8.c
tools/xngen src/f32-vrnd/vrndu-neon.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-neon-x4.c
tools/xngen src/f32-vrnd/vrndu-neon.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-neon-x8.c
tools/xngen src/f32-vrnd/vrndd-neon.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-neon-x4.c
tools/xngen src/f32-vrnd/vrndd-neon.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-neon-x8.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDNE -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-neonv8-x4.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDNE -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-neonv8-x8.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDZ -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-neonv8-x4.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDZ -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-neonv8-x8.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDU -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-neonv8-x4.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDU -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-neonv8-x8.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDD -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-neonv8-x4.c
tools/xngen src/f32-vrnd/neonv8.c.in -D OP=RNDD -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-neonv8-x8.c
################################# x86 128-bit #################################
tools/xngen src/f32-vrnd/vrndne-sse2.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-sse2-x4.c
tools/xngen src/f32-vrnd/vrndne-sse2.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-sse2-x8.c
tools/xngen src/f32-vrnd/vrndz-sse2.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-sse2-x4.c
tools/xngen src/f32-vrnd/vrndz-sse2.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-sse2-x8.c
tools/xngen src/f32-vrnd/vrndu-sse2.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-sse2-x4.c
tools/xngen src/f32-vrnd/vrndu-sse2.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-sse2-x8.c
tools/xngen src/f32-vrnd/vrndd-sse2.c.in -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-sse2-x4.c
tools/xngen src/f32-vrnd/vrndd-sse2.c.in -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-sse2-x8.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDNE -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndne-sse41-x4.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDNE -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-sse41-x8.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDZ -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndz-sse41-x4.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDZ -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-sse41-x8.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDU -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndu-sse41-x4.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDU -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-sse41-x8.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDD -D BATCH_TILE=4 -o src/f32-vrnd/gen/vrndd-sse41-x4.c
tools/xngen src/f32-vrnd/sse41.c.in -D OP=RNDD -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-sse41-x8.c
################################# x86 256-bit #################################
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDNE -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndne-avx-x8.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDNE -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndne-avx-x16.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDZ -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndz-avx-x8.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDZ -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndz-avx-x16.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDU -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndu-avx-x8.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDU -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndu-avx-x16.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDD -D BATCH_TILE=8 -o src/f32-vrnd/gen/vrndd-avx-x8.c
tools/xngen src/f32-vrnd/avx.c.in -D OP=RNDD -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndd-avx-x16.c
################################# x86 512-bit #################################
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDNE -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndne-avx512f-x16.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDNE -D BATCH_TILE=32 -o src/f32-vrnd/gen/vrndne-avx512f-x32.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDZ -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndz-avx512f-x16.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDZ -D BATCH_TILE=32 -o src/f32-vrnd/gen/vrndz-avx512f-x32.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDU -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndu-avx512f-x16.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDU -D BATCH_TILE=32 -o src/f32-vrnd/gen/vrndu-avx512f-x32.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDD -D BATCH_TILE=16 -o src/f32-vrnd/gen/vrndd-avx512f-x16.c
tools/xngen src/f32-vrnd/avx512f.c.in -D OP=RNDD -D BATCH_TILE=32 -o src/f32-vrnd/gen/vrndd-avx512f-x32.c
################################## Unit tests #################################
tools/generate-vunary-test.py --spec test/f32-vrndne.yaml --output test/f32-vrndne.cc
tools/generate-vunary-test.py --spec test/f32-vrndz.yaml --output test/f32-vrndz.cc
tools/generate-vunary-test.py --spec test/f32-vrndu.yaml --output test/f32-vrndu.cc
tools/generate-vunary-test.py --spec test/f32-vrndd.yaml --output test/f32-vrndd.cc