blob: 398612f8d054c4c9f32c1ea67efa85bad47b7973 [file] [log] [blame]
Marat Dukhan918a4a62019-10-27 19:49:49 -07001#!/usr/bin/env python
2# Copyright 2019 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
8def _indent(text):
9 return "\n".join(map(lambda t: " " + t if t else t, text.splitlines()))
10
11
12def _remove_duplicate_newlines(text):
13 filtered_lines = list()
14 last_newline = False
15 for line in text.splitlines():
16 is_newline = len(line.strip()) == 0
17 if not is_newline or not last_newline:
18 filtered_lines.append(line)
19 last_newline = is_newline
20 return "\n".join(filtered_lines)
21
22
23_ARCH_TO_MACRO_MAP = {
24 "aarch32": "XNN_ARCH_ARM",
25 "aarch64": "XNN_ARCH_ARM64",
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070026 "x86-32": "XNN_ARCH_X86",
Marat Dukhan918a4a62019-10-27 19:49:49 -070027 "x86-64": "XNN_ARCH_X86_64",
Marat Dukhan436ebe62019-12-04 15:10:12 -080028 "wasm": "XNN_ARCH_WASM",
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070029 "wasmsimd": "XNN_ARCH_WASMSIMD",
Marat Dukhan918a4a62019-10-27 19:49:49 -070030}
31
32_ISA_TO_ARCH_MAP = {
33 "neon": ["aarch32", "aarch64"],
34 "neonfma": ["aarch32", "aarch64"],
Marat Dukhaneecf8fd2020-06-09 08:59:37 -070035 "neonv8": ["aarch32", "aarch64"],
Marat Dukhan918a4a62019-10-27 19:49:49 -070036 "neonfp16arith": ["aarch32", "aarch64"],
Benoit Jacoba9644732020-08-13 12:48:55 -070037 "neondot": ["aarch32", "aarch64"],
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070038 "sse": ["x86-32", "x86-64"],
39 "sse2": ["x86-32", "x86-64"],
Marat Dukhan595e1702020-07-31 10:12:52 -070040 "ssse3": ["x86-32", "x86-64"],
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070041 "sse41": ["x86-32", "x86-64"],
42 "avx": ["x86-32", "x86-64"],
Marat Dukhan1566fee2020-08-02 21:55:41 -070043 "xop": ["x86-32", "x86-64"],
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070044 "fma3": ["x86-32", "x86-64"],
45 "avx2": ["x86-32", "x86-64"],
46 "avx512f": ["x86-32", "x86-64"],
Marat Dukhanbb00b1d2020-08-10 11:37:23 -070047 "avx512skx": ["x86-32", "x86-64"],
Frank Barcharda635a292020-08-31 09:36:05 -070048 "wasm32": ["wasm", "wasmsimd"],
49 "wasm": ["wasm", "wasmsimd"],
Marat Dukhan1bbf96b2020-06-15 23:01:20 -070050 "wasmsimd": ["wasmsimd"],
Marat Dukhan918a4a62019-10-27 19:49:49 -070051}
52
53_ISA_TO_CHECK_MAP = {
54 "neon": "TEST_REQUIRES_ARM_NEON",
55 "neonfma": "TEST_REQUIRES_ARM_NEON_FMA",
Marat Dukhaneecf8fd2020-06-09 08:59:37 -070056 "neonv8": "TEST_REQUIRES_ARM_NEON_V8",
Marat Dukhan918a4a62019-10-27 19:49:49 -070057 "neonfp16arith": "TEST_REQUIRES_ARM_NEON_FP16_ARITH",
Benoit Jacoba9644732020-08-13 12:48:55 -070058 "neondot": "TEST_REQUIRES_ARM_NEON_DOT",
Marat Dukhan918a4a62019-10-27 19:49:49 -070059 "sse": "TEST_REQUIRES_X86_SSE",
60 "sse2": "TEST_REQUIRES_X86_SSE2",
Marat Dukhan595e1702020-07-31 10:12:52 -070061 "ssse3": "TEST_REQUIRES_X86_SSSE3",
Marat Dukhan69c3f2c2019-11-06 12:30:01 -080062 "sse41": "TEST_REQUIRES_X86_SSE41",
Marat Dukhan918a4a62019-10-27 19:49:49 -070063 "avx": "TEST_REQUIRES_X86_AVX",
Marat Dukhan1566fee2020-08-02 21:55:41 -070064 "xop": "TEST_REQUIRES_X86_XOP",
Marat Dukhan918a4a62019-10-27 19:49:49 -070065 "avx2": "TEST_REQUIRES_X86_AVX2",
Marat Dukhanfda12b82019-11-21 12:27:59 -080066 "fma3": "TEST_REQUIRES_X86_FMA3",
Marat Dukhan918a4a62019-10-27 19:49:49 -070067 "avx512f": "TEST_REQUIRES_X86_AVX512F",
Marat Dukhanbb00b1d2020-08-10 11:37:23 -070068 "avx512skx": "TEST_REQUIRES_X86_AVX512SKX",
Marat Dukhan918a4a62019-10-27 19:49:49 -070069}
70
71
72def parse_target_name(target_name):
73 arch = list()
74 isa = None
75 for target_part in target_name.split("_"):
76 if target_part in _ARCH_TO_MACRO_MAP:
Marat Dukhanfb5b20a2020-06-26 13:14:50 -070077 if target_part in _ISA_TO_ARCH_MAP:
78 arch = _ISA_TO_ARCH_MAP[target_part]
Marat Dukhan47387d62020-06-29 12:53:20 -070079 isa = target_part
Marat Dukhanfb5b20a2020-06-26 13:14:50 -070080 else:
81 arch = [target_part]
Marat Dukhan918a4a62019-10-27 19:49:49 -070082 elif target_part in _ISA_TO_ARCH_MAP:
83 isa = target_part
84 if isa and not arch:
85 arch = _ISA_TO_ARCH_MAP[isa]
86
87 return arch, isa
88
89
90def generate_isa_check_macro(isa):
91 return _ISA_TO_CHECK_MAP.get(isa, "")
92
93
94def postprocess_test_case(test_case, arch, isa, assembly=False):
95 test_case = _remove_duplicate_newlines(test_case)
96 if arch:
97 guard = " || ".join(map(_ARCH_TO_MACRO_MAP.get, arch))
98 if assembly:
99 guard += " && XNN_ENABLE_ASSEMBLY"
Marat Dukhan3de5dfa2020-12-10 11:19:47 -0800100 return "#if %s\n" % guard + _indent(test_case) + "\n" + \
Marat Dukhan918a4a62019-10-27 19:49:49 -0700101 "#endif // %s\n" % guard
102 else:
103 return test_case