1bf215546Sopenharmony_ci# Copyright (C) 2020-2021 Collabora 2bf215546Sopenharmony_ci# Copyright (C) 2018 Rob Clark 3bf215546Sopenharmony_ci 4bf215546Sopenharmony_ci# Permission is hereby granted, free of charge, to any person obtaining a copy 5bf215546Sopenharmony_ci# of this software and associated documentation files (the "Software"), to deal 6bf215546Sopenharmony_ci# in the Software without restriction, including without limitation the rights 7bf215546Sopenharmony_ci# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8bf215546Sopenharmony_ci# copies of the Software, and to permit persons to whom the Software is 9bf215546Sopenharmony_ci# furnished to do so, subject to the following conditions: 10bf215546Sopenharmony_ci 11bf215546Sopenharmony_ci# The above copyright notice and this permission notice shall be included in 12bf215546Sopenharmony_ci# all copies or substantial portions of the Software. 13bf215546Sopenharmony_ci 14bf215546Sopenharmony_ci# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15bf215546Sopenharmony_ci# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16bf215546Sopenharmony_ci# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17bf215546Sopenharmony_ci# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18bf215546Sopenharmony_ci# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19bf215546Sopenharmony_ci# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 20bf215546Sopenharmony_ci# SOFTWARE. 21bf215546Sopenharmony_ci 22bf215546Sopenharmony_civalhall_c = custom_target( 23bf215546Sopenharmony_ci 'valhall_c', 24bf215546Sopenharmony_ci input : ['valhall.c.py', 'ISA.xml'], 25bf215546Sopenharmony_ci output : 'valhall.c', 26bf215546Sopenharmony_ci command : [prog_python, '@INPUT@'], 27bf215546Sopenharmony_ci capture : true, 28bf215546Sopenharmony_ci depend_files : files('valhall.py'), 29bf215546Sopenharmony_ci) 30bf215546Sopenharmony_ci 31bf215546Sopenharmony_civalhall_enums_h = custom_target( 32bf215546Sopenharmony_ci 'valhall_enums.h', 33bf215546Sopenharmony_ci input : ['valhall_enums.h.py', 'ISA.xml'], 34bf215546Sopenharmony_ci output : 'valhall_enums.h', 35bf215546Sopenharmony_ci command : [prog_python, '@INPUT@'], 36bf215546Sopenharmony_ci capture : true, 37bf215546Sopenharmony_ci depend_files : files('valhall.py'), 38bf215546Sopenharmony_ci) 39bf215546Sopenharmony_ci 40bf215546Sopenharmony_ciidep_valhall_enums_h = declare_dependency( 41bf215546Sopenharmony_ci sources : [valhall_enums_h], 42bf215546Sopenharmony_ci include_directories : include_directories('.'), 43bf215546Sopenharmony_ci) 44bf215546Sopenharmony_ci 45bf215546Sopenharmony_civalhall_disasm_c = custom_target( 46bf215546Sopenharmony_ci 'valhall_disasm_c', 47bf215546Sopenharmony_ci input : ['disasm.py', 'ISA.xml'], 48bf215546Sopenharmony_ci output : 'valhall_disasm.c', 49bf215546Sopenharmony_ci command : [prog_python, '@INPUT@'], 50bf215546Sopenharmony_ci capture : true, 51bf215546Sopenharmony_ci depend_files : files('valhall.py'), 52bf215546Sopenharmony_ci) 53bf215546Sopenharmony_ci 54bf215546Sopenharmony_cilibpanfrost_valhall_disasm = static_library( 55bf215546Sopenharmony_ci 'panfrost_valhall_disasm', 56bf215546Sopenharmony_ci valhall_disasm_c, 57bf215546Sopenharmony_ci include_directories : [inc_include, inc_src, inc_mesa], 58bf215546Sopenharmony_ci c_args : [no_override_init_args], 59bf215546Sopenharmony_ci gnu_symbol_visibility : 'hidden', 60bf215546Sopenharmony_ci build_by_default : false, 61bf215546Sopenharmony_ci) 62bf215546Sopenharmony_ci 63bf215546Sopenharmony_ciif with_tests 64bf215546Sopenharmony_ci test( 65bf215546Sopenharmony_ci 'valhall_disasm', 66bf215546Sopenharmony_ci executable( 67bf215546Sopenharmony_ci 'valhall_disasm_test', 68bf215546Sopenharmony_ci files('test/test-disassembler.c'), 69bf215546Sopenharmony_ci c_args : [c_msvc_compat_args, no_override_init_args], 70bf215546Sopenharmony_ci gnu_symbol_visibility : 'hidden', 71bf215546Sopenharmony_ci include_directories : [inc_include, inc_src, inc_mesa], 72bf215546Sopenharmony_ci link_with : [libpanfrost_valhall_disasm], 73bf215546Sopenharmony_ci ), 74bf215546Sopenharmony_ci suite : ['panfrost'], 75bf215546Sopenharmony_ci args : files('test/assembler-cases.txt'), 76bf215546Sopenharmony_ci ) 77bf215546Sopenharmony_ci 78bf215546Sopenharmony_ci test( 79bf215546Sopenharmony_ci 'valhall_asm', 80bf215546Sopenharmony_ci prog_python, 81bf215546Sopenharmony_ci args : files('test-assembly.py', 'test/assembler-cases.txt', 'test/negative-cases.txt'), 82bf215546Sopenharmony_ci suite : ['panfrost'], 83bf215546Sopenharmony_ci ) 84bf215546Sopenharmony_ciendif 85