depend_files : nir_algebraic_py,
)
+ir3_nir_imul_c = custom_target(
+ 'ir3_nir_imul.c',
+ input : 'ir3_nir_imul.py',
+ output : 'ir3_nir_imul.c',
+ command : [
+ prog_python, '@INPUT@',
+ '-p', join_paths(meson.source_root(), 'src/compiler/nir/'),
+ ],
+ capture : true,
+ depend_files : nir_algebraic_py,
+)
+
+ir3_parser = custom_target(
+ 'ir3_parser.[ch]',
+ input: 'ir3_parser.y',
+ output: ['ir3_parser.c', 'ir3_parser.h'],
+ command: [
+ prog_bison, '@INPUT@', '--name-prefix=ir3_yy', '--defines=@OUTPUT1@', '--output=@OUTPUT0@'
+ ]
+)
+
+ir3_lexer = custom_target(
+ 'ir3_lexer.c',
+ input: 'ir3_lexer.l',
+ output: 'ir3_lexer.c',
+ command: [
+ prog_flex, '-o', '@OUTPUT@', '@INPUT@'
+ ]
+)
+
libfreedreno_ir3_files = files(
'disasm-a3xx.c',
'instr-a3xx.h',
'ir3.c',
'ir3_a4xx.c',
+ 'ir3_a6xx.c',
+ 'ir3_assembler.c',
+ 'ir3_assembler.h',
'ir3_compiler_nir.c',
'ir3_compiler.c',
'ir3_compiler.h',
'ir3_context.c',
'ir3_context.h',
+ 'ir3_cf.c',
'ir3_cp.c',
- 'ir3_depth.c',
+ 'ir3_cp_postsched.c',
+ 'ir3_dce.c',
+ 'ir3_delay.c',
+ 'ir3_disk_cache.c',
'ir3_group.c',
'ir3_image.c',
'ir3_image.h',
'ir3_legalize.c',
'ir3_nir.c',
'ir3_nir.h',
+ 'ir3_nir_analyze_ubo_ranges.c',
+ 'ir3_nir_lower_load_barycentric_at_sample.c',
+ 'ir3_nir_lower_load_barycentric_at_offset.c',
+ 'ir3_nir_lower_io_offsets.c',
+ 'ir3_nir_lower_tess.c',
+ 'ir3_nir_lower_tex_prefetch.c',
'ir3_nir_lower_tg4_to_tex.c',
+ 'ir3_nir_move_varying_inputs.c',
+ 'ir3_postsched.c',
'ir3_print.c',
'ir3_ra.c',
+ 'ir3_ra.h',
+ 'ir3_ra_regset.c',
'ir3_sched.c',
'ir3_shader.c',
'ir3_shader.h',
+ 'ir3_validate.c',
)
libfreedreno_ir3 = static_library(
'freedreno_ir3',
- [libfreedreno_ir3_files, ir3_nir_trig_c],
- include_directories : [inc_freedreno, inc_common],
- c_args : [c_vis_args, no_override_init_args],
- cpp_args : [cpp_vis_args],
- dependencies : idep_nir_headers,
+ [libfreedreno_ir3_files, ir3_nir_trig_c, ir3_nir_imul_c, ir3_parser[0], ir3_parser[1], ir3_lexer],
+ include_directories : [inc_freedreno, inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux],
+ c_args : [no_override_init_args],
+ gnu_symbol_visibility : 'hidden',
+ dependencies : [idep_nir_headers, dep_dl],
build_by_default : false,
)
+test('ir3_disasm',
+ executable(
+ 'ir3_disasm',
+ 'tests/disasm.c',
+ link_with: libfreedreno_ir3,
+ dependencies: idep_mesautil,
+ include_directories: [inc_freedreno, inc_include, inc_src],
+ ),
+ suite: ['freedreno'],
+)
+
+test('ir3_delay_test',
+ executable(
+ 'ir3_delay_test',
+ 'tests/delay.c',
+ link_with: libfreedreno_ir3,
+ dependencies: [idep_mesautil, idep_nir],
+ include_directories: [inc_freedreno, inc_include, inc_src, inc_mesa, inc_gallium],
+ ),
+ suite: ['freedreno'],
+)