From e2802d9a4b7e518c549e8dd95a34d2424058f086 Mon Sep 17 00:00:00 2001 From: Martin Sustrik Date: Wed, 15 Sep 2010 16:44:57 +0200 Subject: [PATCH] values of RATE, RECOVERY_IVL and SWAP options are checked for negative values --- src/options.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/options.cpp b/src/options.cpp index f6b24d67..dcbb51db 100644 --- a/src/options.cpp +++ b/src/options.cpp @@ -53,7 +53,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, return 0; case ZMQ_SWAP: - if (optvallen_ != sizeof (int64_t)) { + if (optvallen_ != sizeof (int64_t) || *((int64_t*) optval_) < 0) { errno = EINVAL; return -1; } @@ -82,7 +82,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, return 0; case ZMQ_RATE: - if (optvallen_ != sizeof (int64_t)) { + if (optvallen_ != sizeof (int64_t) || *((int64_t*) optval_) < 0) { errno = EINVAL; return -1; } @@ -90,7 +90,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, return 0; case ZMQ_RECOVERY_IVL: - if (optvallen_ != sizeof (int64_t)) { + if (optvallen_ != sizeof (int64_t) || *((int64_t*) optval_) < 0) { errno = EINVAL; return -1; }