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