diff --git a/include/internal/numbers.h b/include/internal/numbers.h index 1f79ef797..da06dab7a 100644 --- a/include/internal/numbers.h +++ b/include/internal/numbers.h @@ -105,5 +105,9 @@ # define UINT64_MAX __MAXUINT__(uint64_t) # endif +# ifndef SIZE_MAX +# define SIZE_MAX __MAXUINT__(size_t) +# endif + #endif diff --git a/ssl/packet_locl.h b/ssl/packet_locl.h index 48a5f3d7d..ed7c1ca12 100644 --- a/ssl/packet_locl.h +++ b/ssl/packet_locl.h @@ -65,6 +65,8 @@ # include # include +# include "internal/numbers.h" + # ifdef __cplusplus extern "C" { # endif @@ -111,13 +113,8 @@ __owur static ossl_inline int PACKET_buf_init(PACKET *pkt, unsigned char *buf, size_t len) { /* Sanity check for negative values. */ -#ifdef SIZE_MAX if (len > (size_t)(SIZE_MAX / 2)) return 0; -#else - if (len > ((size_t)2 << (sizeof(size_t) * 8 - 1))) - return 0; -#endif pkt->curr = buf; pkt->remaining = len;