summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--meson.build3
-rw-r--r--meson_options.txt2
-rw-r--r--src/gallium/meson.build7
-rw-r--r--src/gallium/state_trackers/osmesa/meson.build28
-rw-r--r--src/gallium/targets/osmesa/meson.build68
5 files changed, 106 insertions, 2 deletions
diff --git a/meson.build b/meson.build
index ef06ea8f6b..8988deae78 100644
--- a/meson.build
+++ b/meson.build
@@ -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'
diff --git a/meson_options.txt b/meson_options.txt
index 84feb63002..74f1e71bf4 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -170,7 +170,7 @@ option(
'osmesa',
type : 'combo',
value : 'none',
- choices : ['none', 'classic'],
+ choices : ['none', 'classic', 'gallium'],
description : 'Build OSmesa.'
)
option(
diff --git a/src/gallium/meson.build b/src/gallium/meson.build
index e0941103b9..6edfe80321 100644
--- a/src/gallium/meson.build
+++ b/src/gallium/meson.build
@@ -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
index 0000000000..dacf10512d
--- /dev/null
+++ b/src/gallium/state_trackers/osmesa/meson.build
@@ -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
index 0000000000..b4b3911ffd
--- /dev/null
+++ b/src/gallium/targets/osmesa/meson.build
@@ -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,
+)