Re: pg_upgrade: fix memory leak in SLRU I/O code

Поиск
Список
Период
Сортировка
От Chao Li
Тема Re: pg_upgrade: fix memory leak in SLRU I/O code
Дата
Msg-id E05B5ACC-703B-463C-80AB-E63EB2BD75BA@gmail.com
обсуждение исходный текст
Ответ на Re: pg_upgrade: fix memory leak in SLRU I/O code  (Yugo Nagata <nagata@sraoss.co.jp>)
Ответы Re: pg_upgrade: fix memory leak in SLRU I/O code
Список pgsql-hackers

> On Feb 5, 2026, at 09:54, Yugo Nagata <nagata@sraoss.co.jp> wrote:
>
> On Wed, 4 Feb 2026 17:20:49 +0800
> Chao Li <li.evan.chao@gmail.com> wrote:
>
>> Hi Hackers,
>>
>> This comes from a previous review and has been on my to-do list for a while.
>>
>> Since src/bin/pg_upgrade/slru_io.c includes postgres_fe.h, it is frontend code, so backend memory contexts are not
usedhere. 
>>
>> In the current code:
>> ```
>> void
>> FreeSlruWrite(SlruSegState *state)
>> {
>> Assert(state->writing);
>>
>> SlruFlush(state);
>>
>> if (state->fd != -1)
>> close(state->fd);
>> pg_free(state);
>> }
>> ```
>>
>> the SlruSegState itself is freed, but state->dir and state->fn are not, which results in a memory leak during
pg_upgraderuns. More generally, I don’t see a reason to free an object itself without also freeing the memory owned by
itsmembers. 
>
> As far as I know, AllocSlruSegState() and FreeSlruWrite() are not called
> repeatedly in a loop, and the amount of memory involved is small, so the
> impact of the leak seems limited. That said, I agree that it is better to
> also free the memory owned by the struct members.
>
> Regards,
> Yugo Nagata
>

Hi Yugo-san,

Thank you very much for the review. Yes, the leak itself is tiny, the main point for me is that the memory owned by the
structmembers is not freed, which can be a bit confusing for code readers. As for the change from pstrdup() to
pg_strdup(),that felt too trivial to justify a separate patch, so I took this as an opportunity to clean it up at the
sametime. 

BTW, this is the CF entry: https://commitfest.postgresql.org/patch/6462/, you may mark yourself as a reviewer.

Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/







В списке pgsql-hackers по дате отправления: