Blame SOURCES/wireshark-1.10.14-valgrind-error.patch

a65ffb
diff --git a/epan/dissectors/packet-distcc.c b/epan/dissectors/packet-distcc.c
a65ffb
index 1478ca2f28..6ec20c5a2a 100644
a65ffb
--- a/epan/dissectors/packet-distcc.c
a65ffb
+++ b/epan/dissectors/packet-distcc.c
a65ffb
@@ -266,7 +266,7 @@ dissect_distcc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree)
a65ffb
     int offset=0;
a65ffb
     proto_tree *tree=NULL;
a65ffb
     proto_item *item=NULL;
a65ffb
-    char token[4];
a65ffb
+    char buf[13];
a65ffb
     guint32 parameter;
a65ffb
 
a65ffb
 
a65ffb
@@ -280,39 +280,33 @@ dissect_distcc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree)
a65ffb
         tree = proto_item_add_subtree(item, ett_distcc);
a65ffb
     }
a65ffb
 
a65ffb
-    while(1){
a65ffb
-        /* we must have at least 12 bytes so we can read the
a65ffb
-           token and the parameter */
a65ffb
-        if(tvb_length_remaining(tvb, offset)<12){
a65ffb
-            return;
a65ffb
-        }
a65ffb
-
a65ffb
-        /* read the token */
a65ffb
-        tvb_memcpy(tvb, token, offset, 4);
a65ffb
-        offset+=4;
a65ffb
+    while (TRUE) {
a65ffb
+        /* read the raw token (4 bytes) and parameter (8 bytes) */
a65ffb
+        tvb_memcpy(tvb, buf, offset, 12);
a65ffb
+        buf[12] = '\0';
a65ffb
+        offset+=12;
a65ffb
 
a65ffb
-        /* read the parameter */
a65ffb
-        if (sscanf(tvb_get_ptr(tvb, offset, 8), "%08x", &parameter) != 1)
a65ffb
+        /* scan the parameter */
a65ffb
+        if (sscanf(buf + 4, "%08x", &parameter) != 1)
a65ffb
             return;
a65ffb
-        offset+=8;
a65ffb
 
a65ffb
-        if(!strncmp(token, "DIST", 4)){
a65ffb
+        if(!strncmp(buf, "DIST", 4)){
a65ffb
             offset=dissect_distcc_dist(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "ARGC", 4)){
a65ffb
+        } else if(!strncmp(buf, "ARGC", 4)){
a65ffb
             offset=dissect_distcc_argc(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "ARGV", 4)){
a65ffb
+        } else if(!strncmp(buf, "ARGV", 4)){
a65ffb
             offset=dissect_distcc_argv(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "DOTI", 4)){
a65ffb
+        } else if(!strncmp(buf, "DOTI", 4)){
a65ffb
             offset=dissect_distcc_doti(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "DONE", 4)){
a65ffb
+        } else if(!strncmp(buf, "DONE", 4)){
a65ffb
             offset=dissect_distcc_done(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "STAT", 4)){
a65ffb
+        } else if(!strncmp(buf, "STAT", 4)){
a65ffb
             offset=dissect_distcc_stat(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "SERR", 4)){
a65ffb
+        } else if(!strncmp(buf, "SERR", 4)){
a65ffb
             offset=dissect_distcc_serr(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "SOUT", 4)){
a65ffb
+        } else if(!strncmp(buf, "SOUT", 4)){
a65ffb
             offset=dissect_distcc_sout(tvb, pinfo, tree, offset, parameter);
a65ffb
-        } else if(!strncmp(token, "DOTO", 4)){
a65ffb
+        } else if(!strncmp(buf, "DOTO", 4)){
a65ffb
             offset=dissect_distcc_doto(tvb, pinfo, tree, offset, parameter);
a65ffb
         } else {
a65ffb
             call_dissector(data_handle, tvb, pinfo, tree);