Changeset: 3ffa85f4a2d5 for MonetDB
URL: https://dev.monetdb.org/hg/MonetDB/rev/3ffa85f4a2d5
Modified Files:
        gdk/gdk_string.c
        sql/server/sql_scan.c
Branch: default
Log Message:

Merge with Oct2020 branch.


diffs (80 lines):

diff --git a/gdk/gdk_string.c b/gdk/gdk_string.c
--- a/gdk/gdk_string.c
+++ b/gdk/gdk_string.c
@@ -108,11 +108,14 @@ strCleanHash(Heap *h, bool rebuild)
         * started. */
        memset(newhash, 0, sizeof(newhash));
        pos = GDK_STRHASHSIZE;
-       while (pos < h->free &&
-              pos + (pad = GDK_VARALIGN - (pos & (GDK_VARALIGN - 1))) < 
GDK_ELIMLIMIT) {
+       while (pos < h->free) {
+               pad = GDK_VARALIGN - (pos & (GDK_VARALIGN - 1));
                if (pad < sizeof(stridx_t))
                        pad += GDK_VARALIGN;
-               pos += pad + extralen;
+               pos += pad;
+               if (pos >= GDK_ELIMLIMIT)
+                       break;
+               pos += extralen;
                s = h->base + pos;
                if (h->hashash)
                        strhash = ((const BUN *) s)[-1];
@@ -315,9 +318,11 @@ strPut(BAT *b, var_t *dst, const void *V
                pad = 0;
        }
 
+       pad += extralen;
+
        /* check heap for space (limited to a certain maximum after
         * which nils are inserted) */
-       if (h->free + pad + len + extralen >= h->size) {
+       if (h->free + pad + len >= h->size) {
                size_t newsize = MAX(h->size, 4096);
 
                /* double the heap size until we have enough space */
@@ -326,11 +331,11 @@ strPut(BAT *b, var_t *dst, const void *V
                                newsize <<= 1;
                        else
                                newsize += 4 * 1024 * 1024;
-               } while (newsize <= h->free + pad + len + extralen);
+               } while (newsize <= h->free + pad + len);
 
                assert(newsize);
 
-               if (h->free + pad + len + extralen >= (size_t) VAR_MAX) {
+               if (h->free + pad + len >= (size_t) VAR_MAX) {
                        GDKerror("string heaps gets larger than %zuGiB.\n", 
(size_t) VAR_MAX >> 30);
                        return 0;
                }
@@ -342,19 +347,16 @@ strPut(BAT *b, var_t *dst, const void *V
                HEAPdecref(h, false);
                b->tvheap = h = new;
                MT_lock_unset(&b->theaplock);
-#ifndef NDEBUG
-               /* fill should solve initialization problems within
-                * valgrind */
-               memset(h->base + h->free, 0, h->size - h->free);
-#endif
 
                /* make bucket point into the new heap */
                bucket = ((stridx_t *) h->base) + off;
        }
 
        /* insert string */
-       pos = h->free + pad + extralen;
+       pos = h->free + pad;
        *dst = (var_t) pos;
+       if (pad > 0)
+               memset(h->base + h->free, 0, pad);
        memcpy(h->base + pos, v, len);
        if (h->hashash) {
                ((BUN *) (h->base + pos))[-1] = strhash;
@@ -362,7 +364,7 @@ strPut(BAT *b, var_t *dst, const void *V
                ((BUN *) (h->base + pos))[-2] = (BUN) len;
 #endif
        }
-       h->free += pad + len + extralen;
+       h->free += pad + len;
        h->dirty = true;
 
        /* maintain hash table */
_______________________________________________
checkin-list mailing list
checkin-list@monetdb.org
https://www.monetdb.org/mailman/listinfo/checkin-list

Reply via email to