Sanitize QT_COMPILER_SUPPORTS_xxx in qcompilerdetection.h
... instead of scoping the defines in qconfig.h, which relied on the Q_PROCESSOR_xxx defines and meant that we had to include qconfig.h after qprocessordetection.h, which added a whole bunch of other dependency issues. We now let configure write QT_COMPILER_SUPPORTS_xxx to qconfig.h as before, without any scoping, and then undefine the ones that don't apply for the given processor. This means we need to include qprocessordetection.h before qcompilerdetection.h in qglobal.h, but the former does not depend on the latter, so this should be fine. Change-Id: If00c00d405463e9626fa0f7f5e6b17f68778904f Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@digia.com>
This commit is contained in:
parent
95fe97dbcb
commit
1b2d3be446
28
configure
vendored
28
configure
vendored
@ -6207,28 +6207,16 @@ fi
|
||||
# Add compiler sub-architecture support
|
||||
echo "" >>"$outpath/src/corelib/global/qconfig.h.new"
|
||||
echo "// Compiler sub-arch support" >>"$outpath/src/corelib/global/qconfig.h.new"
|
||||
for SUBARCH in X86: SSE2 SSE3 SSSE3 SSE4_1 SSE4_2 AVX AVX2 : \
|
||||
ARM: IWMMXT NEON : \
|
||||
MIPS: MIPS_DSP MIPS_DSPR2 :
|
||||
do
|
||||
line=""
|
||||
case $SUBARCH in
|
||||
:)
|
||||
line="#endif"
|
||||
;;
|
||||
*:)
|
||||
line="#ifdef Q_PROCESSOR_$(echo $SUBARCH | sed 's/:$//')"
|
||||
;;
|
||||
*)
|
||||
eval "VAL=\$CFG_$SUBARCH"
|
||||
case "$VAL" in
|
||||
yes)
|
||||
line=" #define QT_COMPILER_SUPPORTS_$SUBARCH"
|
||||
;;
|
||||
esac
|
||||
for SUBARCH in SSE2 SSE3 SSSE3 SSE4_1 SSE4_2 AVX AVX2 \
|
||||
IWMMXT NEON \
|
||||
MIPS_DSP MIPS_DSPR2; do
|
||||
eval "VAL=\$CFG_$SUBARCH"
|
||||
case "$VAL" in
|
||||
yes)
|
||||
echo "#define QT_COMPILER_SUPPORTS_$SUBARCH" \
|
||||
>>"$outpath/src/corelib/global/qconfig.h.new"
|
||||
;;
|
||||
esac
|
||||
[ -n "$line" ] && echo "$line" >>"$outpath/src/corelib/global/qconfig.h.new"
|
||||
done
|
||||
|
||||
echo "" >>"$outpath/src/corelib/global/qconfig.h.new"
|
||||
|
@ -877,4 +877,26 @@
|
||||
Q_UNUSED(valueOfExpression); /* the value may not be used if Q_ASSERT_X and Q_ASSUME_IMPL are noop */\
|
||||
} while (0)
|
||||
|
||||
|
||||
/*
|
||||
Sanitize compiler feature availability
|
||||
*/
|
||||
#if !defined(Q_PROCESSOR_X86)
|
||||
# undef QT_COMPILER_SUPPORTS_SSE2
|
||||
# undef QT_COMPILER_SUPPORTS_SSE3
|
||||
# undef QT_COMPILER_SUPPORTS_SSSE3
|
||||
# undef QT_COMPILER_SUPPORTS_SSE4_1
|
||||
# undef QT_COMPILER_SUPPORTS_SSE4_2
|
||||
# undef QT_COMPILER_SUPPORTS_AVX
|
||||
# undef QT_COMPILER_SUPPORTS_AVX2
|
||||
#endif
|
||||
#if !defined(Q_PROCESSOR_ARM)
|
||||
# undef QT_COMPILER_SUPPORTS_IWMMXT
|
||||
# undef QT_COMPILER_SUPPORTS_NEON
|
||||
#endif
|
||||
#if !defined(Q_PROCESSOR_MIPS)
|
||||
# undef QT_COMPILER_SUPPORTS_MIPS_DSP
|
||||
# undef QT_COMPILER_SUPPORTS_MIPS_DSPR2
|
||||
#endif
|
||||
|
||||
#endif // QCOMPILERDETECTION_H
|
||||
|
@ -68,8 +68,8 @@
|
||||
#define QT_STRINGIFY(x) QT_STRINGIFY2(x)
|
||||
|
||||
#include <QtCore/qsystemdetection.h>
|
||||
#include <QtCore/qcompilerdetection.h>
|
||||
#include <QtCore/qprocessordetection.h>
|
||||
#include <QtCore/qcompilerdetection.h>
|
||||
|
||||
#if defined (__ELF__)
|
||||
# define Q_OF_ELF
|
||||
|
Loading…
Reference in New Issue
Block a user