xref: /aosp_15_r20/external/mesa3d/src/gallium/drivers/vc4/meson.build (revision 6104692788411f58d303aa86923a9ff6ecaded22)
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