appveyor.yml: add a /arch:AVX2 config on Windows
authorEven Rouault <even.rouault@spatialys.com>
Sat, 1 Jul 2017 00:53:55 +0000 (02:53 +0200)
committerEven Rouault <even.rouault@spatialys.com>
Sat, 1 Jul 2017 08:00:57 +0000 (10:00 +0200)
Try running the tests if the CPU supports AVX2.

appveyor.yml
tools/travis-ci/detect-avx2.c [new file with mode: 0644]
tools/travis-ci/run.sh

index b55fc07c6d084d60131366b28f7ddbfc6878a13a..6b04e22c7d9bef59c25ed86dcf5d5d5b51f763c4 100644 (file)
@@ -6,6 +6,9 @@ skip_tags: false
 clone_depth: 50
 environment:
   matrix:
+  - OPJ_CI_ARCH: x64
+    OPJ_CI_VSCOMNTOOLS: $(VS140COMNTOOLS)
+    OPJ_CI_INSTRUCTION_SETS: "/arch:AVX2"
   - OPJ_CI_ARCH: x86
     OPJ_CI_VSCOMNTOOLS: $(VS140COMNTOOLS)
     OPJ_CI_INCLUDE_IF_DEPLOY: 1
diff --git a/tools/travis-ci/detect-avx2.c b/tools/travis-ci/detect-avx2.c
new file mode 100644 (file)
index 0000000..b998c2e
--- /dev/null
@@ -0,0 +1,152 @@
+/*
+ * The copyright in this software is being made available under the 2-clauses
+ * BSD License, included below. This software may be subject to other third
+ * party and contributor rights, including patent rights, and no such rights
+ * are granted under this license.
+ *
+ * Copyright (c) 2017, IntoPIX SA <support@intopix.com>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#define CPUID_SSSE3_ECX_BIT     9
+#define CPUID_OSXSAVE_ECX_BIT   27
+#define CPUID_AVX_ECX_BIT       28
+
+#define CPUID_AVX2_EBX_BIT      5
+
+#define CPUID_SSE_EDX_BIT       25
+
+#define BIT_XMM_STATE           (1 << 1)
+#define BIT_YMM_STATE           (2 << 1)
+
+#define REG_EAX                 0
+#define REG_EBX                 1
+#define REG_ECX                 2
+#define REG_EDX                 3
+
+#if defined(__GNUC__) && (defined(__i386__) ||defined(__x86_64))
+
+#include <cpuid.h>
+
+#define CPL_CPUID(level, subfunction, array) __cpuid_count(level, subfunction, array[0], array[1], array[2], array[3])
+
+#elif defined(_MSC_VER) && (defined(_M_IX86) || defined(_M_X64))
+
+#include <intrin.h>
+
+#define CPL_CPUID(level, subfunction, array) __cpuidex(array, level, subfunction)
+
+#else
+
+#error "not supported"
+
+#endif
+
+#if defined(__GNUC__) && (defined(__i386__) ||defined(__x86_64))
+
+int CPLHaveRuntimeAVX()
+{
+    int cpuinfo[4] = { 0, 0, 0, 0 };
+    unsigned int nXCRLow;
+    unsigned int nXCRHigh;
+
+    CPL_CPUID(1, 0, cpuinfo);
+
+    // Check OSXSAVE feature.
+    if ((cpuinfo[REG_ECX] & (1 << CPUID_OSXSAVE_ECX_BIT)) == 0) {
+        return 0;
+    }
+
+    // Check AVX feature.
+    if ((cpuinfo[REG_ECX] & (1 << CPUID_AVX_ECX_BIT)) == 0) {
+        return 0;
+    }
+
+    // Issue XGETBV and check the XMM and YMM state bit.
+
+    __asm__("xgetbv" : "=a"(nXCRLow), "=d"(nXCRHigh) : "c"(0));
+    if ((nXCRLow & (BIT_XMM_STATE | BIT_YMM_STATE)) !=
+            (BIT_XMM_STATE | BIT_YMM_STATE)) {
+        return 0;
+    }
+
+    return 1;
+}
+
+#elif defined(_MSC_FULL_VER) && (_MSC_FULL_VER >= 160040219) && (defined(_M_IX86) || defined(_M_X64))
+// _xgetbv available only in Visual Studio 2010 SP1 or later
+
+int CPLHaveRuntimeAVX()
+{
+    int cpuinfo[4] = { 0, 0, 0, 0 };
+    unsigned __int64 xcrFeatureMask;
+
+    CPL_CPUID(1, 0, cpuinfo);
+
+    // Check OSXSAVE feature.
+    if ((cpuinfo[REG_ECX] & (1 << CPUID_OSXSAVE_ECX_BIT)) == 0) {
+        return 0;
+    }
+
+    // Check AVX feature.
+    if ((cpuinfo[REG_ECX] & (1 << CPUID_AVX_ECX_BIT)) == 0) {
+        return 0;
+    }
+
+    // Issue XGETBV and check the XMM and YMM state bit.
+    xcrFeatureMask = _xgetbv(_XCR_XFEATURE_ENABLED_MASK);
+    if ((xcrFeatureMask & (BIT_XMM_STATE | BIT_YMM_STATE)) !=
+            (BIT_XMM_STATE | BIT_YMM_STATE)) {
+        return 0;
+    }
+
+    return 1;
+}
+
+#endif
+
+int CPLHaveRuntimeAVX2()
+{
+    int cpuinfo[4] = { 0, 0, 0, 0 };
+    if (!CPLHaveRuntimeAVX()) {
+        return 0;
+    }
+
+    CPL_CPUID(7, 0, cpuinfo);
+
+    // Check AVX2 feature.
+    if ((cpuinfo[REG_EBX] & (1 << CPUID_AVX2_EBX_BIT)) == 0) {
+        return 0;
+    }
+
+    return 1;
+}
+
+int main()
+{
+    if (CPLHaveRuntimeAVX2()) {
+        return 0;
+    }
+    return 1;
+}
index ac21dfe74e215485dd8cbd7ad11970901fdf47a6..5118657bc35270e395206b2ee1c902d891c2c9cd 100755 (executable)
@@ -142,6 +142,15 @@ elif [ "${TRAVIS_OS_NAME}" == "windows" ]; then
                        OPJ_CC_VERSION=vs????
                fi
        fi
+       if [ "${OPJ_CI_INSTRUCTION_SETS-:}" == "/arch:AVX2" ]; then
+               cl $PWD/tools/travis-ci/detect-avx2.c
+               if ./detect-avx2.exe; then
+                       echo "AVX2 available on CPU"
+               else
+                       echo "AVX2 not available on CPU. Disabling tests"
+                       export OPJ_CI_SKIP_TESTS=1
+               fi
+       fi
 else
        echo "OS not supported: ${TRAVIS_OS_NAME}"; exit 1
 fi