Re: BUG #17950: Incorrect memory access in gtsvector_picksplit()

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Alexander Lakhin <exclusion(at)gmail(dot)com>
Cc: pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #17950: Incorrect memory access in gtsvector_picksplit()
Date: 2023-08-13 14:35:43
Message-ID: 665394.1691937343@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Alexander Lakhin <exclusion(at)gmail(dot)com> writes:
> I can also propose a regression test addition that demonstrates the valgrind
> complaint and also the output of gtsvectorout() for the case ISALLTRUE and
> the opposite.

OK, but ...

> This addition increases the duration of `make check -C contrib/pageinspect`
> under valgrind by 7-8 seconds for me:

[ ie, more than triple its previous runtime ]

... that seems completely unacceptable cost-wise. I'd be inclined
to commit the fix without a supporting test case, instead of that.

Given that the misapplication of GETSIGN is causing an incorrect
pointer to be passed to sizebitvec(), how come the error is not
leading to outright wrong answers? I guess because it's in
picksplit, the worst outcome normally is a poor choice of split,
so maybe exhibiting wrong behavior in a detectable way is hard.

> In absence of any objections or other propositions, I'm inclined to register
> this bugfix on the commitfest.

Please do that in any case, so we don't forget about it.

regards, tom lane

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Alexander Lakhin 2023-08-13 18:00:01 Re: BUG #17950: Incorrect memory access in gtsvector_picksplit()
Previous Message Alexander Lakhin 2023-08-13 13:00:01 Re: BUG #17950: Incorrect memory access in gtsvector_picksplit()