2019-07-10 18:33:24 +01:00
|
|
|
# Copyright © 2018 Rob Clark
|
|
|
|
# Copyright © 2019 Collabora
|
|
|
|
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
|
|
# in the Software without restriction, including without limitation the rights
|
|
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
# The above copyright notice and this permission notice shall be included in
|
|
|
|
# all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
# SOFTWARE.
|
|
|
|
|
|
|
|
libpanfrost_bifrost_files = files(
|
2020-05-05 22:58:16 +01:00
|
|
|
'bi_layout.c',
|
2020-03-11 18:54:49 +00:00
|
|
|
'bi_liveness.c',
|
2020-03-03 20:39:04 +00:00
|
|
|
'bi_print.c',
|
2021-02-10 16:47:24 +00:00
|
|
|
'bi_opt_copy_prop.c',
|
2020-03-11 19:10:32 +00:00
|
|
|
'bi_opt_dce.c',
|
2020-03-12 18:16:22 +00:00
|
|
|
'bi_pack.c',
|
2020-03-12 00:39:36 +00:00
|
|
|
'bi_ra.c',
|
2020-03-07 00:25:00 +00:00
|
|
|
'bi_schedule.c',
|
2021-01-06 18:31:34 +00:00
|
|
|
'bi_test_pack.c',
|
2020-03-04 14:19:06 +00:00
|
|
|
'bir.c',
|
2020-03-03 00:47:11 +00:00
|
|
|
'bifrost_compile.c',
|
2019-07-10 18:33:24 +01:00
|
|
|
)
|
|
|
|
|
2020-03-10 12:20:59 +00:00
|
|
|
bifrost_nir_algebraic_c = custom_target(
|
|
|
|
'bifrost_nir_algebraic.c',
|
|
|
|
input : 'bifrost_nir_algebraic.py',
|
|
|
|
output : 'bifrost_nir_algebraic.c',
|
|
|
|
command : [
|
|
|
|
prog_python, '@INPUT@',
|
|
|
|
'-p', join_paths(meson.source_root(), 'src/compiler/nir/'),
|
|
|
|
],
|
|
|
|
capture : true,
|
|
|
|
depend_files : nir_algebraic_py,
|
|
|
|
)
|
|
|
|
|
2020-09-14 18:21:33 +01:00
|
|
|
bifrost_gen_disasm_c = custom_target(
|
|
|
|
'bifrost_gen_disasm.c',
|
|
|
|
input : ['gen_disasm.py', 'ISA.xml'],
|
|
|
|
output : 'bifrost_gen_disasm.c',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
2020-12-08 00:58:22 +00:00
|
|
|
depend_files : files('bifrost_isa.py'),
|
2020-09-14 18:21:33 +01:00
|
|
|
)
|
|
|
|
|
2020-12-23 17:29:34 +00:00
|
|
|
bi_opcodes_c = custom_target(
|
|
|
|
'bi_opcodes.c',
|
|
|
|
input : ['bi_opcodes.c.py', 'ISA.xml'],
|
|
|
|
output : 'bi_opcodes.c',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
|
|
|
depend_files : files('bifrost_isa.py'),
|
|
|
|
)
|
|
|
|
|
2020-11-27 19:39:40 +00:00
|
|
|
bi_printer_c = custom_target(
|
|
|
|
'bi_printer.c',
|
|
|
|
input : ['bi_printer.c.py', 'ISA.xml'],
|
|
|
|
output : 'bi_printer.c',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
|
|
|
depend_files : files('bifrost_isa.py'),
|
|
|
|
)
|
|
|
|
|
2020-12-04 19:54:00 +00:00
|
|
|
bi_packer_c = custom_target(
|
|
|
|
'bi_packer.c',
|
|
|
|
input : ['bi_packer.c.py', 'ISA.xml'],
|
|
|
|
output : 'bi_packer.c',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
|
|
|
depend_files : files('bifrost_isa.py'),
|
|
|
|
)
|
|
|
|
|
2020-11-27 18:51:00 +00:00
|
|
|
bi_opcodes_h = custom_target(
|
|
|
|
'bi_opcodes.h',
|
|
|
|
input : ['bi_opcodes.h.py', 'ISA.xml'],
|
|
|
|
output : 'bi_opcodes.h',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
|
|
|
depend_files : files('bifrost_isa.py'),
|
|
|
|
)
|
|
|
|
|
|
|
|
idep_bi_opcodes_h = declare_dependency(
|
|
|
|
sources : [bi_opcodes_h],
|
|
|
|
include_directories : include_directories('.'),
|
|
|
|
)
|
|
|
|
|
2020-11-28 00:01:00 +00:00
|
|
|
bi_builder_h = custom_target(
|
|
|
|
'bi_builder.h',
|
|
|
|
input : ['bi_builder.h.py', 'ISA.xml'],
|
|
|
|
output : 'bi_builder.h',
|
|
|
|
command : [prog_python, '@INPUT@'],
|
|
|
|
capture : true,
|
|
|
|
depend_files : files('bifrost_isa.py'),
|
|
|
|
)
|
|
|
|
|
|
|
|
idep_bi_builder_h = declare_dependency(
|
|
|
|
sources : [bi_builder_h],
|
|
|
|
include_directories : include_directories('.'),
|
|
|
|
)
|
|
|
|
|
2020-08-05 22:25:27 +01:00
|
|
|
libpanfrost_bifrost_disasm = static_library(
|
|
|
|
'panfrost_bifrost_disasm',
|
2020-09-14 18:21:33 +01:00
|
|
|
['disassemble.c', 'bi_print_common.c', bifrost_gen_disasm_c],
|
2020-08-05 22:25:27 +01:00
|
|
|
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost_hw],
|
|
|
|
dependencies: [idep_nir],
|
|
|
|
link_with: [libpanfrost_util],
|
|
|
|
c_args : [no_override_init_args],
|
|
|
|
gnu_symbol_visibility : 'hidden',
|
|
|
|
build_by_default : false,
|
|
|
|
)
|
|
|
|
|
2019-07-10 18:33:24 +01:00
|
|
|
libpanfrost_bifrost = static_library(
|
|
|
|
'panfrost_bifrost',
|
2020-12-04 19:54:00 +00:00
|
|
|
[libpanfrost_bifrost_files, bifrost_nir_algebraic_c, bi_opcodes_c, bi_printer_c, bi_packer_c],
|
2019-03-05 16:21:47 +00:00
|
|
|
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost_hw],
|
2020-12-16 19:07:32 +00:00
|
|
|
dependencies: [idep_nir, idep_bi_opcodes_h, idep_bi_builder_h],
|
2020-08-05 22:25:27 +01:00
|
|
|
link_with: [libpanfrost_util, libpanfrost_bifrost_disasm],
|
2020-04-24 21:10:41 +01:00
|
|
|
c_args : [no_override_init_args],
|
|
|
|
gnu_symbol_visibility : 'hidden',
|
2019-07-10 18:33:24 +01:00
|
|
|
build_by_default : false,
|
|
|
|
)
|