• Heikki Linnakangas's avatar
    Fix query-duration memory leak with GIN rescans. · 68fa75f3
    Heikki Linnakangas authored
    The requiredEntries / additionalEntries arrays were not freed in
    freeScanKeys() like other per-key stuff.
    
    It's not obvious, but startScanKey() was only ever called after the keys
    have been initialized with ginNewScanKey(). That's why it doesn't need to
    worry about freeing existing arrays. The ginIsNewKey() test in gingetbitmap
    was never true, because ginrescan free's the existing keys, and it's not OK
    to call gingetbitmap twice in a row without calling ginrescan in between.
    To make that clear, remove the unnecessary ginIsNewKey(). And just to be
    extra sure that nothing funny happens if there is an existing key after all,
    call freeScanKeys() to free it if it exists. This makes the code more
    straightforward.
    
    (I'm seeing other similar leaks in testing a query that rescans an GIN index
    scan, but that's a different issue. This just fixes the obvious leak with
    those two arrays.)
    
    Backpatch to 9.4, where GIN fast scan was added.
    68fa75f3
ginscan.c 11.9 KB