meson: build gallium based osmesa
authorDylan Baker <dylan@pnwbakers.com>
Tue, 24 Oct 2017 22:52:57 +0000 (15:52 -0700)
committerDylan Baker <dylan@pnwbakers.com>
Fri, 27 Oct 2017 18:06:45 +0000 (11:06 -0700)
This has been tested with the osdemo from mesa-demos

v2: - Add SELinux dependency
    - fix typo GALLIUM_LLVM -> GALLIUM_LLVMPIPE

Signed-off-by: Dylan Baker <dylanx.c.baker@intel.com>
Reviewed-by: Eric Engestrom <eric.engestrom@imgtec.com>
meson.build
meson_options.txt
src/gallium/meson.build
src/gallium/state_trackers/osmesa/meson.build [new file with mode: 0644]
src/gallium/targets/osmesa/meson.build [new file with mode: 0644]

index ef06ea8f6b755ccbb6ce567a972ccfcd5211a0e3..8988deae7838d5d5d68150ae12a63cf7d0bff95d 100644 (file)
@@ -715,6 +715,9 @@ if with_osmesa != 'none'
   if with_osmesa == 'classic' and not with_dri_swrast
     error('OSMesa classic requires dri (classic) swrast.')
   endif
+  if with_osmesa == 'gallium' and not with_gallium_softpipe
+    error('OSMesa gallium requires gallium softpipe or llvmpipe.')
+  endif
   osmesa_lib_name = 'OSMesa'
   osmesa_bits = get_option('osmesa-bits')
   if osmesa_bits != '8'
index 84feb630026610e39f50f06a95ab4747a3253c8f..74f1e71bf4344351a4c579bf733ce3d034607d59 100644 (file)
@@ -170,7 +170,7 @@ option(
   'osmesa',
   type : 'combo',
   value : 'none',
-  choices : ['none', 'classic'],
+  choices : ['none', 'classic', 'gallium'],
   description : 'Build OSmesa.'
 )
 option(
index e0941103b93462881856e75c7a46d7dd1a279661..6edfe80321d3a4da9d89edff64cc1104586a4827 100644 (file)
@@ -66,6 +66,9 @@ if with_gallium_imx
   subdir('winsys/imx/drm')
 endif
 subdir('state_trackers/dri')
+if with_osmesa == 'gallium'
+  subdir('state_trackers/osmesa')
+endif
 # TODO: i915
 # TODO: SVGA
 # TODO: r300
@@ -77,9 +80,11 @@ subdir('state_trackers/dri')
 if with_dri and with_gallium
   subdir('targets/dri')
 endif
+if with_osmesa == 'gallium'
+  subdir('targets/osmesa')
+endif
 # TODO: xlib-glx
 # TODO: OMX
-# TODO: osmesa
 # TODO: VA
 # TODO: vdpau
 # TODO: xa
diff --git a/src/gallium/state_trackers/osmesa/meson.build b/src/gallium/state_trackers/osmesa/meson.build
new file mode 100644 (file)
index 0000000..dacf105
--- /dev/null
@@ -0,0 +1,28 @@
+# 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.
+
+libosmesa_st = static_library(
+  'osmesa_st',
+  'osmesa.c',
+  c_args : ['-DGALLIUM_SOFTPIPE', '-DGALLIUM_TRACE'],
+  include_directories : [
+    inc_include, inc_src, inc_gallium, inc_gallium_aux, inc_mapi, inc_mesa,
+  ],
+)
diff --git a/src/gallium/targets/osmesa/meson.build b/src/gallium/targets/osmesa/meson.build
new file mode 100644 (file)
index 0000000..b4b3911
--- /dev/null
@@ -0,0 +1,68 @@
+# 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.
+
+osmesa_link_with = []
+osmesa_link_args = []
+osmesa_comp_args = ['-DGALLIUM_SOFTPIPE', '-DGALLIUM_TRACE']
+osmesa_deps = []
+
+if with_shared_glapi
+  osmesa_link_with += libglapi
+endif
+if with_ld_version_script
+  osmesa_link_args += [
+    '-Wl,--version-script', join_paths(meson.current_source_dir(), 'osmesa.sym')
+  ]
+endif
+
+if with_llvm
+  osmesa_comp_args += '-DGALLIUM_LLVMPIPE'
+  osmesa_deps += dep_llvm
+  osmesa_link_with += libllvmpipe
+endif
+# TODO: swr
+
+libosmesa = shared_library(
+  osmesa_lib_name,
+  'target.c',
+  c_args : [c_vis_args, osmesa_comp_args],
+  cpp_args : [cpp_vis_args, osmesa_comp_args],
+  link_args : [ld_args_gc_sections, osmesa_link_args],
+  include_directories : [
+    inc_include, inc_src, inc_gallium, inc_gallium_aux, inc_gallium_winsys,
+    inc_gallium_drivers,
+  ],
+  link_whole : [libosmesa_st],
+  link_with : [
+    libmesa_gallium, libgallium, libglapi_static, libws_null, libtrace,
+    libsoftpipe, osmesa_link_with,
+  ],
+  dependencies : [dep_selinux, dep_thread, dep_clock, dep_unwind, osmesa_deps],
+  version : '8.0.0',
+  install : true,
+)
+
+pkg.generate(
+  name : 'osmesa',
+  description : 'Mesa Off-screen Rendering Library',
+  version : '8',
+  libraries : libosmesa,
+  libraries_private : gl_priv_libs,
+)