From d4567efa5ca5383fd5576b8871b3abc05e085360 Mon Sep 17 00:00:00 2001 From: Dylan Baker Date: Fri, 20 Oct 2017 15:57:15 -0700 Subject: [PATCH] meson: build imx driver Signed-off-by: Dylan Baker Reviewed-by: Christian Gmeiner --- meson.build | 5 +++++ meson_options.txt | 2 +- src/gallium/meson.build | 4 +++- src/gallium/targets/dri/meson.build | 5 +++++ src/gallium/winsys/imx/drm/meson.build | 28 ++++++++++++++++++++++++++ 5 files changed, 42 insertions(+), 2 deletions(-) create mode 100644 src/gallium/winsys/imx/drm/meson.build diff --git a/meson.build b/meson.build index a21781f3b8c..9f481225823 100644 --- a/meson.build +++ b/meson.build @@ -98,6 +98,7 @@ with_gallium_softpipe = false with_gallium_vc4 = false with_gallium_vc5 = false with_gallium_etnaviv = false +with_gallium_imx = false _drivers = get_option('gallium-drivers') if _drivers != '' _split = _drivers.split(',') @@ -108,6 +109,7 @@ if _drivers != '' with_gallium_vc4 = _split.contains('vc4') with_gallium_vc5 = _split.contains('vc5') with_gallium_etnaviv = _split.contains('etnaviv') + with_gallium_imx = _split.contains('imx') with_gallium = true with_dri = true endif @@ -123,6 +125,9 @@ endif if with_dri_swrast and with_gallium_softpipe error('Only one swrast provider can be built') endif +if with_gallium_imx and not with_gallium_etnaviv + error('IMX driver requires etnaviv driver') +endif dep_libdrm_intel = [] if with_dri_i915 diff --git a/meson_options.txt b/meson_options.txt index 5ca4e0301e6..be93871d614 100644 --- a/meson_options.txt +++ b/meson_options.txt @@ -46,7 +46,7 @@ option( option( 'gallium-drivers', type : 'string', - value : 'pl111,radeonsi,nouveau,swrast,vc4,etnaviv', + value : 'pl111,radeonsi,nouveau,swrast,vc4,etnaviv,imx', description : 'comma separated list of gallium drivers to build.' ) option( diff --git a/src/gallium/meson.build b/src/gallium/meson.build index cc823ca2e4f..4f39e6dad37 100644 --- a/src/gallium/meson.build +++ b/src/gallium/meson.build @@ -61,13 +61,15 @@ endif if with_gallium_etnaviv subdir('winsys/etnaviv/drm') endif +if with_gallium_imx + subdir('winsys/imx/drm') +endif subdir('state_trackers/dri') # TODO: freedreno # TODO: i915 # TODO: SVGA # TODO: r300 # TODO: r600 -# TODO: IMX # TODO: SWR # TODO: virgl # TODO: winsys/sw/xlib diff --git a/src/gallium/targets/dri/meson.build b/src/gallium/targets/dri/meson.build index 9640e8acbab..1517fcc5d3c 100644 --- a/src/gallium/targets/dri/meson.build +++ b/src/gallium/targets/dri/meson.build @@ -96,6 +96,11 @@ if with_gallium_etnaviv gallium_dri_link_with += [libetnaviv, libetnavivdrm] gallium_dri_drivers += 'etnaviv_dri.so' endif +if with_gallium_imx + gallium_dri_c_args += '-DGALLIUM_IMX' + gallium_dri_link_with += libimxdrm + gallium_dri_drivers += 'imx-drm_dri.so' +endif if with_gallium_vc4 or with_gallium_vc5 gallium_dri_link_with += libbroadcom_cle diff --git a/src/gallium/winsys/imx/drm/meson.build b/src/gallium/winsys/imx/drm/meson.build new file mode 100644 index 00000000000..468345476ec --- /dev/null +++ b/src/gallium/winsys/imx/drm/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. + +libimxdrm = static_library( + 'imxdrm', + 'imx_drm_winsys.c', + include_directories : [ + inc_include, inc_src, inc_gallium, inc_gallium_aux, + include_directories('../..'), + ], +) -- 2.30.2