xref: /aosp_15_r20/external/XNNPACK/scripts/generate-qs8-vcvt.sh (revision 4bdc94577ba0e567308109d787f7fec7b531ce36)
1#!/bin/sh
2# Copyright 2022 Google LLC
3#
4# This source code is licensed under the BSD-style license found in the
5# LICENSE file in the root directory of this source tree.
6
7################################## ARM NEON ###################################
8tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=8  -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-neon-x8.c &
9tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=16 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-neon-x16.c &
10tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=32 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-neon-x32.c &
11
12tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=8  -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-neon-x8.c &
13tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=16 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-neon-x16.c &
14tools/xngen src/qs8-vcvt/neon.c.in -D BATCH_TILE=32 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-neon-x32.c &
15
16################################### x86 SSE2 ##################################
17tools/xngen src/qs8-vcvt/sse2.c.in -D BATCH_TILE=16 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-sse2-x16.c &
18tools/xngen src/qs8-vcvt/sse2.c.in -D BATCH_TILE=32 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-sse2-x32.c &
19
20tools/xngen src/qs8-vcvt/sse2.c.in -D BATCH_TILE=16 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-sse2-x16.c &
21tools/xngen src/qs8-vcvt/sse2.c.in -D BATCH_TILE=32 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-sse2-x32.c &
22
23################################## x86 SSSE3 ##################################
24tools/xngen src/qs8-vcvt/ssse3.c.in -D BATCH_TILE=16 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-ssse3-x16.c &
25tools/xngen src/qs8-vcvt/ssse3.c.in -D BATCH_TILE=32 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-ssse3-x32.c &
26
27tools/xngen src/qs8-vcvt/ssse3.c.in -D BATCH_TILE=16 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-ssse3-x16.c &
28tools/xngen src/qs8-vcvt/ssse3.c.in -D BATCH_TILE=32 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-ssse3-x32.c &
29
30################################## x86 SSE4.1 #################################
31tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=8  -D AVX=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-sse41-x8.c &
32tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=16 -D AVX=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-sse41-x16.c &
33tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=32 -D AVX=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-sse41-x32.c &
34
35tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=8  -D AVX=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx-x8.c &
36tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=16 -D AVX=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx-x16.c &
37tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=32 -D AVX=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx-x32.c &
38
39tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=8  -D AVX=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-sse41-x8.c &
40tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=16 -D AVX=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-sse41-x16.c &
41tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=32 -D AVX=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-sse41-x32.c &
42
43tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=8  -D AVX=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx-x8.c &
44tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=16 -D AVX=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx-x16.c &
45tools/xngen src/qs8-vcvt/sse4.c.in -D BATCH_TILE=32 -D AVX=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx-x32.c &
46
47################################### x86 AVX2 ##################################
48tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=16 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx2-x16.c &
49tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=32 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx2-x32.c &
50tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=64 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-avx2-x64.c &
51
52tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=16 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx2-x16.c &
53tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=32 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx2-x32.c &
54tools/xngen src/qs8-vcvt/avx2.c.in -D BATCH_TILE=64 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-avx2-x64.c &
55
56################################## WAsm SIMD ##################################
57tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=8  -D RELAXED=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmsimd-x8.c &
58tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=16 -D RELAXED=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmsimd-x16.c &
59tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=32 -D RELAXED=0 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmsimd-x32.c &
60
61tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=8  -D RELAXED=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmrelaxedsimd-x8.c &
62tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=16 -D RELAXED=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmrelaxedsimd-x16.c &
63tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=32 -D RELAXED=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-wasmrelaxedsimd-x32.c &
64
65tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=8  -D RELAXED=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmsimd-x8.c &
66tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=16 -D RELAXED=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmsimd-x16.c &
67tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=32 -D RELAXED=0 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmsimd-x32.c &
68
69tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=8  -D RELAXED=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmrelaxedsimd-x8.c &
70tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=16 -D RELAXED=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmrelaxedsimd-x16.c &
71tools/xngen src/qs8-vcvt/wasmsimd.c.in -D BATCH_TILE=32 -D RELAXED=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-wasmrelaxedsimd-x32.c &
72
73################################## ARMv6 SIMD #################################
74tools/xngen src/qs8-vcvt/armsimd32.c.in -D BATCH_TILE=4 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-armsimd32-x4.c &
75tools/xngen src/qs8-vcvt/armsimd32.c.in -D BATCH_TILE=8 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-armsimd32-x8.c &
76
77tools/xngen src/qs8-vcvt/armsimd32.c.in -D BATCH_TILE=4 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-armsimd32-x4.c &
78tools/xngen src/qs8-vcvt/armsimd32.c.in -D BATCH_TILE=8 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-armsimd32-x8.c &
79
80#################################### Scalar ###################################
81tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=1 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-scalar-x1.c &
82tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=2 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-scalar-x2.c &
83tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=4 -D DATATYPE=QS8 -o src/qs8-vcvt/gen/vcvt-scalar-x4.c &
84
85tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=1 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-scalar-x1.c &
86tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=2 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-scalar-x2.c &
87tools/xngen src/qs8-vcvt/scalar.c.in -D BATCH_TILE=4 -D DATATYPE=QU8 -o src/qu8-vcvt/gen/vcvt-scalar-x4.c &
88
89################################## Unit tests #################################
90tools/generate-vcvt-test.py --spec test/qs8-vcvt.yaml --output test/qs8-vcvt.cc &
91tools/generate-vcvt-test.py --spec test/qu8-vcvt.yaml --output test/qu8-vcvt.cc &
92
93wait
94