]> granicus.if.org Git - postgresql/commitdiff
Avoid memcpy() with same source and destination address.
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Fri, 7 Mar 2014 11:13:33 +0000 (13:13 +0200)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Fri, 7 Mar 2014 11:29:19 +0000 (13:29 +0200)
The behavior of that is undefined, although unlikely to lead to problems in
practice.

Found by running regression tests with Valgrind.

src/backend/tsearch/dict_ispell.c
src/backend/utils/adt/tsvector.c

index 425b810d055aa1641fb10954cea9d9ec3f3db4df..5cca3b64f0d971f92afee0706feecc8ea7552a51 100644 (file)
@@ -126,20 +126,19 @@ dispell_lexize(PG_FUNCTION_ARGS)
        if (res == NULL)
                PG_RETURN_POINTER(NULL);
 
-       ptr = cptr = res;
-       while (ptr->lexeme)
+       cptr = res;
+       for (ptr = cptr; ptr->lexeme; ptr++)
        {
                if (searchstoplist(&(d->stoplist), ptr->lexeme))
                {
                        pfree(ptr->lexeme);
                        ptr->lexeme = NULL;
-                       ptr++;
                }
                else
                {
-                       memcpy(cptr, ptr, sizeof(TSLexeme));
+                       if (cptr != ptr)
+                               memcpy(cptr, ptr, sizeof(TSLexeme));
                        cptr++;
-                       ptr++;
                }
        }
        cptr->lexeme = NULL;
index fc8a318da3cee55b0e45822f1bb20f44cc258295..609b0721bef42b1c33e025984b305f3286ad6f8f 100644 (file)
@@ -124,7 +124,8 @@ uniqueentry(WordEntryIN *a, int l, char *buf, int *outbuflen)
                                buflen += res->poslen * sizeof(WordEntryPos) + sizeof(uint16);
                        }
                        res++;
-                       memcpy(res, ptr, sizeof(WordEntryIN));
+                       if (res != ptr)
+                               memcpy(res, ptr, sizeof(WordEntryIN));
                }
                else if (ptr->entry.haspos)
                {