]> git.ipfire.org Git - thirdparty/vectorscan.git/commitdiff
hs_valid_platform: Fix check for SSE4.2 (#310)
authorMichael Tremer <michael.tremer@ipfire.org>
Thu, 22 Aug 2024 07:34:05 +0000 (08:34 +0100)
committerGitHub <noreply@github.com>
Thu, 22 Aug 2024 07:34:05 +0000 (10:34 +0300)
Vectorscan requires SSE4.2 as a minimum on x86_64. For Hyperscan this
used to be SSSE3.

Applications that use the library call hs_valid_platform() to check if
the CPU fulfils this minimum requirement. However, when Vectorscan
upgraded to SSE4.2, the check was not updated. This leads to the library
trying to execute instructions that are not supported, resulting in the
application to crash.

This might not have been noticed as the CPUs that do not support SSE4.2
are rather old and unlikely to run any load where performance is an
issue. However, I believe that the library should not let the
application crash.

Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
src/hs_valid_platform.c

index b1d44ff4b144bd89c2556f305439a9e2ceded2ef..4ab42df35caf3ac933f80a7733f1d664b7c7133f 100644 (file)
 
 HS_PUBLIC_API
 hs_error_t HS_CDECL hs_valid_platform(void) {
-    /* Hyperscan requires SSSE3, anything else is a bonus */
+    /* Vectorscan requires SSE4.2, anything else is a bonus */
 #if !defined(VS_SIMDE_BACKEND) && (defined(ARCH_IA32) || defined(ARCH_X86_64))
     // cppcheck-suppress knownConditionTrueFalse
-    if (check_ssse3()) {
+    if (check_sse42()) {
         return HS_SUCCESS;
     } else {
         return HS_ARCH_ERROR;