summaryrefslogtreecommitdiff
path: root/tools/qa
diff options
context:
space:
mode:
authorDr. David Alan Gilbert <dave@treblig.org>2020-09-27 03:14:51 +0100
committerTomaž Vajngerl <quikee@gmail.com>2020-09-28 13:22:11 +0200
commit15a5a56326761b79c9ea56b99a05faee457f1a1b (patch)
treea191724d2d460132d69b5b21b9ddfb2084c18883 /tools/qa
parentdc4ba0a287d0aebb8d99716025a316f113fee98d (diff)
Fix SSE2 cpuid checks
As per afb62b0e96e9bf91ec99857cc16ddb094bcaa3be swing the actual check into a separate file and make only that file be compiled with the specific flag. Change-Id: If848a041fc3a26cfaa79f945d63f6c43f8cf3772 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/103497 Tested-by: Jenkins Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
Diffstat (limited to 'tools/qa')
-rw-r--r--tools/qa/cppunit/test_cpu_runtime_detection_SSE2.cxx20
-rw-r--r--tools/qa/cppunit/test_cpu_runtime_detection_SSE2_check.cxx35
-rw-r--r--tools/qa/cppunit/test_cpu_runtime_detection_x86_checks.hxx1
3 files changed, 39 insertions, 17 deletions
diff --git a/tools/qa/cppunit/test_cpu_runtime_detection_SSE2.cxx b/tools/qa/cppunit/test_cpu_runtime_detection_SSE2.cxx
index 7455d0191844..6da1850a135a 100644
--- a/tools/qa/cppunit/test_cpu_runtime_detection_SSE2.cxx
+++ b/tools/qa/cppunit/test_cpu_runtime_detection_SSE2.cxx
@@ -9,7 +9,7 @@
#include <tools/simdsupport.hxx>
-#ifdef LO_SSE2_AVAILABLE
+#include "test_cpu_runtime_detection_x86_checks.hxx"
#include <cppunit/TestAssert.h>
#include <cppunit/TestFixture.h>
@@ -23,7 +23,6 @@ namespace
class CpuRuntimeDetection_SSE2 : public CppUnit::TestFixture
{
public:
- void checkSSE2();
void testCpuRuntimeDetection();
CPPUNIT_TEST_SUITE(CpuRuntimeDetection_SSE2);
@@ -33,26 +32,13 @@ public:
void CpuRuntimeDetection_SSE2::testCpuRuntimeDetection()
{
- // can only run if this function if CPU supports SSE2
+ // can only run this function if CPU supports SSE2
if (cpuid::isCpuInstructionSetSupported(cpuid::InstructionSetFlags::SSE2))
- checkSSE2();
-}
-
-void CpuRuntimeDetection_SSE2::checkSSE2()
-{
- // Try some SSE2 intrinsics calculation
- __m128i a = _mm_set1_epi32(15);
- __m128i b = _mm_set1_epi32(15);
- __m128i c = _mm_xor_si128(a, b);
-
- // Check zero
- CPPUNIT_ASSERT_EQUAL(0xFFFF, _mm_movemask_epi8(_mm_cmpeq_epi32(c, _mm_setzero_si128())));
+ CpuRuntimeDetectionX86Checks::checkSSE2();
}
CPPUNIT_TEST_SUITE_REGISTRATION(CpuRuntimeDetection_SSE2);
} // end anonymous namespace
-#endif
-
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/tools/qa/cppunit/test_cpu_runtime_detection_SSE2_check.cxx b/tools/qa/cppunit/test_cpu_runtime_detection_SSE2_check.cxx
new file mode 100644
index 000000000000..14bcc78717d8
--- /dev/null
+++ b/tools/qa/cppunit/test_cpu_runtime_detection_SSE2_check.cxx
@@ -0,0 +1,35 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+
+#include <sal/types.h>
+#include <tools/simdsupport.hxx>
+
+#include <cppunit/TestAssert.h>
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+#include <cppunit/plugin/TestPlugIn.h>
+
+#include <tools/cpuid.hxx>
+
+#include "test_cpu_runtime_detection_x86_checks.hxx"
+
+void CpuRuntimeDetectionX86Checks::checkSSE2()
+{
+#ifdef LO_SSE2_AVAILABLE
+ // Try some SSE2 intrinsics calculation
+ __m128i a = _mm_set1_epi32(15);
+ __m128i b = _mm_set1_epi32(15);
+ __m128i c = _mm_xor_si128(a, b);
+
+ // Check zero
+ CPPUNIT_ASSERT_EQUAL(0xFFFF, _mm_movemask_epi8(_mm_cmpeq_epi32(c, _mm_setzero_si128())));
+#endif
+}
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/tools/qa/cppunit/test_cpu_runtime_detection_x86_checks.hxx b/tools/qa/cppunit/test_cpu_runtime_detection_x86_checks.hxx
index 8321216c05b1..0046985acdeb 100644
--- a/tools/qa/cppunit/test_cpu_runtime_detection_x86_checks.hxx
+++ b/tools/qa/cppunit/test_cpu_runtime_detection_x86_checks.hxx
@@ -14,6 +14,7 @@ class CpuRuntimeDetectionX86Checks
{
public:
static void checkAVX2();
+ static void checkSSE2();
static void checkSSSE3();
};