Previously, when calling is_between(a, b, c), the calculation was wrong. It counted C as between A and B if C was equal to B, but not A.
Example of this are: is_between(1, 10, 10) = 1 (Expected: 0) is_between(1, 10, 1) = 0 (Expected: 0) is_between(20, 10, 10) = 1 (Expected: 0) And so on and so forth. Obviously, ten is not a number between one and ten - only two to eight are, so I made this patch :) Signed-off-by: Cruz Julian Bishop <cruzjbis...@gmail.com> --- drivers/staging/android/logger.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/staging/android/logger.c b/drivers/staging/android/logger.c index 226d8b5..925df5c 100644 --- a/drivers/staging/android/logger.c +++ b/drivers/staging/android/logger.c @@ -298,11 +298,11 @@ static inline int is_between(size_t a, size_t b, size_t c) { if (a < b) { /* is c between a and b? */ - if (a < c && c <= b) + if (a < c && c < b) return 1; } else { /* is c outside of b through a? */ - if (c <= b || a < c) + if (c < b || a < c) return 1; } -- 1.7.9.5 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/