Skip to content

Commit

Permalink
memcmp: remove unreachable code from memcmp simd
Browse files Browse the repository at this point in the history
cppcheck:

src/util-memcmp.h:281:18: warning: Identical condition 'len-offset<16', second condition is always false [identicalConditionAfterEarlyExit]
        if (diff < 16) {
                 ^
src/util-memcmp.h:280:24: note: 'diff' is assigned value 'len-offset' here.
        int diff = len - offset;
                       ^
src/util-memcmp.h:269:33: note: If condition 'len-offset<16' is true, the function will return/exit
        if (likely(len - offset < 16)) {
                                ^
src/util-memcmp.h:281:18: note: Testing identical condition 'len-offset<16'
        if (diff < 16) {
                 ^
src/util-memcmp.h:344:18: warning: Identical condition 'len-offset<16', second condition is always false [identicalConditionAfterEarlyExit]
        if (diff < 16) {
                 ^
src/util-memcmp.h:343:24: note: 'diff' is assigned value 'len-offset' here.
        int diff = len - offset;
                       ^
src/util-memcmp.h:318:33: note: If condition 'len-offset<16' is true, the function will return/exit
        if (likely(len - offset < 16)) {
                                ^
src/util-memcmp.h:344:18: note: Testing identical condition 'len-offset<16'
        if (diff < 16) {
                 ^
src/util-memcmp.h:171:18: warning: Identical condition 'len-offset<16', second condition is always false [identicalConditionAfterEarlyExit]
        if (diff < 16) {
                 ^
src/util-memcmp.h:170:24: note: 'diff' is assigned value 'len-offset' here.
        int diff = len - offset;
                       ^
src/util-memcmp.h:159:33: note: If condition 'len-offset<16' is true, the function will return/exit
        if (likely(len - offset < 16)) {
                                ^
src/util-memcmp.h:171:18: note: Testing identical condition 'len-offset<16'
        if (diff < 16) {
                 ^
src/util-memcmp.h:233:18: warning: Identical condition 'len-offset<16', second condition is always false [identicalConditionAfterEarlyExit]
        if (diff < 16) {
                 ^
src/util-memcmp.h:232:24: note: 'diff' is assigned value 'len-offset' here.
        int diff = len - offset;
                       ^
src/util-memcmp.h:208:33: note: If condition 'len-offset<16' is true, the function will return/exit
        if (likely(len - offset < 16)) {
                                ^
src/util-memcmp.h:233:18: note: Testing identical condition 'len-offset<16'
        if (diff < 16) {
                 ^
  • Loading branch information
victorjulien committed May 6, 2022
1 parent 9bdf18a commit ca97ed4
Showing 1 changed file with 10 additions and 46 deletions.
56 changes: 10 additions & 46 deletions src/util-memcmp.h
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Copyright (C) 2007-2013 Open Information Security Foundation
/* Copyright (C) 2007-2022 Open Information Security Foundation
*
* You can copy, redistribute or modify this Program under the terms of
* the GNU General Public License version 2 as published by the Free
Expand All @@ -20,7 +20,7 @@
*
* \author Victor Julien <[email protected]>
*
* Memcmp implementations for SSE3, SSE4.1, SSE4.2 and TILE-Gx SIMD.
* Memcmp implementations for SSE3, SSE4.1, SSE4.2.
*
* Both SCMemcmp and SCMemcmpLowercase return 0 on a exact match,
* 1 on a failed match.
Expand Down Expand Up @@ -167,17 +167,8 @@ static inline int SCMemcmp(const void *s1, const void *s2, size_t len)
b2 = _mm_loadu_si128((const __m128i *) s2);
c = _mm_cmpeq_epi8(b1, b2);

int diff = len - offset;
if (diff < 16) {
int rmask = ~(0xFFFFFFFF << diff);

if ((_mm_movemask_epi8(c) & rmask) != rmask) {
return 1;
}
} else {
if (_mm_movemask_epi8(c) != 0x0000FFFF) {
return 1;
}
if (_mm_movemask_epi8(c) != 0x0000FFFF) {
return 1;
}

offset += SCMEMCMP_BYTES;
Expand Down Expand Up @@ -229,17 +220,8 @@ static inline int SCMemcmpLowercase(const void *s1, const void *s2, size_t len)
/* now all is lowercase, let's do the actual compare (reuse mask1 reg) */
mask1 = _mm_cmpeq_epi8(b1, b2);

int diff = len - offset;
if (diff < 16) {
int rmask = ~(0xFFFFFFFF << diff);

if ((_mm_movemask_epi8(mask1) & rmask) != rmask) {
return 1;
}
} else {
if (_mm_movemask_epi8(mask1) != 0x0000FFFF) {
return 1;
}
if (_mm_movemask_epi8(mask1) != 0x0000FFFF) {
return 1;
}

offset += SCMEMCMP_BYTES;
Expand Down Expand Up @@ -277,17 +259,8 @@ static inline int SCMemcmp(const void *s1, const void *s2, size_t len)
b2 = _mm_loadu_si128((const __m128i *) s2);
c = _mm_cmpeq_epi8(b1, b2);

int diff = len - offset;
if (diff < 16) {
int rmask = ~(0xFFFFFFFF << diff);

if ((_mm_movemask_epi8(c) & rmask) != rmask) {
return 1;
}
} else {
if (_mm_movemask_epi8(c) != 0x0000FFFF) {
return 1;
}
if (_mm_movemask_epi8(c) != 0x0000FFFF) {
return 1;
}

offset += SCMEMCMP_BYTES;
Expand Down Expand Up @@ -340,17 +313,8 @@ static inline int SCMemcmpLowercase(const void *s1, const void *s2, size_t len)
/* now all is lowercase, let's do the actual compare (reuse mask1 reg) */
mask1 = _mm_cmpeq_epi8(b1, b2);

int diff = len - offset;
if (diff < 16) {
int rmask = ~(0xFFFFFFFF << diff);

if ((_mm_movemask_epi8(mask1) & rmask) != rmask) {
return 1;
}
} else {
if (_mm_movemask_epi8(mask1) != 0x0000FFFF) {
return 1;
}
if (_mm_movemask_epi8(mask1) != 0x0000FFFF) {
return 1;
}

offset += SCMEMCMP_BYTES;
Expand Down

0 comments on commit ca97ed4

Please sign in to comment.