[03/13] meson: build r300 driver

Submitted by Dylan Baker on Nov. 1, 2017, 10:49 p.m.

Details

Message ID 20171101224948.14696-4-dylan@pnwbakers.com
State New
Headers show
Series "meson: build remaining gallium drivers, media state trackers" ( rev: 1 ) in Mesa

Not browsing as part of any series.

Commit Message

Dylan Baker Nov. 1, 2017, 10:49 p.m.
This is build tested only

Signed-off-by: Dylan Baker <dylanx.c.baker@intel.com>
---
 meson.build                          |   4 +-
 meson_options.txt                    |   2 +-
 src/gallium/drivers/r300/meson.build | 156 +++++++++++++++++++++++++++++++++++
 src/gallium/meson.build              |   4 +-
 src/gallium/targets/dri/meson.build  |  12 ++-
 5 files changed, 173 insertions(+), 5 deletions(-)
 create mode 100644 src/gallium/drivers/r300/meson.build

Patch hide | download patch | download mbox

diff --git a/meson.build b/meson.build
index 9206369a72a..daa07330f12 100644
--- a/meson.build
+++ b/meson.build
@@ -104,6 +104,7 @@  endif
 with_gallium = false
 with_gallium_pl111 = false
 with_gallium_radeonsi = false
+with_gallium_r300 = false
 with_gallium_nouveau = false
 with_gallium_freedreno = false
 with_gallium_softpipe = false
@@ -117,6 +118,7 @@  if _drivers != ''
   _split = _drivers.split(',')
   with_gallium_pl111 = _split.contains('pl111')
   with_gallium_radeonsi = _split.contains('radeonsi')
+  with_gallium_r300 = _split.contains('r300')
   with_gallium_nouveau = _split.contains('nouveau')
   with_gallium_freedreno = _split.contains('freedreno')
   with_gallium_softpipe = _split.contains('swrast')
@@ -645,7 +647,7 @@  dep_libdrm_freedreno = []
 if with_amd_vk or with_gallium_radeonsi
   dep_libdrm_amdgpu = dependency('libdrm_amdgpu', version : '>= 2.4.86')
 endif
-if with_gallium_radeonsi or with_dri_r100 or with_dri_r200
+if with_gallium_radeonsi or with_dri_r100 or with_dri_r200 or with_gallium_r300
   dep_libdrm_radeon = dependency('libdrm_radeon', version : '>= 2.4.71')
 endif
 if with_gallium_nouveau or with_dri_nouveau
