[Mesa-dev] [PATCH 1/3] meson: Add support for the vc4 driver.
Eric Anholt
eric at anholt.net
Mon Oct 16 20:57:09 UTC 2017
---
meson.build | 2 +
meson_options.txt | 2 +-
src/{ => broadcom/cle}/meson.build | 80 +++++++++++----------
src/{ => broadcom}/meson.build | 50 ++-----------
src/gallium/drivers/vc4/meson.build | 101 +++++++++++++++++++++++++++
src/gallium/meson.build | 7 +-
src/gallium/targets/dri/meson.build | 11 ++-
src/{ => gallium/winsys/vc4/drm}/meson.build | 54 +++-----------
src/meson.build | 4 +-
9 files changed, 179 insertions(+), 132 deletions(-)
copy src/{ => broadcom/cle}/meson.build (53%)
copy src/{ => broadcom}/meson.build (51%)
create mode 100644 src/gallium/drivers/vc4/meson.build
copy src/{ => gallium/winsys/vc4/drm}/meson.build (53%)
diff --git a/meson.build b/meson.build
index bc3bbf41a65a..f538cf79bb4f 100644
--- a/meson.build
+++ b/meson.build
@@ -94,12 +94,14 @@ with_gallium = false
with_gallium_radeonsi = false
with_gallium_nouveau = false
with_gallium_softpipe = false
+with_gallium_vc4 = false
_drivers = get_option('gallium-drivers')
if _drivers != ''
_split = _drivers.split(',')
with_gallium_radeonsi = _split.contains('radeonsi')
with_gallium_nouveau = _split.contains('nouveau')
with_gallium_softpipe = _split.contains('swrast')
+ with_gallium_vc4 = _split.contains('vc4')
with_gallium = true
with_dri = true
endif
diff --git a/meson_options.txt b/meson_options.txt
index 71e9ea635557..51a180501289 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -46,7 +46,7 @@ option(
option(
'gallium-drivers',
type : 'string',
- value : 'radeonsi,nouveau,swrast',
+ value : 'radeonsi,nouveau,swrast,vc4',
description : 'comma separated list of gallium drivers to build.'
)
option(
diff --git a/src/meson.build b/src/broadcom/cle/meson.build
similarity index 53%
copy from src/meson.build
copy to src/broadcom/cle/meson.build
index 15d8af0197d3..32510cee5ef6 100644
--- a/src/meson.build
+++ b/src/broadcom/cle/meson.build
@@ -1,15 +1,15 @@
-# Copyright © 2017 Intel Corporation
-
+# Copyright © 2017 Broadcom
+#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
-
+#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
-
+#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
@@ -18,44 +18,42 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
-inc_common = include_directories(
- '../include', '.', 'mapi', 'mesa', 'gallium/include', 'gallium/auxiliary')
-inc_mesa = include_directories('mesa')
-inc_mapi = include_directories('mapi')
-inc_src = include_directories('.')
+v3d_versions = [
+ 21,
+ 33
+]
-libglsl_util = static_library(
- 'glsl_util',
- files('mesa/main/extensions_table.c', 'mesa/main/imports.c',
- 'mesa/program/prog_parameter.c', 'mesa/program/symbol_table.c',
- 'mesa/program/dummy_errors.c'),
- include_directories : [inc_common],
- c_args : [c_vis_args],
- build_by_default : false,
-)
+v3d_xml_files = []
+foreach v: v3d_versions
+ v3d_xml_files += 'v3d_packet_v at 0@.xml'.format(v)
+endforeach
-sha1_h = vcs_tag(
- input : 'git_sha1.h.in',
- output : 'git_sha1.h',
+v3d_xml_h = custom_target(
+ 'v3d_xml.h',
+ input : ['../../intel/genxml/gen_zipped_file.py', v3d_xml_files],
+ output : 'v3d_xml.h',
+ command : [prog_python2, '@INPUT@'],
+ capture : true,
)
-subdir('gtest')
-subdir('util')
-subdir('mapi/glapi/gen')
-subdir('mapi')
-# TODO: opengl
-# TODO: osmesa
-subdir('compiler')
-subdir('egl/wayland/wayland-drm')
-subdir('vulkan')
-subdir('amd')
-subdir('intel')
-# TODO: vc4
-subdir('mesa')
-subdir('loader')
-subdir('glx')
-if with_gbm
- subdir('gbm')
-endif
-# TODO: egl
-subdir('gallium')
+v3d_xml_pack = []
+foreach f : v3d_xml_files
+ _name = '@0 at _pack.h'.format(f.split('.')[0])
+ _xml = custom_target(
+ _name,
+ input : ['gen_pack_header.py', f],
+ output : _name,
+ command : [prog_python2, '@INPUT@'],
+ capture : true,
+ )
+ v3d_xml_pack += _xml
+endforeach
+
+libbroadcom_cle = static_library(
+ ['broadcom_cle', v3d_xml_h],
+ 'v3d_decoder.c',
+ include_directories : [inc_common, inc_broadcom],
+ c_args : [c_vis_args, no_override_init_args],
+ dependencies : [dep_libdrm, dep_valgrind],
+ build_by_default : false,
+)
diff --git a/src/meson.build b/src/broadcom/meson.build
similarity index 51%
copy from src/meson.build
copy to src/broadcom/meson.build
index 15d8af0197d3..909ca108ebd7 100644
--- a/src/meson.build
+++ b/src/broadcom/meson.build
@@ -1,15 +1,15 @@
-# Copyright © 2017 Intel Corporation
-
+# Copyright © 2017 Broadcom
+#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
-
+#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
-
+#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
@@ -18,44 +18,6 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
-inc_common = include_directories(
- '../include', '.', 'mapi', 'mesa', 'gallium/include', 'gallium/auxiliary')
-inc_mesa = include_directories('mesa')
-inc_mapi = include_directories('mapi')
-inc_src = include_directories('.')
-
-libglsl_util = static_library(
- 'glsl_util',
- files('mesa/main/extensions_table.c', 'mesa/main/imports.c',
- 'mesa/program/prog_parameter.c', 'mesa/program/symbol_table.c',
- 'mesa/program/dummy_errors.c'),
- include_directories : [inc_common],
- c_args : [c_vis_args],
- build_by_default : false,
-)
-
-sha1_h = vcs_tag(
- input : 'git_sha1.h.in',
- output : 'git_sha1.h',
-)
+inc_broadcom = include_directories('.', 'cle')
-subdir('gtest')
-subdir('util')
-subdir('mapi/glapi/gen')
-subdir('mapi')
-# TODO: opengl
-# TODO: osmesa
-subdir('compiler')
-subdir('egl/wayland/wayland-drm')
-subdir('vulkan')
-subdir('amd')
-subdir('intel')
-# TODO: vc4
-subdir('mesa')
-subdir('loader')
-subdir('glx')
-if with_gbm
- subdir('gbm')
-endif
-# TODO: egl
-subdir('gallium')
+subdir('cle')
diff --git a/src/gallium/drivers/vc4/meson.build b/src/gallium/drivers/vc4/meson.build
new file mode 100644
index 000000000000..38b47fbdd977
--- /dev/null
+++ b/src/gallium/drivers/vc4/meson.build
@@ -0,0 +1,101 @@
+# Copyright © 2017 Broadcom
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+files_libvc4 = files(
+ 'kernel/vc4_drv.h',
+ 'kernel/vc4_gem.c',
+ 'kernel/vc4_packet.h',
+ 'kernel/vc4_render_cl.c',
+ 'kernel/vc4_validate.c',
+ 'kernel/vc4_validate_shaders.c',
+ 'vc4_blit.c',
+ 'vc4_bufmgr.c',
+ 'vc4_bufmgr.h',
+ 'vc4_cl.c',
+ 'vc4_cl_dump.c',
+ 'vc4_cl_dump.h',
+ 'vc4_cl.h',
+ 'vc4_context.c',
+ 'vc4_context.h',
+ 'vc4_draw.c',
+ 'vc4_emit.c',
+ 'vc4_fence.c',
+ 'vc4_formats.c',
+ 'vc4_job.c',
+ 'vc4_nir_lower_blend.c',
+ 'vc4_nir_lower_io.c',
+ 'vc4_nir_lower_txf_ms.c',
+ 'vc4_opt_algebraic.c',
+ 'vc4_opt_constant_folding.c',
+ 'vc4_opt_copy_propagation.c',
+ 'vc4_opt_dead_code.c',
+ 'vc4_opt_peephole_sf.c',
+ 'vc4_opt_small_immediates.c',
+ 'vc4_opt_vpm.c',
+ 'vc4_opt_coalesce_ff_writes.c',
+ 'vc4_program.c',
+ 'vc4_qir.c',
+ 'vc4_qir_emit_uniform_stream_resets.c',
+ 'vc4_qir_live_variables.c',
+ 'vc4_qir_lower_uniforms.c',
+ 'vc4_qir_schedule.c',
+ 'vc4_qir_validate.c',
+ 'vc4_qir.h',
+ 'vc4_qpu.c',
+ 'vc4_qpu_defines.h',
+ 'vc4_qpu_disasm.c',
+ 'vc4_qpu_emit.c',
+ 'vc4_qpu.h',
+ 'vc4_qpu_schedule.c',
+ 'vc4_qpu_validate.c',
+ 'vc4_query.c',
+ 'vc4_register_allocate.c',
+ 'vc4_reorder_uniforms.c',
+ 'vc4_resource.c',
+ 'vc4_resource.h',
+ 'vc4_screen.c',
+ 'vc4_screen.h',
+ 'vc4_simulator.c',
+ 'vc4_simulator_validate.h',
+ 'vc4_state.c',
+ 'vc4_tiling.c',
+ 'vc4_tiling_lt.c',
+ 'vc4_tiling.h',
+ 'vc4_uniforms.c',
+)
+
+simpenrose_c_args = []
+dep_simpenrose = dependency('simpenrose', required : false)
+if dep_simpenrose.found()
+ simpenrose_c_args = '-DUSE_VC4_SIMULATOR'
+endif
+
+libvc4 = static_library(
+ 'vc4',
+ [files_libvc4, v3d_xml_pack, nir_opcodes_h, nir_builder_opcodes_h],
+ include_directories : [
+ inc_src, inc_include, inc_gallium, inc_gallium_aux, inc_broadcom,
+ inc_gallium_drivers, inc_drm_uapi,
+ ],
+ c_args : [c_vis_args, simpenrose_c_args],
+ cpp_args : [cpp_vis_args],
+ dependencies : [dep_simpenrose, dep_libdrm, dep_valgrind],
+ build_by_default : false,
+)
diff --git a/src/gallium/meson.build b/src/gallium/meson.build
index e7970e116387..3c5756c0a7f9 100644
--- a/src/gallium/meson.build
+++ b/src/gallium/meson.build
@@ -32,6 +32,9 @@ subdir('drivers/radeon')
subdir('drivers/radeonsi')
subdir('drivers/nouveau')
subdir('drivers/softpipe')
+if with_gallium_vc4
+ subdir('drivers/vc4')
+endif
subdir('drivers/llvmpipe')
subdir('winsys/sw/null')
subdir('winsys/sw/dri')
@@ -40,6 +43,9 @@ subdir('winsys/sw/wrapper')
subdir('winsys/radeon/drm')
subdir('winsys/amdgpu/drm')
subdir('winsys/nouveau/drm')
+if with_gallium_vc4
+ subdir('winsys/vc4/drm')
+endif
subdir('state_trackers/dri')
# TODO: freedreno
# TODO: i915
@@ -50,7 +56,6 @@ subdir('state_trackers/dri')
# TODO: IMX
# TODO: PL111
# TODO: SWR
-# TODO: vc4
# TODO: virgl
# TODO: winsys/sw/xlib
# TODO: clover
diff --git a/src/gallium/targets/dri/meson.build b/src/gallium/targets/dri/meson.build
index 2dc0de6a4d0c..02ea2e26bcd5 100644
--- a/src/gallium/targets/dri/meson.build
+++ b/src/gallium/targets/dri/meson.build
@@ -54,7 +54,7 @@ endif
if with_gallium_radeonsi
gallium_dri_c_args += '-DGALLIUM_RADEONSI'
gallium_dri_link_with += [
- libradeonsi, libnir, libradeonwinsys, libamdgpuwinsys, libradeon,
+ libradeonsi, libradeonwinsys, libamdgpuwinsys, libradeon,
libamd_common,
]
gallium_dri_drivers += 'radeonsi_dri.so'
@@ -76,6 +76,15 @@ if with_gallium_softpipe
gallium_dri_link_with += libllvmpipe
endif
endif
+if with_gallium_vc4
+ gallium_dri_c_args += '-DGALLIUM_VC4'
+ gallium_dri_link_with += [libvc4, libvc4winsys, libbroadcom_cle]
+ gallium_dri_drivers += 'vc4_dri.so'
+endif
+
+if with_gallium_vc4 or with_gallium_radeonsi
+ gallium_dri_link_with += libnir
+endif
libgallium_dri = shared_library(
'gallium_dri',
diff --git a/src/meson.build b/src/gallium/winsys/vc4/drm/meson.build
similarity index 53%
copy from src/meson.build
copy to src/gallium/winsys/vc4/drm/meson.build
index 15d8af0197d3..58216dc5f545 100644
--- a/src/meson.build
+++ b/src/gallium/winsys/vc4/drm/meson.build
@@ -1,15 +1,15 @@
-# Copyright © 2017 Intel Corporation
-
+# Copyright © 2017 Broadcom
+#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
-
+#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
-
+#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
@@ -18,44 +18,12 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
-inc_common = include_directories(
- '../include', '.', 'mapi', 'mesa', 'gallium/include', 'gallium/auxiliary')
-inc_mesa = include_directories('mesa')
-inc_mapi = include_directories('mapi')
-inc_src = include_directories('.')
-
-libglsl_util = static_library(
- 'glsl_util',
- files('mesa/main/extensions_table.c', 'mesa/main/imports.c',
- 'mesa/program/prog_parameter.c', 'mesa/program/symbol_table.c',
- 'mesa/program/dummy_errors.c'),
- include_directories : [inc_common],
+libvc4winsys = static_library(
+ 'vc4winsys',
+ files('vc4_drm_winsys.c'),
+ include_directories : [
+ inc_src, inc_include,
+ inc_gallium, inc_gallium_aux, inc_gallium_drivers,
+ ],
c_args : [c_vis_args],
- build_by_default : false,
)
-
-sha1_h = vcs_tag(
- input : 'git_sha1.h.in',
- output : 'git_sha1.h',
-)
-
-subdir('gtest')
-subdir('util')
-subdir('mapi/glapi/gen')
-subdir('mapi')
-# TODO: opengl
-# TODO: osmesa
-subdir('compiler')
-subdir('egl/wayland/wayland-drm')
-subdir('vulkan')
-subdir('amd')
-subdir('intel')
-# TODO: vc4
-subdir('mesa')
-subdir('loader')
-subdir('glx')
-if with_gbm
- subdir('gbm')
-endif
-# TODO: egl
-subdir('gallium')
diff --git a/src/meson.build b/src/meson.build
index 15d8af0197d3..0326be0bfef3 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -49,8 +49,10 @@ subdir('compiler')
subdir('egl/wayland/wayland-drm')
subdir('vulkan')
subdir('amd')
+if with_gallium_vc4
+ subdir('broadcom')
+endif
subdir('intel')
-# TODO: vc4
subdir('mesa')
subdir('loader')
subdir('glx')
--
2.14.2
More information about the mesa-dev
mailing list