diff --git a/src/basic/alloc-util.h b/src/basic/alloc-util.h index 62b591117b..ebe42889ea 100644 --- a/src/basic/alloc-util.h +++ b/src/basic/alloc-util.h @@ -52,11 +52,8 @@ static inline void freep(void *p) { #define _cleanup_free_ _cleanup_(freep) -/* Checks the size arguments of allocation functions for overflow in multiplication. In addition, checks if either of - * them is 0; that is almost certainly an error (e.g., an overflow in computing _need_), so it's better to fail (and - * we cannot leave this check to malloc, because the behavior of malloc(0) is impl. specific). */ static inline bool size_multiply_overflow(size_t size, size_t need) { - return _unlikely_(need == 0 || size == 0 || size > (SIZE_MAX / need)); + return _unlikely_(need != 0 && size > (SIZE_MAX / need)); } _malloc_ _alloc_(1, 2) static inline void *malloc_multiply(size_t size, size_t need) {