> On Apr 24, 2026, at 16:07, Michael Paquier <[email protected]> wrote:
> 
> On Fri, Apr 24, 2026 at 03:26:03PM +0900, Fujii Masao wrote:
>> Attached patch fixes this issue by changing printVerboseErrorMessages()
>> to use a local PQExpBufferData instead of a static one. Thoughts?
> 
> That looks like an oversight of 4a39f87acd6e to me.  A static buffer
> in this context is not adapted.
> 
>> Since this issue was introduced in v15, the patch should be
>> backpatched to v15 if accepted.
> 
> This forces a new allocation for each message printed vs a set of
> resets after one allocation is done.  This change is not going to be
> entirely free as done in the patch, so should we worry about that?
> Perhaps it would be cheaper to allocate a PQExpBuffer in each CState,
> and just reuse it in this routine?
> --
> Michael

I am not too worried about that, because this code path is only used with 
--verbose-errors and only when printing error messages. In that situation, the 
cost of one extra memory allocation per log line should be much smaller than 
the I/O cost of writing the log message itself. So I think the simpler fix is 
probably acceptable.

But if we really care about the performance problem, I think PQExpBuffer might 
be better stored in TState that is per thread, while CState is per connection.

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






Reply via email to