Re: Bug in brin_minmax_multi_distance_numeric() - Mailing list pgsql-hackers

From Tomas Vondra
Subject Re: Bug in brin_minmax_multi_distance_numeric()
Date
Msg-id 73006ea9-762d-4244-a63b-56bc91e3ba35@vondra.me
Whole thread Raw
In response to Bug in brin_minmax_multi_distance_numeric()  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: Bug in brin_minmax_multi_distance_numeric()
List 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 by date:

Previous
From: Nathan Bossart
Date:
Subject: Re: Non-text mode for pg_dumpall
Next
From: Tom Lane
Date:
Subject: Re: Bug in brin_minmax_multi_distance_numeric()