2012-02-14 09:01:17 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2014-08-21 13:51:22 +00:00
|
|
|
** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
|
2012-03-27 17:43:45 +00:00
|
|
|
** Copyright (C) 2012 Intel Corporation
|
2012-09-19 12:28:29 +00:00
|
|
|
** Contact: http://www.qt-project.org/legal
|
2012-02-14 09:01:17 +00:00
|
|
|
**
|
|
|
|
** This file is part of the FOO module of the Qt Toolkit.
|
|
|
|
**
|
2014-08-21 13:51:22 +00:00
|
|
|
** $QT_BEGIN_LICENSE:LGPL21$
|
2012-09-19 12:28:29 +00:00
|
|
|
** Commercial License Usage
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2014-08-21 13:51:22 +00:00
|
|
|
** a written agreement between you and Digia. For licensing terms and
|
|
|
|
** conditions see http://qt.digia.com/licensing. For further information
|
2012-09-19 12:28:29 +00:00
|
|
|
** use the contact form at http://qt.digia.com/contact-us.
|
|
|
|
**
|
2012-02-14 09:01:17 +00:00
|
|
|
** GNU Lesser General Public License Usage
|
2012-09-19 12:28:29 +00:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
2014-08-21 13:51:22 +00:00
|
|
|
** General Public License version 2.1 or version 3 as published by the Free
|
|
|
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
|
|
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
|
|
|
** following information to ensure the GNU Lesser General Public License
|
|
|
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
|
|
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
2012-09-19 12:28:29 +00:00
|
|
|
**
|
|
|
|
** In addition, as a special exception, Digia gives you certain additional
|
2014-08-21 13:51:22 +00:00
|
|
|
** rights. These rights are described in the Digia Qt LGPL Exception
|
2012-02-14 09:01:17 +00:00
|
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
2012-03-28 19:28:46 +00:00
|
|
|
#define QGLOBAL_H
|
2014-03-06 20:58:21 +00:00
|
|
|
#include "../../src/corelib/global/archdetect.cpp"
|
2012-03-27 17:43:45 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
extern const char msg[];
|
2014-03-06 20:58:21 +00:00
|
|
|
const char msg[] = "==Qt=magic=Qt== Architecture:" ARCH_PROCESSOR;
|
2012-03-27 17:43:45 +00:00
|
|
|
|
2011-12-31 22:40:49 +00:00
|
|
|
extern const char msg2[];
|
|
|
|
const char msg2[] = "==Qt=magic=Qt== Sub-architecture:"
|
|
|
|
// This is the list of features found in GCC or MSVC
|
|
|
|
// We don't use all of them, but this is ready for future expansion
|
|
|
|
|
|
|
|
// -- x86 --
|
|
|
|
#ifdef __3dNOW__
|
|
|
|
// 3dNow!, introduced with the AMD K6-2, discontinued after 2010
|
|
|
|
" 3dnow"
|
|
|
|
#endif
|
|
|
|
#ifdef __3dNOW_A__
|
|
|
|
// Athlon
|
|
|
|
" 3dnow-a"
|
|
|
|
#endif
|
|
|
|
#ifdef __ABM__
|
|
|
|
// Advanced Bit Manipulation, AMD Barcelona (family 10h)
|
|
|
|
" abm"
|
|
|
|
#endif
|
|
|
|
#ifdef __AES__
|
|
|
|
// AES New Instructions, Intel Core-i7 second generation ("Sandy Bridge")
|
|
|
|
" aes"
|
|
|
|
#endif
|
|
|
|
#ifdef __AVX__
|
|
|
|
// Advanced Vector Extensions, Intel Core-i7 second generation ("Sandy Bridge")
|
|
|
|
" avx"
|
|
|
|
#endif
|
|
|
|
#ifdef __AVX2__
|
2013-08-06 23:04:50 +00:00
|
|
|
// AVX 2, Intel Core 4th Generation ("Haswell")
|
2011-12-31 22:40:49 +00:00
|
|
|
" avx2"
|
|
|
|
#endif
|
2013-08-06 23:24:57 +00:00
|
|
|
#ifdef __AVX512F__
|
|
|
|
// AVX512 Foundation, Intel Xeon Phi codename "Knights Landing"
|
|
|
|
" avx512f"
|
|
|
|
#endif
|
|
|
|
#ifdef __AVX512CD__
|
|
|
|
// AVX512 Conflict Detection, Intel Xeon Phi codename "Knights Landing"
|
|
|
|
" avx512cd"
|
|
|
|
#endif
|
2014-07-30 16:53:01 +00:00
|
|
|
#ifdef __AVX512DQ__
|
|
|
|
// AVX512 Double & Quadword, future Intel Xeon processor
|
|
|
|
" avx512dq"
|
|
|
|
#endif
|
|
|
|
#ifdef __AVX512BW__
|
|
|
|
// AVX512 Byte & Word, future Intel Xeon processor
|
|
|
|
" avx512bw"
|
|
|
|
#endif
|
2013-08-06 23:24:57 +00:00
|
|
|
#ifdef __AVX512ER__
|
|
|
|
// AVX512 Exponentiation & Reciprocal, Intel Xeon Phi codename "Knights Landing"
|
|
|
|
" avx512ef"
|
|
|
|
#endif
|
|
|
|
#ifdef __AVX512PF__
|
|
|
|
// AVX512 Prefetch, Intel Xeon Phi codename "Knights Landing"
|
|
|
|
" avx512pf"
|
|
|
|
#endif
|
2014-07-30 16:53:01 +00:00
|
|
|
#ifdef __AVX512VL__
|
|
|
|
// AVX512 Vector Length, future Intel Xeon processor
|
|
|
|
" avx512vl"
|
|
|
|
#endif
|
2011-12-31 22:40:49 +00:00
|
|
|
#ifdef __BMI__
|
2013-08-06 23:04:50 +00:00
|
|
|
// Bit Manipulation Instructions 1, Intel Core 4th Generation ("Haswell"), AMD "Bulldozer 2"
|
2011-12-31 22:40:49 +00:00
|
|
|
" bmi"
|
|
|
|
#endif
|
|
|
|
#ifdef __BMI2__
|
2013-08-06 23:04:50 +00:00
|
|
|
// Bit Manipulation Instructions 2, Intel Core 4th Generation ("Haswell")
|
2011-12-31 22:40:49 +00:00
|
|
|
" bmi2"
|
|
|
|
#endif
|
|
|
|
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_16
|
|
|
|
// cmpxchg16b instruction, Intel Pentium 4 64-bit ("Nocona"), AMD Barcelona (family 10h)
|
|
|
|
// Notably, this instruction is missing on earlier AMD Athlon 64
|
|
|
|
" cx16"
|
|
|
|
#endif
|
|
|
|
#ifdef __F16C__
|
2013-08-06 23:04:50 +00:00
|
|
|
// 16-bit floating point conversion, Intel Core 3rd Generation ("Ivy Bridge")
|
2011-12-31 22:40:49 +00:00
|
|
|
" f16c"
|
|
|
|
#endif
|
|
|
|
#ifdef __FMA__
|
2013-08-06 23:04:50 +00:00
|
|
|
// Fused Multiply-Add with 3 arguments, Intel Core 4th Generation ("Haswell"), AMD "Bulldozer 2"
|
2011-12-31 22:40:49 +00:00
|
|
|
// a.k.a. "FMA3"
|
|
|
|
" fma"
|
|
|
|
#endif
|
|
|
|
#ifdef __FMA4__
|
|
|
|
// Fused Multiply-Add with 4 arguments, AMD "Bulldozer"
|
|
|
|
" fma4"
|
|
|
|
#endif
|
|
|
|
#ifdef __FSGSBASE__
|
2013-08-06 23:04:50 +00:00
|
|
|
// rdfsgsbase, wrfsgsbase, Intel Core 3rd Generation ("Ivy Bridge")
|
2011-12-31 22:40:49 +00:00
|
|
|
" fsgsbase"
|
|
|
|
#endif
|
|
|
|
#ifdef __LWP__
|
|
|
|
// LWP instructions, AMD "Bulldozer"
|
|
|
|
" lwp"
|
|
|
|
#endif
|
|
|
|
#ifdef __LZCNT__
|
2013-08-06 23:04:50 +00:00
|
|
|
// Leading-Zero bit count, Intel Core 4th Generation ("Haswell")
|
2011-12-31 22:40:49 +00:00
|
|
|
" lzcnt"
|
|
|
|
#endif
|
|
|
|
#ifdef __MMX__
|
|
|
|
// Multimedia Extensions, Pentium MMX, AMD K6-2
|
|
|
|
" mmx"
|
|
|
|
#endif
|
|
|
|
#ifdef __MOVBE__
|
|
|
|
// Move Big Endian, Intel Atom & "Haswell"
|
|
|
|
" movbe"
|
|
|
|
#endif
|
|
|
|
#ifdef __NO_SAHF__
|
|
|
|
// missing SAHF instruction in 64-bit, up to Intel Pentium 4 64-bit ("Nocona"), AMD Athlon FX
|
|
|
|
// Note: the macro is not defined, so this will never show up
|
|
|
|
" no-sahf"
|
|
|
|
#endif
|
|
|
|
#ifdef __PCLMUL__
|
|
|
|
// (Packed) Carry-less multiplication, Intel Core-i7 second generation ("Sandy Bridge")
|
|
|
|
" pclmul"
|
|
|
|
#endif
|
|
|
|
#ifdef __POPCNT__
|
|
|
|
// Population Count (count of set bits), Intel Core-i7 second generation ("Sandy Bridge")
|
|
|
|
" popcnt"
|
|
|
|
#endif
|
|
|
|
#ifdef __RDRND__
|
2013-08-06 23:04:50 +00:00
|
|
|
// Random number generator, Intel Core 3rd Generation ("Ivy Bridge")
|
2011-12-31 22:40:49 +00:00
|
|
|
" rdrnd"
|
|
|
|
#endif
|
2013-08-06 23:24:57 +00:00
|
|
|
#ifdef __SHA__
|
|
|
|
// SHA-1 and SHA-256 instructions, Intel processor TBA
|
|
|
|
" sha"
|
|
|
|
#endif
|
2011-12-31 22:40:49 +00:00
|
|
|
#if defined(__SSE__) || (defined(_M_IX86_FP) && _M_IX86_FP >= 1) || defined(_M_X64)
|
|
|
|
// Streaming SIMD Extensions, Intel Pentium III, AMD Athlon
|
|
|
|
" sse"
|
|
|
|
#endif
|
|
|
|
#if defined(__SSE2__) || (defined(_M_IX86_FP) && _M_IX86_FP >= 2) || defined(_M_X64)
|
|
|
|
// SSE2, Intel Pentium-M, Intel Pentium 4, AMD Opteron and Athlon 64
|
|
|
|
" sse2"
|
|
|
|
#endif
|
|
|
|
#ifdef __SSE3__
|
|
|
|
// SSE3, Intel Pentium 4 "Prescott", AMD Athlon 64 rev E
|
|
|
|
" sse3"
|
|
|
|
#endif
|
|
|
|
#ifdef __SSSE3__
|
2012-06-12 12:44:24 +00:00
|
|
|
// Supplemental SSE3, Intel Core 2 ("Merom"), AMD "Bulldozer"
|
2011-12-31 22:40:49 +00:00
|
|
|
" ssse3"
|
|
|
|
#endif
|
|
|
|
#ifdef __SSE4A__
|
|
|
|
// SSE4a, AMD Barcelona
|
|
|
|
" sse4a"
|
|
|
|
#endif
|
|
|
|
#ifdef __SSE4_1__
|
2012-06-12 12:44:24 +00:00
|
|
|
// SSE 4.1, Intel Core2 45nm shrink ("Penryn"), AMD "Bulldozer"
|
2011-12-31 22:40:49 +00:00
|
|
|
" sse4.1"
|
|
|
|
#endif
|
|
|
|
#ifdef __SSE4_2__
|
|
|
|
// SSE 4.2, Intel Core-i7 ("Nehalem"), AMD "Bulldozer"
|
|
|
|
" sse4.2"
|
|
|
|
// Since no processor supports SSE4.2 without 4.1 and since no Intel processor
|
|
|
|
// supports SSE4a, define "sse4" to indicate SSE4"
|
|
|
|
" sse4"
|
|
|
|
#endif
|
|
|
|
#ifdef __TBM__
|
|
|
|
// TBM, AMD "Bulldozer"
|
|
|
|
" tbm"
|
|
|
|
#endif
|
|
|
|
#ifdef __XOP__
|
|
|
|
// XOP, AMD "Bulldozer"
|
|
|
|
" xop"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// -- ARM --
|
|
|
|
#ifdef __ARM_NEON__
|
|
|
|
" neon"
|
|
|
|
#endif
|
|
|
|
#ifdef __IWMMXT__
|
|
|
|
" iwmmxt"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// -- SPARC --
|
|
|
|
#ifdef __VIS__
|
|
|
|
" vis"
|
|
|
|
# if __VIS__ >= 0x200
|
|
|
|
" vis2"
|
|
|
|
# endif
|
|
|
|
# if __VIS__ >= 0x300
|
|
|
|
" vis3"
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// -- MIPS --
|
2012-07-20 13:03:56 +00:00
|
|
|
# if __mips_dsp
|
|
|
|
" dsp"
|
|
|
|
# endif
|
|
|
|
# if __mips_dspr2
|
|
|
|
" dspr2"
|
|
|
|
# endif
|
2011-12-31 22:40:49 +00:00
|
|
|
|
|
|
|
// -- POWER, PowerPC --
|
|
|
|
#ifdef __ALTIVEC__
|
|
|
|
" altivec"
|
|
|
|
#endif
|
|
|
|
"";
|
|
|
|
|
2012-03-27 17:43:45 +00:00
|
|
|
int main()
|
|
|
|
{
|
|
|
|
puts(msg);
|
2011-12-31 22:40:49 +00:00
|
|
|
puts(msg2);
|
2012-03-27 17:43:45 +00:00
|
|
|
}
|