Re: Bug in brin_minmax_multi_distance_numeric()

Поиск
Список
Период
Сортировка
От Tomas Vondra
Тема Re: Bug in brin_minmax_multi_distance_numeric()
Дата
Msg-id 73006ea9-762d-4244-a63b-56bc91e3ba35@vondra.me
обсуждение исходный текст
Ответ на Bug in brin_minmax_multi_distance_numeric()  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: Bug in brin_minmax_multi_distance_numeric()
Список pgsql-hackers
On 7/31/25 19:33, Tom Lane wrote:
> Per the discussion in [1], I think we need something like
> 
> -    PG_RETURN_FLOAT8(DirectFunctionCall1(numeric_float8, d));
> +    PG_RETURN_DATUM(DirectFunctionCall1(numeric_float8, d));
> 
> in brin_minmax_multi_distance_numeric().  Peter was proposing
> that as cosmetic cleanup, but I think it's actually a functional
> bug that needs to be back-patched.  It is certainly broken on
> 32-bit machines where the Datum result of numeric_float8 will
> be a pointer, so that we will convert the numeric pointer value
> to a float and return that, yielding a totally-garbage distance
> value.  But I think it's broken on 64-bit machines too, because
> we'll be interpreting the output of numeric_float8 as a uintptr_t
> and applying some unwanted conversion to make that a float.
> 

Agreed it's a bug on 32-bit machines. Not sure about 64-bits.


> It's not clear to me exactly what this function is used for,
> but I guess the consequences would be broken BRIN indexes
> on numeric columns?
> 

Actually, no - it should not cause "broken" indexes, as in "giving
incorrect results". The distance functions determine in what order we
merge points into ranges, and if the distances are bogus then we can
build a summary that is less efficient.


regards

-- 
Tomas Vondra




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