Re: [sqlsmith] Failed assertion in brin_minmax_multi_distance_float4 on REL_14_STABLE

From: Tomas Vondra <tomas(dot)vondra(at)enterprisedb(dot)com>
To: Justin Pryzby <pryzby(at)telsasoft(dot)com>, Andreas Seltenreich <andreas(dot)seltenreich(at)credativ(dot)de>
Cc: pgsql-hackers(at)postgresql(dot)org, Jaime Casanova <jcasanov(at)systemguards(dot)com(dot)ec>
Subject: Re: [sqlsmith] Failed assertion in brin_minmax_multi_distance_float4 on REL_14_STABLE
Date: 2021-11-04 22:56:07
Message-ID: 83b2e911-ccd9-5503-fb32-369050a6e93d@enterprisedb.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi,

On 11/4/21 17:53, Justin Pryzby wrote:
> On Thu, Nov 04, 2021 at 09:46:49AM +0100, Andreas Seltenreich wrote:
>> sqlsmith triggers the following assertion when testing REL_14_STABLE:
>>
>> TRAP: FailedAssertion("a1 <= a2", File: "brin_minmax_multi.c", Line: 1879, PID: 631814)
>>
>> I can reproduce it with the following query on a fresh regression
>> database:
>>
>> insert into public.brintest_multi (float4col) values (real 'nan');
>>
>> The branch was at f6162c020c while testing, backtrace below.
>
> I couldn't reproduce this, but it reminds me of this one, which we also had
> trouble reproducing.
>

I can reproduce that just fine - all I had to do was 'make installcheck'
and then connect to the regression db and run the insert.

It seems to be a simple case of confusion in handling of NaN values. We
do sort them correctly (by calling float4_lt), but given two values

arg1 = nan (0x400000)
arg2 = 0.0909090936

then a simple comparison does not give the expected result

(arg1 < arg2)
(arg1 == arg2)
(arg1 > arg2)

all evaluate to false, which is why the assert fails. So I guess the
distance function for float4 (and probably float8 too) need a couple
more lines checking NaN.

regards

--
Tomas Vondra
EnterpriseDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Mark Dilger 2021-11-04 22:58:16 Re: Extending amcheck to check toast size and compression
Previous Message Andres Freund 2021-11-04 22:46:36 Re: Predefined role pg_maintenance for VACUUM, ANALYZE, CHECKPOINT.