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:
Tor Arne Vestbø 2013-04-29 13:26:58 +02:00 committed by The Qt Project
parent 95fe97dbcb
commit 1b2d3be446
3 changed files with 31 additions and 21 deletions

28
configure vendored
View File

@ -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"

View File

@ -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

View File

@ -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