diff options
| -rw-r--r-- | libglusterfs/src/dict.c | 3 | 
1 files changed, 2 insertions, 1 deletions
diff --git a/libglusterfs/src/dict.c b/libglusterfs/src/dict.c index 6c3fc164d8e..03a220a8218 100644 --- a/libglusterfs/src/dict.c +++ b/libglusterfs/src/dict.c @@ -2813,7 +2813,8 @@ dict_unserialize (char *orig_buf, int32_t size, dict_t **fill)                  vallen = ntoh32 (hostord);                  buf += DICT_DATA_HDR_VAL_LEN; -                if ((buf + keylen) > (orig_buf + size)) { +                if ((keylen < 0) || (vallen < 0) || +                    (buf + keylen) > (orig_buf + size)) {                          gf_msg_callingfn ("dict", GF_LOG_ERROR, 0,                                            LG_MSG_UNDERSIZED_BUF,                                            "undersized buffer passed. "  | 
