Quoting Jan Vesely (2018-01-06 15:18:54) > On Fri, 2018-01-05 at 15:26 -0800, Dylan Baker wrote: > > Quoting Jan Vesely (2018-01-05 14:16:41) > > > Hi, > > > > > > > > > sorry for the delay. I was mostly traveling during the holidays. > > > > No worries, I was also away over the holidays and didn't look at this until > > today. > > > > > > > > On Fri, 2017-12-15 at 10:54 -0800, Dylan Baker wrote: > > > > This has only been compile tested. > > > > > > > > v2: - Have a single option for opencl (Eric E) > > > > - fix typo "tgis" -> "tgsi" (Curro) > > > > - Don't add "lib" to pipe loader libraries, which matches the > > > > autotools behavior > > > > v3: - Remove trailing whitespace > > > > - Make PIPE_SEARCH_DIR an absolute path > > > > > > > > cc: Curro Jerez <curroje...@riseup.net> > > > > cc: Jan Vesely <jan.ves...@rutgers.edu> > > > > cc: Aaron Watry <awa...@gmail.com> > > > > Signed-off-by: Dylan Baker <dylanx.c.ba...@intel.com> > > > > --- > > > > include/meson.build | 19 ++++ > > > > meson.build | 29 +++++- > > > > meson_options.txt | 7 ++ > > > > src/gallium/auxiliary/pipe-loader/meson.build | 3 +- > > > > src/gallium/meson.build | 12 ++- > > > > src/gallium/state_trackers/clover/meson.build | 122 > > > > ++++++++++++++++++++++++++ > > > > src/gallium/targets/opencl/meson.build | 73 +++++++++++++++ > > > > src/gallium/targets/pipe-loader/meson.build | 77 ++++++++++++++++ > > > > 8 files changed, 336 insertions(+), 6 deletions(-) > > > > create mode 100644 src/gallium/state_trackers/clover/meson.build > > > > create mode 100644 src/gallium/targets/opencl/meson.build > > > > create mode 100644 src/gallium/targets/pipe-loader/meson.build > > > > > > > > diff --git a/include/meson.build b/include/meson.build > > > > index e4dae91cede..a2e7ce6580e 100644 > > > > --- a/include/meson.build > > > > +++ b/include/meson.build > > > > @@ -78,3 +78,22 @@ if with_gallium_st_nine > > > > subdir : 'd3dadapter', > > > > ) > > > > endif > > > > + > > > > +# Only install the headers if we are building a stand alone > > > > implementation and > > > > +# not an ICD enabled implementation > > > > +if with_gallium_opencl and not with_opencl_icd > > > > + install_headers( > > > > + 'CL/cl.h', > > > > + 'CL/cl.hpp', > > > > + 'CL/cl_d3d10.h', > > > > + 'CL/cl_d3d11.h', > > > > + 'CL/cl_dx9_media_sharing.h', > > > > + 'CL/cl_egl.h', > > > > + 'CL/cl_ext.h', > > > > + 'CL/cl_gl.h', > > > > + 'CL/cl_gl_ext.h', > > > > + 'CL/cl_platform.h', > > > > + 'CL/opencl.h', > > > > + subdir: 'CL' > > > > + ) > > > > +endif > > > > diff --git a/meson.build b/meson.build > > > > index 842d441199e..74b2d5c49dc 100644 > > > > --- a/meson.build > > > > +++ b/meson.build > > > > @@ -583,6 +583,22 @@ if with_gallium_st_nine > > > > endif > > > > endif > > > > > > > > +_opencl = get_option('gallium-opencl') > > > > +if _opencl !=' disabled' > > > > + if not with_gallium > > > > + error('OpenCL Clover implementation requires at least one gallium > > > > driver.') > > > > + endif > > > > + > > > > + # TODO: alitvec? > > > > + dep_clc = dependency('libclc') > > > > + with_gallium_opencl = true > > > > + with_opencl_icd = _opencl == 'icd' > > > > +else > > > > + dep_clc = [] > > > > + with_gallium_opencl = false > > > > + with_gallium_icd = false > > > > +endif > > > > + > > > > gl_pkgconfig_c_flags = [] > > > > if with_platform_x11 > > > > if with_any_vk or (with_glx == 'dri' and with_dri_platform == 'drm') > > > > @@ -930,7 +946,7 @@ dep_thread = dependency('threads') > > > > if dep_thread.found() and host_machine.system() != 'windows' > > > > pre_args += '-DHAVE_PTHREAD' > > > > endif > > > > -if with_amd_vk or with_gallium_radeonsi or with_gallium_r600 # TODO: > > > > clover > > > > +if with_amd_vk or with_gallium_radeonsi or with_gallium_r600 or > > > > with_gallium_opencl > > > > dep_elf = dependency('libelf', required : false) > > > > if not dep_elf.found() > > > > dep_elf = cc.find_library('elf') > > > > @@ -972,12 +988,19 @@ if with_amd_vk or with_gallium_radeonsi or > > > > with_gallium_r600 > > > > llvm_modules += 'asmparser' > > > > endif > > > > endif > > > > +if with_gallium_opencl > > > > + llvm_modules += [ > > > > + 'all-targets', 'linker', 'coverage', 'instrumentation', 'ipo', > > > > 'irreader', > > > > + 'lto', 'option', 'objcarcopts', 'profiledata', > > > > + ] > > > > + # TODO: optional modules > > > > +endif > > > > > > > > _llvm = get_option('llvm') > > > > if _llvm == 'auto' > > > > dep_llvm = dependency( > > > > 'llvm', version : '>= 3.9.0', modules : llvm_modules, > > > > - required : with_amd_vk or with_gallium_radeonsi or > > > > with_gallium_swr, > > > > + required : with_amd_vk or with_gallium_radeonsi or > > > > with_gallium_swr or with_gallium_opencl, > > > > ) > > > > with_llvm = dep_llvm.found() > > > > elif _llvm == 'true' > > > > @@ -1154,8 +1177,6 @@ else > > > > dep_lmsensors = [] > > > > endif > > > > > > > > -# TODO: clover > > > > - > > > > # TODO: gallium tests > > > > > > > > # TODO: various libdirs > > > > diff --git a/meson_options.txt b/meson_options.txt > > > > index 4f4db5b7d26..894378985fd 100644 > > > > --- a/meson_options.txt > > > > +++ b/meson_options.txt > > > > @@ -120,6 +120,13 @@ option( > > > > value : false, > > > > description : 'build gallium "nine" Direct3D 9.x state tracker.', > > > > ) > > > > +option( > > > > + 'gallium-opencl', > > > > + type : 'combo', > > > > + choices : ['icd', 'standalone', 'disabled'], > > > > + value : 'disabled', > > > > + description : 'build gallium "clover" OpenCL state tracker.', > > > > +) > > > > option( > > > > 'd3d-drivers-path', > > > > type : 'string', > > > > diff --git a/src/gallium/auxiliary/pipe-loader/meson.build > > > > b/src/gallium/auxiliary/pipe-loader/meson.build > > > > index 9b12432aea0..869a2935149 100644 > > > > --- a/src/gallium/auxiliary/pipe-loader/meson.build > > > > +++ b/src/gallium/auxiliary/pipe-loader/meson.build > > > > @@ -60,7 +60,8 @@ libpipe_loader_dynamic = static_library( > > > > ], > > > > c_args : [ > > > > c_vis_args, libpipe_loader_defines, '-DHAVE_PIPE_LOADER_DRI', > > > > - '-DPIPE_SEARCH_DIR="@0@"'.format(join_paths(get_option('libdir'), > > > > 'gallium-pipe') > > > > + '-DPIPE_SEARCH_DIR="@0@"'.format( > > > > + join_paths(get_option('prefix'), get_option('libdir'), > > > > 'gallium-pipe') > > > > ) > > > > ], > > > > link_with : [libloader, libxmlconfig], > > > > diff --git a/src/gallium/meson.build b/src/gallium/meson.build > > > > index fc21dcf03e1..6330c7514af 100644 > > > > --- a/src/gallium/meson.build > > > > +++ b/src/gallium/meson.build > > > > @@ -145,7 +145,17 @@ endif > > > > if with_gallium_st_nine > > > > subdir('state_trackers/nine') > > > > endif > > > > -# TODO: clover > > > > +if with_gallium_opencl > > > > + # TODO: this isn't really clover specific, but ATM clover is the only > > > > + # consumer > > > > + subdir('targets/pipe-loader') > > > > + > > > > + if meson.version().version_compare('< 0.44.0') > > > > + error('OpenCL requires meson 0.44.0 or greater.') > > > > + endif > > > > + subdir('state_trackers/clover') > > > > + subdir('targets/opencl') > > > > +endif > > > > if with_dri > > > > subdir('state_trackers/dri') > > > > subdir('targets/dri') > > > > diff --git a/src/gallium/state_trackers/clover/meson.build > > > > b/src/gallium/state_trackers/clover/meson.build > > > > new file mode 100644 > > > > index 00000000000..accc090d31f > > > > --- /dev/null > > > > +++ b/src/gallium/state_trackers/clover/meson.build > > > > @@ -0,0 +1,122 @@ > > > > +# 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. > > > > + > > > > +clover_cpp_args = [] > > > > +clover_incs = [inc_include, inc_src, inc_gallium, inc_gallium_aux] > > > > + > > > > +if with_opencl_icd > > > > + clover_cpp_args += '-DHAVE_CLOVER_ICD' > > > > +endif > > > > + > > > > +libcltgsi = static_library( > > > > + 'cltgsi', > > > > + files('tgsi/compiler.cpp', 'tgsi/invocation.hpp'), > > > > + include_directories : clover_incs, > > > > + cpp_args : [cpp_vis_args], > > > > +) > > > > + > > > > +libclllvm = static_library( > > > > + 'clllvm', > > > > + files( > > > > + 'llvm/codegen/bitcode.cpp', > > > > + 'llvm/codegen/common.cpp', > > > > + 'llvm/codegen/native.cpp', > > > > + 'llvm/codegen.hpp', > > > > + 'llvm/compat.hpp', > > > > + 'llvm/invocation.cpp', > > > > + 'llvm/invocation.hpp', > > > > + 'llvm/metadata.hpp', > > > > + 'llvm/util.hpp', > > > > + ), > > > > + include_directories : clover_incs, > > > > + cpp_args : [ > > > > + cpp_vis_args, > > > > + > > > > '-DLIBCLC_INCLUDEDIR="@0@"'.format(dep_clc.get_pkgconfig_variable('includedir')), > > > > + > > > > '-DLIBCLC_LIBEXECDIR="@0@"'.format(dep_clc.get_pkgconfig_variable('libexecdir')), > > > > > > The above directories need to have '/' appended otherwise loading of > > > libclc fails: > > > fatal error: cannot open file '/home/vesely/.local/lib/clcturks-r600 > > > --.bc': No such file or directory > > > > > > for some reason the fedora libclc package libexecdir ends with '/' > > > while the upstream does not. Other packages that I checked also > > > providevariables without the last slash. > > > clover/Makefile.am:47/48 appends '/' for autotools build. > > > > > > After fixing these I can run clinfo and a simple piglit using meson > > > build clover. > > > so with those fixed: > > > Tested-by: Jan Vesely <jan.ves...@rutgers.edu> > > > > > > remaining differences from autotools: > > > libdir is $prefix/lib64 instead of $prefix/lib, it might be just my old > > > autotools configuration. > > > as mentioned before, llvm-config $PATH and PKG_CONFIG_PATH need to be > > > set on every invocation, meson now at least warns when PKG_CONFIG_PATH > > > is different. > > > > That is a meson issue, I'm sorta the defacto meson llvm guy (I wrote the > > code > > and I seem to get all of the bug reports, lol) so if adding support for > > directly > > passing the path to llvm-config is okay with the maintainers I'll add > > support. > > So, please file a bug about the llvm-config :) > > is this the right place to report meson bugs?: > https://github.com/mesonbuild/meson/issues
That's the right place Dylan > > or is there a bugzilla somewhere? > > thanks, > Jan > > > > > Dylan > > > > > > > > thanks, > > > Jan > > > > > -- > Jan Vesely <jan.ves...@rutgers.edu>
signature.asc
Description: signature
_______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/mesa-dev