diff --git a/meson_options.txt b/meson_options.txt
index d93dd6eab2a..eca431edd95 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -46,7 +46,7 @@  option(
 option(
   'gallium-drivers',
   type : 'string',
-  value : 'pl111,radeonsi,nouveau,freedreno,swrast,vc4,etnaviv,imx',
+  value : 'pl111,radeonsi,nouveau,freedreno,swrast,vc4,etnaviv,imx,r300',
   description : 'comma separated list of gallium drivers to build.'
 )
 option(
diff --git a/src/gallium/drivers/r300/meson.build b/src/gallium/drivers/r300/meson.build
new file mode 100644
index 00000000000..0d525d8d1b3
--- /dev/null
+++ b/src/gallium/drivers/r300/meson.build
@@ -0,0 +1,156 @@ 
+# Copyright © 2017 Intel Corporation
+
+# 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_r300 = files(
+  'r300_blit.c',
+  'r300_cb.h',
+  'r300_chipset.c',
+  'r300_chipset.h',
+  'r300_context.c',
+  'r300_context.h',
+  'r300_cs.h',
+  'r300_debug.c',
+  'r300_defines.h',
+  'r300_emit.c',
+  'r300_emit.h',
+  'r300_flush.c',
+  'r300_fs.c',
+  'r300_fs.h',
+  'r300_hyperz.c',
+  'r300_public.h',
+  'r300_query.c',
+  'r300_reg.h',
+  'r300_render.c',
+  'r300_render_stencilref.c',
+  'r300_render_translate.c',
+  'r300_resource.c',
+  'r300_screen_buffer.c',
+  'r300_screen_buffer.h',
+  'r300_screen.c',
+  'r300_screen.h',
+  'r300_shader_semantics.h',
+  'r300_state.c',
+  'r300_state_derived.c',
+  'r300_state_inlines.h',
+  'r300_texture.c',
+  'r300_texture_desc.c',
+  'r300_texture_desc.h',
+  'r300_texture.h',
+  'r300_tgsi_to_rc.c',
+  'r300_tgsi_to_rc.h',
+  'r300_transfer.c',
+  'r300_transfer.h',
+  'r300_vs.c',
+  'r300_vs_draw.c',
+  'r300_vs.h',
+  'compiler/memory_pool.c',
+  'compiler/memory_pool.h',
+  'compiler/r300_fragprog.c',
+  'compiler/r300_fragprog_emit.c',
+  'compiler/r300_fragprog.h',
+  'compiler/r300_fragprog_swizzle.c',
+  'compiler/r300_fragprog_swizzle.h',
+  'compiler/r3xx_fragprog.c',
+  'compiler/r3xx_vertprog.c',
+  'compiler/r3xx_vertprog_dump.c',
+  'compiler/r500_fragprog.c',
+  'compiler/r500_fragprog_emit.c',
+  'compiler/r500_fragprog.h',
+  'compiler/radeon_code.c',
+  'compiler/radeon_code.h',
+  'compiler/radeon_compiler.c',
+  'compiler/radeon_compiler.h',
+  'compiler/radeon_compiler_util.c',
+  'compiler/radeon_compiler_util.h',
+  'compiler/radeon_dataflow.c',
+  'compiler/radeon_dataflow_deadcode.c',
+  'compiler/radeon_dataflow.h',
+  'compiler/radeon_dataflow_swizzles.c',
+  'compiler/radeon_emulate_branches.c',
+  'compiler/radeon_emulate_branches.h',
+  'compiler/radeon_emulate_loops.c',
+  'compiler/radeon_emulate_loops.h',
+  'compiler/radeon_inline_literals.c',
+  'compiler/radeon_list.c',
+  'compiler/radeon_list.h',
+  'compiler/radeon_opcodes.c',
+  'compiler/radeon_opcodes.h',
+  'compiler/radeon_optimize.c',
+  'compiler/radeon_pair_dead_sources.c',
+  'compiler/radeon_pair_regalloc.c',
+  'compiler/radeon_pair_schedule.c',
+  'compiler/radeon_pair_translate.c',
+  'compiler/radeon_program_alu.c',
+  'compiler/radeon_program_alu.h',
+  'compiler/radeon_program.c',
+  'compiler/radeon_program_constants.h',
+  'compiler/radeon_program.h',
+  'compiler/radeon_program_pair.c',
+  'compiler/radeon_program_pair.h',
+  'compiler/radeon_program_print.c',
+  'compiler/radeon_program_tex.c',
+  'compiler/radeon_program_tex.h',
+  'compiler/radeon_regalloc.h',
+  'compiler/radeon_remove_constants.c',
+  'compiler/radeon_remove_constants.h',
+  'compiler/radeon_rename_regs.c',
+  'compiler/radeon_rename_regs.h',
+  'compiler/radeon_swizzle.h',
+  'compiler/radeon_variable.c',
+  'compiler/radeon_variable.h',
+  'compiler/radeon_vert_fc.c',
+)
+
+libr300 = static_library(
+  'r300',
+  files_r300,
+  c_args : [c_vis_args],
+  include_directories : [
+    inc_src, inc_include, inc_gallium, inc_gallium_aux, inc_gallium_drivers,
+    inc_mesa,
+  ],
+  dependencies : [dep_libdrm_radeon, dep_llvm],
+)
+
+if with_tests
+  test('r300_compiler_test', executable(
+      'r300_compiler_test',
+      files(
+        'compiler/tests/r300_compiler_tests.c',
+        'compiler/tests/radeon_compiler_optimize_tests.c',
+        'compiler/tests/radeon_compiler_regalloc_tests.c',
+        'compiler/tests/radeon_compiler_util_tests.c',
+        'compiler/tests/rc_test_helpers.c',
+        'compiler/tests/unit_test.c',
+      ),
+      c_args : [
+        '-DTEST_PATH="@0@"'.format(
+          join_paths(meson.current_source_dir(), 'compiler', 'tests')
+        )
+      ],
+      include_directories : [
+        inc_src, inc_include, inc_gallium, inc_gallium_aux,
+        include_directories('compiler'),
+      ],
+      link_with : [libr300, libgallium, libmesa_util],
+      dependencies : [dep_m, dep_clock, dep_dl, dep_thread, dep_unwind],
+    )
+  )
+endif
diff --git a/src/gallium/meson.build b/src/gallium/meson.build
index 67002132cd0..15fe86ff6db 100644
--- a/src/gallium/meson.build
+++ b/src/gallium/meson.build
@@ -44,6 +44,9 @@  endif
 if with_gallium_i915
   subdir('drivers/i915')
 endif
+if with_gallium_r300
+  subdir('drivers/r300')
+endif
 subdir('drivers/llvmpipe')
 subdir('winsys/sw/null')
 subdir('winsys/sw/dri')
@@ -76,7 +79,6 @@  if with_osmesa == 'gallium'
   subdir('state_trackers/osmesa')
 endif
 # TODO: SVGA
-# TODO: r300
 # TODO: r600
 # TODO: SWR
 # TODO: virgl
diff --git a/src/gallium/targets/dri/meson.build b/src/gallium/targets/dri/meson.build
index 631cd664e52..4fc1a841130 100644
--- a/src/gallium/targets/dri/meson.build
+++ b/src/gallium/targets/dri/meson.build
@@ -59,8 +59,7 @@  endif
 if with_gallium_radeonsi
   gallium_dri_c_args += '-DGALLIUM_RADEONSI'
   gallium_dri_link_with += [
-    libradeonsi, libradeonwinsys, libamdgpuwinsys, libradeon,
-    libamd_common,
+    libradeonsi, libamdgpuwinsys, libradeon, libamd_common,
   ]
   gallium_dri_drivers += 'radeonsi_dri.so'
 endif
@@ -112,6 +111,15 @@  if with_gallium_i915
   gallium_dri_link_with += [libi915, libi915drm]
   gallium_dri_drivers += 'i915_dri.so'
 endif
+if with_gallium_r300
+  gallium_dri_c_args += '-DGALLIUM_R300'
+  gallium_dri_link_with += libr300
+  gallium_dri_drivers += 'r300_dri.so'
+endif
+
+if with_gallium_radeonsi or with_gallium_r300 # TODO: r600
+  gallium_dri_link_with += libradeonwinsys
+endif
 
 if with_gallium_vc4 or with_gallium_vc5
   gallium_dri_link_with += libbroadcom_cle