| #!/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. |
| |
| ################################### x86 SSE ################################### |
| ### C2 micro-kernels |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c2-minmax-sse2-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=2 -D VARIANT=LD64 -o src/qs8-gemm/gen/4x4c2-minmax-sse2-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c2-minmax-ssse3-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=3 -D VARIANT=LD64 -o src/qs8-gemm/gen/4x4c2-minmax-ssse3-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c2-minmax-sse41-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=4 -D VARIANT=LD64 -o src/qs8-gemm/gen/4x4c2-minmax-sse41-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c2-minmax-xop-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=5 -D VARIANT=LD64 -o src/qs8-gemm/gen/4x4c2-minmax-xop-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c2-minmax-sse2-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/4x4c2-minmax-sse2-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c2-minmax-ssse3-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/4x4c2-minmax-ssse3-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c2-minmax-sse41-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=4 -D VARIANT=LD128 -o src/qs8-gemm/gen/4x4c2-minmax-sse41-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c2-minmax-xop-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=5 -D VARIANT=LD128 -o src/qs8-gemm/gen/4x4c2-minmax-xop-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c2-xw-minmax-sse2.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/4x4c2-xw-minmax-sse2.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c2-xw-minmax-ssse3.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/4x4c2-xw-minmax-ssse3.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c2-xw-minmax-sse41.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=4 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/4x4c2-xw-minmax-sse41.c |
| |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c2-xw-minmax-xop.c |
| tools/xngen src/qs8-gemm/MRx4c2-minmax-sse.c.in -D MR=4 -D SSE=5 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/4x4c2-xw-minmax-xop.c |
| |
| ### C8 micro-kernels |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c8-minmax-sse2-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=2 -D VARIANT=LD64 -o src/qs8-gemm/gen/2x4c8-minmax-sse2-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=2 -D VARIANT=LD64 -o src/qs8-gemm/gen/3x4c8-minmax-sse2-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c8-minmax-ssse3-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=3 -D VARIANT=LD64 -o src/qs8-gemm/gen/2x4c8-minmax-ssse3-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=3 -D VARIANT=LD64 -o src/qs8-gemm/gen/3x4c8-minmax-ssse3-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c8-minmax-sse41-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=4 -D VARIANT=LD64 -o src/qs8-gemm/gen/2x4c8-minmax-sse41-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=4 -D VARIANT=LD64 -o src/qs8-gemm/gen/3x4c8-minmax-sse41-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=LD64 -o src/qs8-gemm/gen/1x4c8-minmax-xop-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=5 -D VARIANT=LD64 -o src/qs8-gemm/gen/2x4c8-minmax-xop-ld64.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=5 -D VARIANT=LD64 -o src/qs8-gemm/gen/3x4c8-minmax-xop-ld64.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c8-minmax-sse2-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/2x4c8-minmax-sse2-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/3x4c8-minmax-sse2-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c8-minmax-ssse3-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/2x4c8-minmax-ssse3-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/3x4c8-minmax-ssse3-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c8-minmax-sse41-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=4 -D VARIANT=LD128 -o src/qs8-gemm/gen/2x4c8-minmax-sse41-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=4 -D VARIANT=LD128 -o src/qs8-gemm/gen/3x4c8-minmax-sse41-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x4c8-minmax-xop-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=5 -D VARIANT=LD128 -o src/qs8-gemm/gen/2x4c8-minmax-xop-ld128.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=5 -D VARIANT=LD128 -o src/qs8-gemm/gen/3x4c8-minmax-xop-ld128.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c8-xw-minmax-sse2.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/2x4c8-xw-minmax-sse2.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/3x4c8-xw-minmax-sse2.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c8-xw-minmax-ssse3.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/2x4c8-xw-minmax-ssse3.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/3x4c8-xw-minmax-ssse3.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=4 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c8-xw-minmax-sse41.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=4 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/2x4c8-xw-minmax-sse41.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=4 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/3x4c8-xw-minmax-sse41.c |
| |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=1 -D SSE=5 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x4c8-xw-minmax-xop.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=2 -D SSE=5 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/2x4c8-xw-minmax-xop.c |
| tools/xngen src/qs8-gemm/MRx4c8-minmax-sse.c.in -D MR=3 -D SSE=5 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/3x4c8-xw-minmax-xop.c |
| |
| ################################### x86 AVX2 ################################## |
| ### C8 micro-kernels |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=1 -D VARIANT=LD128 -o src/qs8-gemm/gen/1x8c8-minmax-avx2.c |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=2 -D VARIANT=LD128 -o src/qs8-gemm/gen/2x8c8-minmax-avx2.c |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=3 -D VARIANT=LD128 -o src/qs8-gemm/gen/3x8c8-minmax-avx2.c |
| |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=1 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/1x8c8-xw-minmax-avx2.c |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=2 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/2x8c8-xw-minmax-avx2.c |
| tools/xngen src/qs8-gemm/MRx8c8-minmax-avx2.c.in -D MR=3 -D VARIANT=EXTENDED -o src/qs8-gemm/gen/3x8c8-xw-minmax-avx2.c |
| |
| ################################## Unit tests ################################# |
| tools/generate-gemm-test.py --spec test/qs8-gemm-minmax.yaml --output test/qs8-gemm-minmax.cc |