[Mesa-dev] [PATCH 3/5] meson: Override C++ standard to gnu++11 when building with altivec on ppc64le

Eric Engestrom eric.engestrom at intel.com
Wed Dec 5 11:22:52 UTC 2018


On Tuesday, 2018-12-04 13:52:19 -0800, Dylan Baker wrote:
> Otherwise there will be symbol collisions for the vector name.
> 
> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=108943
> Fixes: 34bbb24ce7702658cdc4e9d34a650e169716c39e
>        ("meson: Add support for ppc assembly/optimizations")
> ---
>  meson.build                                   | 12 ++++++++++++
>  src/gallium/state_trackers/clover/meson.build |  3 +++
>  2 files changed, 15 insertions(+)
> 
> diff --git a/meson.build b/meson.build
> index 3d07c88364a..0785609c4b0 100644
> --- a/meson.build
> +++ b/meson.build
> @@ -624,6 +624,7 @@ if with_gallium_st_nine
>    endif
>  endif
>  
> +clover_cpp_std = []
>  if get_option('power8') != 'false'
>    # on old versions of meson the cpu family would return as ppc64le on little
>    # endian power8, this was changed in 0.48 such that the family would always
> @@ -631,6 +632,7 @@ if get_option('power8') != 'false'
>    # should be checked. Since we support versions < 0.48 we need to use
>    # startswith.
>    if host_machine.cpu_family().startswith('ppc64') and host_machine.endian() == 'little'
> +    _test_args = []
>      if cc.get_id() == 'gcc' and cc.version().version_compare('< 4.8')
>        error('Altivec is not supported with gcc version < 4.8.')
>      endif
> @@ -645,9 +647,19 @@ if get_option('power8') != 'false'
>          args : '-mpower8-vector',
>          name : 'POWER8 intrinsics')
>        pre_args += ['-D_ARCH_PWR8', '-mpower8-vector']
> +      _test_args += ['-D_ARCH_PWR8', '-mpower8-vector']
>      elif get_option('power8') == 'true'
>        error('POWER8 intrinsic support required but not found.')
>      endif
> +
> +    if cpp.compiles('''
> +        #if !defined(__VEC__) || !defined(__ALTIVEC__)
> +        #error "AltiVec not enabled"
> +        #endif''',
> +        args : _test_args,
> +        name : 'Altivec')
> +      clover_cpp_std += ['cpp_std=gnu++11']
> +    endif

This doesn't look quite right, but I don't trust my brain right now;
I'll have a look at it again later.

In the mean time, the rest of this series is:
Reviewed-by: Eric Engestrom <eric.engestrom at intel.com>

>    endif
>  endif
>  
> diff --git a/src/gallium/state_trackers/clover/meson.build b/src/gallium/state_trackers/clover/meson.build
> index 1a09d8f2ca9..a6729af2fb8 100644
> --- a/src/gallium/state_trackers/clover/meson.build
> +++ b/src/gallium/state_trackers/clover/meson.build
> @@ -30,6 +30,7 @@ libcltgsi = static_library(
>    files('tgsi/compiler.cpp', 'tgsi/invocation.hpp'),
>    include_directories : clover_incs,
>    cpp_args : [cpp_vis_args],
> +  override_options : clover_cpp_std,
>  )
>  
>  libclllvm = static_library(
> @@ -56,6 +57,7 @@ libclllvm = static_library(
>      )),
>    ],
>    dependencies : [dep_llvm, dep_elf],
> +  override_options : clover_cpp_std,
>  )
>  
>  clover_files = files(
> @@ -119,4 +121,5 @@ libclover = static_library(
>    include_directories : clover_incs,
>    cpp_args : [clover_cpp_args, cpp_vis_args],
>    link_with : [libcltgsi, libclllvm],
> +  override_options : clover_cpp_std,
>  )
> -- 
> 2.19.2
> 
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list