[Mesa-dev] [PATCH 1/4] scons: Move fallback HAVE_* definitions to headers.

Jose Fonseca jfonseca at vmware.com
Fri Apr 22 19:06:49 UTC 2016


On 22/04/16 15:03, Roland Scheidegger wrote:
> Am 22.04.2016 um 10:35 schrieb Jose Fonseca:
>> These were being defined in SCons, but it's not practical:
>>
>> - we actually need to include Gallium headers from external source trees, with
>> completely disjoint build infrastructure, and it's unsustainable to
>> replicate the HAVE_xxx checks or even hard-coded defines across
>> everywhere.
>>
>> - checking compiler version via command line doesn't really work due to
>>    Clang essentially being like a cameleon which can fake either GCC or
>>    MSVC
>>
>> There's no change for autoconf.
>> ---
>>   include/c99_compat.h | 44 ++++++++++++++++++++++++++++++++++++++++++++
>>   scons/gallium.py     | 48 +++++-------------------------------------------
>>   src/util/macros.h    |  2 ++
>>   3 files changed, 51 insertions(+), 43 deletions(-)
>>
>> diff --git a/include/c99_compat.h b/include/c99_compat.h
>> index b55ad9c..bfe655b 100644
>> --- a/include/c99_compat.h
>> +++ b/include/c99_compat.h
>> @@ -135,4 +135,48 @@ test_c99_compat_h(const void * restrict a,
>>   #endif
>>
>>
>> +/* Fallback definitions, for build systems other than autoconfig which don't
>> + * auto-detect these things. */
>> +#ifdef HAVE_NO_AUTOCONF
>> +
>> +#  ifndef _WIN32
>> +#    define HAVE_PTHREAD
>> +#    define HAVE_POSIX_MEMALIGN
>> +#  endif
>> +
>> +#  ifdef __GNUC__
>> +#    if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 2)
>> +#      error "GCC version 4.2 or higher required"
>> +#    endif
>> +
>> +     /* https://gcc.gnu.org/onlinedocs/gcc-4.2.4/gcc/Other-Builtins.html */
>> +#    define HAVE___BUILTIN_CLZ 1
>> +#    define HAVE___BUILTIN_CLZLL 1
>> +#    define HAVE___BUILTIN_CTZ 1
>> +#    define HAVE___BUILTIN_EXPECT 1
>> +#    define HAVE___BUILTIN_FFS 1
>> +#    define HAVE___BUILTIN_FFSLL 1
>> +#    define HAVE___BUILTIN_POPCOUNT 1
>> +#    define HAVE___BUILTIN_POPCOUNTLL 1
>> +     /* https://gcc.gnu.org/onlinedocs/gcc-4.2.4/gcc/Function-Attributes.html */
>> +#    define HAVE_FUNC_ATTRIBUTE_FLATTEN 1
>> +#    define HAVE_FUNC_ATTRIBUTE_UNUSED 1
>> +#    define HAVE_FUNC_ATTRIBUTE_FORMAT 1
>> +#    define HAVE_FUNC_ATTRIBUTE_PACKED 1
>> +
>> +#    if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)
>> +       /* https://gcc.gnu.org/onlinedocs/gcc-4.3.6/gcc/Other-Builtins.html */
>> +#      define HAVE___BUILTIN_BSWAP32 1
>> +#      define HAVE___BUILTIN_BSWAP64 1
>> +#    endif
>> +
>> +#    if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5)
>> +#      define HAVE___BUILTIN_UNREACHABLE 1
>> +#    endif
>> +
>> +#  endif /* __GNUC__ */
>> +
>> +#endif /* !HAVE_AUTOCONF */
>> +
>> +
>>   #endif /* _C99_COMPAT_H_ */
> Is that the right file for putting them in?

I could put them in a seperate header.

The ideal would be for autotools to generate "mesa_config.h" somewhere 
with all the #defines instead of passing -DHAVE foo in the command line. 
  In that case, Scons would use a handwritten mesa_config.h with the the 
above definitions, and would use it by merely adding it's include path.

But until that happens it doesn't make much difference.

> But either way, for the series:
> Reviewed-by: Roland Scheidegger <sroland at vmware.com>

Thanks.

Jose


More information about the mesa-dev mailing list