1*61046927SAndroid Build Coastguard Worker# Copyright © 2017 Broadcom 2*61046927SAndroid Build Coastguard Worker# SPDX-License-Identifier: MIT 3*61046927SAndroid Build Coastguard Worker 4*61046927SAndroid Build Coastguard Workerfiles_libvc4 = files( 5*61046927SAndroid Build Coastguard Worker 'kernel/vc4_drv.h', 6*61046927SAndroid Build Coastguard Worker 'kernel/vc4_gem.c', 7*61046927SAndroid Build Coastguard Worker 'kernel/vc4_packet.h', 8*61046927SAndroid Build Coastguard Worker 'kernel/vc4_render_cl.c', 9*61046927SAndroid Build Coastguard Worker 'kernel/vc4_validate.c', 10*61046927SAndroid Build Coastguard Worker 'kernel/vc4_validate_shaders.c', 11*61046927SAndroid Build Coastguard Worker 'vc4_blit.c', 12*61046927SAndroid Build Coastguard Worker 'vc4_bufmgr.c', 13*61046927SAndroid Build Coastguard Worker 'vc4_bufmgr.h', 14*61046927SAndroid Build Coastguard Worker 'vc4_cl.c', 15*61046927SAndroid Build Coastguard Worker 'vc4_cl_dump.c', 16*61046927SAndroid Build Coastguard Worker 'vc4_cl_dump.h', 17*61046927SAndroid Build Coastguard Worker 'vc4_cl.h', 18*61046927SAndroid Build Coastguard Worker 'vc4_context.c', 19*61046927SAndroid Build Coastguard Worker 'vc4_context.h', 20*61046927SAndroid Build Coastguard Worker 'vc4_draw.c', 21*61046927SAndroid Build Coastguard Worker 'vc4_emit.c', 22*61046927SAndroid Build Coastguard Worker 'vc4_fence.c', 23*61046927SAndroid Build Coastguard Worker 'vc4_formats.c', 24*61046927SAndroid Build Coastguard Worker 'vc4_job.c', 25*61046927SAndroid Build Coastguard Worker 'vc4_nir_lower_blend.c', 26*61046927SAndroid Build Coastguard Worker 'vc4_nir_lower_io.c', 27*61046927SAndroid Build Coastguard Worker 'vc4_nir_lower_txf_ms.c', 28*61046927SAndroid Build Coastguard Worker 'vc4_opt_algebraic.c', 29*61046927SAndroid Build Coastguard Worker 'vc4_opt_constant_folding.c', 30*61046927SAndroid Build Coastguard Worker 'vc4_opt_copy_propagation.c', 31*61046927SAndroid Build Coastguard Worker 'vc4_opt_dead_code.c', 32*61046927SAndroid Build Coastguard Worker 'vc4_opt_peephole_sf.c', 33*61046927SAndroid Build Coastguard Worker 'vc4_opt_small_immediates.c', 34*61046927SAndroid Build Coastguard Worker 'vc4_opt_vpm.c', 35*61046927SAndroid Build Coastguard Worker 'vc4_opt_coalesce_ff_writes.c', 36*61046927SAndroid Build Coastguard Worker 'vc4_program.c', 37*61046927SAndroid Build Coastguard Worker 'vc4_qir.c', 38*61046927SAndroid Build Coastguard Worker 'vc4_qir_emit_uniform_stream_resets.c', 39*61046927SAndroid Build Coastguard Worker 'vc4_qir_live_variables.c', 40*61046927SAndroid Build Coastguard Worker 'vc4_qir_lower_uniforms.c', 41*61046927SAndroid Build Coastguard Worker 'vc4_qir_schedule.c', 42*61046927SAndroid Build Coastguard Worker 'vc4_qir_validate.c', 43*61046927SAndroid Build Coastguard Worker 'vc4_qir.h', 44*61046927SAndroid Build Coastguard Worker 'vc4_qpu.c', 45*61046927SAndroid Build Coastguard Worker 'vc4_qpu_defines.h', 46*61046927SAndroid Build Coastguard Worker 'vc4_qpu_disasm.c', 47*61046927SAndroid Build Coastguard Worker 'vc4_qpu_emit.c', 48*61046927SAndroid Build Coastguard Worker 'vc4_qpu.h', 49*61046927SAndroid Build Coastguard Worker 'vc4_qpu_schedule.c', 50*61046927SAndroid Build Coastguard Worker 'vc4_qpu_validate.c', 51*61046927SAndroid Build Coastguard Worker 'vc4_query.c', 52*61046927SAndroid Build Coastguard Worker 'vc4_register_allocate.c', 53*61046927SAndroid Build Coastguard Worker 'vc4_reorder_uniforms.c', 54*61046927SAndroid Build Coastguard Worker 'vc4_resource.c', 55*61046927SAndroid Build Coastguard Worker 'vc4_resource.h', 56*61046927SAndroid Build Coastguard Worker 'vc4_screen.c', 57*61046927SAndroid Build Coastguard Worker 'vc4_screen.h', 58*61046927SAndroid Build Coastguard Worker 'vc4_simulator.c', 59*61046927SAndroid Build Coastguard Worker 'vc4_simulator_validate.h', 60*61046927SAndroid Build Coastguard Worker 'vc4_state.c', 61*61046927SAndroid Build Coastguard Worker 'vc4_tiling.c', 62*61046927SAndroid Build Coastguard Worker 'vc4_tiling_lt.c', 63*61046927SAndroid Build Coastguard Worker 'vc4_tiling.h', 64*61046927SAndroid Build Coastguard Worker 'vc4_uniforms.c', 65*61046927SAndroid Build Coastguard Worker) 66*61046927SAndroid Build Coastguard Worker 67*61046927SAndroid Build Coastguard Workervc4_c_args = [] 68*61046927SAndroid Build Coastguard Worker 69*61046927SAndroid Build Coastguard Workervc4_deps = [ 70*61046927SAndroid Build Coastguard Worker dep_simpenrose, dep_libdrm, dep_valgrind, 71*61046927SAndroid Build Coastguard Worker idep_nir_headers, idep_mesautil, 72*61046927SAndroid Build Coastguard Worker] 73*61046927SAndroid Build Coastguard Worker 74*61046927SAndroid Build Coastguard Workerlibvc4_neon = [] 75*61046927SAndroid Build Coastguard Workerif host_machine.cpu_family() == 'arm' 76*61046927SAndroid Build Coastguard Worker libvc4_neon = static_library( 77*61046927SAndroid Build Coastguard Worker 'vc4_neon', 78*61046927SAndroid Build Coastguard Worker 'vc4_tiling_lt.c', 79*61046927SAndroid Build Coastguard Worker include_directories : [ 80*61046927SAndroid Build Coastguard Worker inc_src, inc_include, inc_gallium, inc_gallium_aux, inc_broadcom 81*61046927SAndroid Build Coastguard Worker ], 82*61046927SAndroid Build Coastguard Worker c_args : ['-mfpu=neon', '-DV3D_BUILD_NEON'], 83*61046927SAndroid Build Coastguard Worker dependencies : vc4_deps, 84*61046927SAndroid Build Coastguard Worker ) 85*61046927SAndroid Build Coastguard Worker vc4_c_args += '-DUSE_ARM_ASM' 86*61046927SAndroid Build Coastguard Workerendif 87*61046927SAndroid Build Coastguard Worker 88*61046927SAndroid Build Coastguard Workerif dep_simpenrose.found() 89*61046927SAndroid Build Coastguard Worker vc4_c_args += '-DUSE_VC4_SIMULATOR' 90*61046927SAndroid Build Coastguard Workerendif 91*61046927SAndroid Build Coastguard Worker 92*61046927SAndroid Build Coastguard Workerlibvc4 = static_library( 93*61046927SAndroid Build Coastguard Worker 'vc4', 94*61046927SAndroid Build Coastguard Worker [files_libvc4, v3d_xml_pack], 95*61046927SAndroid Build Coastguard Worker include_directories : [ 96*61046927SAndroid Build Coastguard Worker inc_src, inc_include, inc_gallium, inc_gallium_aux, inc_broadcom, 97*61046927SAndroid Build Coastguard Worker inc_gallium_drivers, 98*61046927SAndroid Build Coastguard Worker ], 99*61046927SAndroid Build Coastguard Worker link_with: libvc4_neon, 100*61046927SAndroid Build Coastguard Worker c_args : [vc4_c_args], 101*61046927SAndroid Build Coastguard Worker gnu_symbol_visibility : 'hidden', 102*61046927SAndroid Build Coastguard Worker dependencies : vc4_deps, 103*61046927SAndroid Build Coastguard Worker build_by_default : false, 104*61046927SAndroid Build Coastguard Worker) 105*61046927SAndroid Build Coastguard Worker 106*61046927SAndroid Build Coastguard Workerdriver_vc4 = declare_dependency( 107*61046927SAndroid Build Coastguard Worker compile_args : '-DGALLIUM_VC4', 108*61046927SAndroid Build Coastguard Worker link_with : [libvc4, libvc4winsys, libbroadcom_cle, libbroadcom_v3d], 109*61046927SAndroid Build Coastguard Worker dependencies : idep_nir, 110*61046927SAndroid Build Coastguard Worker) 111