xref: /aosp_15_r20/external/mesa3d/src/freedreno/ir3/meson.build (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker# Copyright © 2018 Rob Clark
2*61046927SAndroid Build Coastguard Worker# SPDX-License-Identifier: MIT
3*61046927SAndroid Build Coastguard Worker
4*61046927SAndroid Build Coastguard Workerir3_nir_trig_c = custom_target(
5*61046927SAndroid Build Coastguard Worker  'ir3_nir_trig.c',
6*61046927SAndroid Build Coastguard Worker  input : 'ir3_nir_trig.py',
7*61046927SAndroid Build Coastguard Worker  output : 'ir3_nir_trig.c',
8*61046927SAndroid Build Coastguard Worker  command : [
9*61046927SAndroid Build Coastguard Worker    prog_python, '@INPUT@', '-p', dir_compiler_nir,
10*61046927SAndroid Build Coastguard Worker  ],
11*61046927SAndroid Build Coastguard Worker  capture : true,
12*61046927SAndroid Build Coastguard Worker  depend_files : nir_algebraic_depends,
13*61046927SAndroid Build Coastguard Worker)
14*61046927SAndroid Build Coastguard Worker
15*61046927SAndroid Build Coastguard Workerir3_nir_imul_c = custom_target(
16*61046927SAndroid Build Coastguard Worker  'ir3_nir_imul.c',
17*61046927SAndroid Build Coastguard Worker  input : 'ir3_nir_imul.py',
18*61046927SAndroid Build Coastguard Worker  output : 'ir3_nir_imul.c',
19*61046927SAndroid Build Coastguard Worker  command : [
20*61046927SAndroid Build Coastguard Worker    prog_python, '@INPUT@', '-p', dir_compiler_nir,
21*61046927SAndroid Build Coastguard Worker  ],
22*61046927SAndroid Build Coastguard Worker  capture : true,
23*61046927SAndroid Build Coastguard Worker  depend_files : nir_algebraic_depends,
24*61046927SAndroid Build Coastguard Worker)
25*61046927SAndroid Build Coastguard Worker
26*61046927SAndroid Build Coastguard Workerir3_nir_branch_and_or_not_c = custom_target(
27*61046927SAndroid Build Coastguard Worker  'ir3_nir_branch_and_or_not.c',
28*61046927SAndroid Build Coastguard Worker  input : 'ir3_nir_branch_and_or_not.py',
29*61046927SAndroid Build Coastguard Worker  output : 'ir3_nir_branch_and_or_not.c',
30*61046927SAndroid Build Coastguard Worker  command : [
31*61046927SAndroid Build Coastguard Worker    prog_python, '@INPUT@', '-p', dir_compiler_nir,
32*61046927SAndroid Build Coastguard Worker  ],
33*61046927SAndroid Build Coastguard Worker  capture : true,
34*61046927SAndroid Build Coastguard Worker  depend_files : nir_algebraic_depends,
35*61046927SAndroid Build Coastguard Worker)
36*61046927SAndroid Build Coastguard Worker
37*61046927SAndroid Build Coastguard Workerir3_parser = custom_target(
38*61046927SAndroid Build Coastguard Worker  'ir3_parser.[ch]',
39*61046927SAndroid Build Coastguard Worker  input: 'ir3_parser.y',
40*61046927SAndroid Build Coastguard Worker  output: ['ir3_parser.c', 'ir3_parser.h'],
41*61046927SAndroid Build Coastguard Worker  command: [
42*61046927SAndroid Build Coastguard Worker    prog_bison, '@INPUT@', '--name-prefix=ir3_yy', '--defines=@OUTPUT1@', '--output=@OUTPUT0@'
43*61046927SAndroid Build Coastguard Worker  ]
44*61046927SAndroid Build Coastguard Worker)
45*61046927SAndroid Build Coastguard Worker
46*61046927SAndroid Build Coastguard Workerir3_lexer = custom_target(
47*61046927SAndroid Build Coastguard Worker  'ir3_lexer.c',
48*61046927SAndroid Build Coastguard Worker  input: 'ir3_lexer.l',
49*61046927SAndroid Build Coastguard Worker  output: 'ir3_lexer.c',
50*61046927SAndroid Build Coastguard Worker  command: [
51*61046927SAndroid Build Coastguard Worker    prog_flex, '-o', '@OUTPUT@', '@INPUT@'
52*61046927SAndroid Build Coastguard Worker  ]
53*61046927SAndroid Build Coastguard Worker)
54*61046927SAndroid Build Coastguard Worker
55*61046927SAndroid Build Coastguard Workerlibfreedreno_ir3_files = files(
56*61046927SAndroid Build Coastguard Worker  'disasm-a3xx.c',
57*61046927SAndroid Build Coastguard Worker  'instr-a3xx.h',
58*61046927SAndroid Build Coastguard Worker  'ir3.c',
59*61046927SAndroid Build Coastguard Worker  'ir3_a4xx.c',
60*61046927SAndroid Build Coastguard Worker  'ir3_a6xx.c',
61*61046927SAndroid Build Coastguard Worker  'ir3_array_to_ssa.c',
62*61046927SAndroid Build Coastguard Worker  'ir3_assembler.c',
63*61046927SAndroid Build Coastguard Worker  'ir3_assembler.h',
64*61046927SAndroid Build Coastguard Worker  'ir3_compiler_nir.c',
65*61046927SAndroid Build Coastguard Worker  'ir3_compiler.c',
66*61046927SAndroid Build Coastguard Worker  'ir3_compiler.h',
67*61046927SAndroid Build Coastguard Worker  'ir3_context.c',
68*61046927SAndroid Build Coastguard Worker  'ir3_context.h',
69*61046927SAndroid Build Coastguard Worker  'ir3_cf.c',
70*61046927SAndroid Build Coastguard Worker  'ir3_cp.c',
71*61046927SAndroid Build Coastguard Worker  'ir3_cse.c',
72*61046927SAndroid Build Coastguard Worker  'ir3_dce.c',
73*61046927SAndroid Build Coastguard Worker  'ir3_delay.c',
74*61046927SAndroid Build Coastguard Worker  'ir3_dominance.c',
75*61046927SAndroid Build Coastguard Worker  'ir3_disk_cache.c',
76*61046927SAndroid Build Coastguard Worker  'ir3_image.c',
77*61046927SAndroid Build Coastguard Worker  'ir3_image.h',
78*61046927SAndroid Build Coastguard Worker  'ir3.h',
79*61046927SAndroid Build Coastguard Worker  'ir3_legalize.c',
80*61046927SAndroid Build Coastguard Worker  'ir3_legalize_relative.c',
81*61046927SAndroid Build Coastguard Worker  'ir3_liveness.c',
82*61046927SAndroid Build Coastguard Worker  'ir3_lower_parallelcopy.c',
83*61046927SAndroid Build Coastguard Worker  'ir3_lower_shared_phi.c',
84*61046927SAndroid Build Coastguard Worker  'ir3_lower_spill.c',
85*61046927SAndroid Build Coastguard Worker  'ir3_lower_subgroups.c',
86*61046927SAndroid Build Coastguard Worker  'ir3_merge_regs.c',
87*61046927SAndroid Build Coastguard Worker  'ir3_nir.c',
88*61046927SAndroid Build Coastguard Worker  'ir3_nir.h',
89*61046927SAndroid Build Coastguard Worker  'ir3_nir_analyze_ubo_ranges.c',
90*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_64b.c',
91*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_driver_params_to_ubo.c',
92*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_load_barycentric_at_sample.c',
93*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_load_barycentric_at_offset.c',
94*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_push_consts_to_preamble.c',
95*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_io_offsets.c',
96*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_tess.c',
97*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_tex_prefetch.c',
98*61046927SAndroid Build Coastguard Worker  'ir3_nir_move_varying_inputs.c',
99*61046927SAndroid Build Coastguard Worker  'ir3_nir_lower_layer_id.c',
100*61046927SAndroid Build Coastguard Worker  'ir3_nir_opt_preamble.c',
101*61046927SAndroid Build Coastguard Worker  'ir3_opt_predicates.c',
102*61046927SAndroid Build Coastguard Worker  'ir3_postsched.c',
103*61046927SAndroid Build Coastguard Worker  'ir3_print.c',
104*61046927SAndroid Build Coastguard Worker  'ir3_ra.c',
105*61046927SAndroid Build Coastguard Worker  'ir3_ra.h',
106*61046927SAndroid Build Coastguard Worker  'ir3_ra_predicates.c',
107*61046927SAndroid Build Coastguard Worker  'ir3_ra_validate.c',
108*61046927SAndroid Build Coastguard Worker  'ir3_reconvergence.c',
109*61046927SAndroid Build Coastguard Worker  'ir3_remove_unreachable.c',
110*61046927SAndroid Build Coastguard Worker  'ir3_rpt.c',
111*61046927SAndroid Build Coastguard Worker  'ir3_sched.c',
112*61046927SAndroid Build Coastguard Worker  'ir3_shader.c',
113*61046927SAndroid Build Coastguard Worker  'ir3_shader.h',
114*61046927SAndroid Build Coastguard Worker  'ir3_shared_folding.c',
115*61046927SAndroid Build Coastguard Worker  'ir3_shared_ra.c',
116*61046927SAndroid Build Coastguard Worker  'ir3_spill.c',
117*61046927SAndroid Build Coastguard Worker  'ir3_validate.c',
118*61046927SAndroid Build Coastguard Worker)
119*61046927SAndroid Build Coastguard Worker
120*61046927SAndroid Build Coastguard Workerlibfreedreno_ir3 = static_library(
121*61046927SAndroid Build Coastguard Worker  'freedreno_ir3',
122*61046927SAndroid Build Coastguard Worker  [libfreedreno_ir3_files, ir3_nir_trig_c, ir3_nir_imul_c, ir3_nir_branch_and_or_not_c, ir3_parser[0], ir3_parser[1], ir3_lexer],
123*61046927SAndroid Build Coastguard Worker  include_directories : [inc_freedreno, inc_include, inc_src],
124*61046927SAndroid Build Coastguard Worker  c_args : [no_override_init_args],
125*61046927SAndroid Build Coastguard Worker  gnu_symbol_visibility : 'hidden',
126*61046927SAndroid Build Coastguard Worker  link_with: [libir3encode, libfreedreno_common],
127*61046927SAndroid Build Coastguard Worker  dependencies : [idep_libir3decode, idep_nir_headers, dep_dl, idep_mesautil],
128*61046927SAndroid Build Coastguard Worker  build_by_default : false,
129*61046927SAndroid Build Coastguard Worker)
130*61046927SAndroid Build Coastguard Worker
131*61046927SAndroid Build Coastguard Workertest('ir3_disasm',
132*61046927SAndroid Build Coastguard Worker  executable(
133*61046927SAndroid Build Coastguard Worker    'ir3_disasm',
134*61046927SAndroid Build Coastguard Worker    'tests/disasm.c',
135*61046927SAndroid Build Coastguard Worker    link_args : [ld_args_build_id],
136*61046927SAndroid Build Coastguard Worker    link_with: [libfreedreno_ir3],
137*61046927SAndroid Build Coastguard Worker    dependencies: [idep_libir3decode, idep_mesautil, idep_nir],
138*61046927SAndroid Build Coastguard Worker    include_directories: [inc_freedreno, inc_include, inc_src],
139*61046927SAndroid Build Coastguard Worker  ),
140*61046927SAndroid Build Coastguard Worker  suite: ['freedreno'],
141*61046927SAndroid Build Coastguard Worker)
142*61046927SAndroid Build Coastguard Worker
143*61046927SAndroid Build Coastguard Workertest('ir3_delay_test',
144*61046927SAndroid Build Coastguard Worker  executable(
145*61046927SAndroid Build Coastguard Worker    'ir3_delay_test',
146*61046927SAndroid Build Coastguard Worker    'tests/delay.c',
147*61046927SAndroid Build Coastguard Worker    link_with: libfreedreno_ir3,
148*61046927SAndroid Build Coastguard Worker    link_args: ld_args_build_id,
149*61046927SAndroid Build Coastguard Worker    dependencies: [idep_mesautil, idep_nir],
150*61046927SAndroid Build Coastguard Worker    include_directories: [inc_freedreno, inc_include, inc_src],
151*61046927SAndroid Build Coastguard Worker  ),
152*61046927SAndroid Build Coastguard Worker  suite: ['freedreno'],
153*61046927SAndroid Build Coastguard Worker)
154