17ec681f3Smrg# Copyright (C) 2020-2021 Collabora 27ec681f3Smrg# Copyright (C) 2018 Rob Clark 37ec681f3Smrg 47ec681f3Smrg# Permission is hereby granted, free of charge, to any person obtaining a copy 57ec681f3Smrg# of this software and associated documentation files (the "Software"), to deal 67ec681f3Smrg# in the Software without restriction, including without limitation the rights 77ec681f3Smrg# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 87ec681f3Smrg# copies of the Software, and to permit persons to whom the Software is 97ec681f3Smrg# furnished to do so, subject to the following conditions: 107ec681f3Smrg 117ec681f3Smrg# The above copyright notice and this permission notice shall be included in 127ec681f3Smrg# all copies or substantial portions of the Software. 137ec681f3Smrg 147ec681f3Smrg# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 157ec681f3Smrg# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 167ec681f3Smrg# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 177ec681f3Smrg# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 187ec681f3Smrg# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 197ec681f3Smrg# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 207ec681f3Smrg# SOFTWARE. 217ec681f3Smrg 227ec681f3Smrgvalhall_disasm_c = custom_target( 237ec681f3Smrg 'valhall_disasm_c', 247ec681f3Smrg input : ['disasm.py', 'ISA.xml'], 257ec681f3Smrg output : 'valhall_disasm.c', 267ec681f3Smrg command : [prog_python, '@INPUT@'], 277ec681f3Smrg capture : true, 287ec681f3Smrg depend_files : files('valhall.py'), 297ec681f3Smrg) 307ec681f3Smrg 317ec681f3Smrglibpanfrost_valhall_disasm = static_library( 327ec681f3Smrg 'panfrost_valhall_disasm', 337ec681f3Smrg valhall_disasm_c, 347ec681f3Smrg include_directories : [inc_include, inc_src, inc_mesa], 357ec681f3Smrg c_args : [no_override_init_args], 367ec681f3Smrg gnu_symbol_visibility : 'hidden', 377ec681f3Smrg build_by_default : false, 387ec681f3Smrg) 397ec681f3Smrg 407ec681f3Smrgif with_tests 417ec681f3Smrg test( 427ec681f3Smrg 'valhall_disasm', 437ec681f3Smrg executable( 447ec681f3Smrg 'valhall_disasm_test', 457ec681f3Smrg files('test/test-disassembler.c'), 467ec681f3Smrg c_args : [c_msvc_compat_args, no_override_init_args], 477ec681f3Smrg gnu_symbol_visibility : 'hidden', 487ec681f3Smrg include_directories : [inc_include, inc_src, inc_mesa], 497ec681f3Smrg link_with : [libpanfrost_valhall_disasm], 507ec681f3Smrg ), 517ec681f3Smrg suite : ['panfrost'], 527ec681f3Smrg args : files('test/assembler-cases.txt'), 537ec681f3Smrg ) 547ec681f3Smrg 557ec681f3Smrg test( 567ec681f3Smrg 'valhall_asm', 577ec681f3Smrg prog_python, 587ec681f3Smrg args : files('test-assembly.py', 'test/assembler-cases.txt', 'test/negative-cases.txt'), 597ec681f3Smrg suite : ['panfrost'], 607ec681f3Smrg ) 617ec681f3Smrgendif 62