Re: BUG #19078: Segfaults in tts_minimal_store_tuple() following pg_upgrade

From: Yuri Zamyatin <yuri(at)yrz(dot)am>
To: David Rowley <dgrowleyml(at)gmail(dot)com>
Cc: Jeff Davis <pgsql(at)j-davis(dot)com>, pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #19078: Segfaults in tts_minimal_store_tuple() following pg_upgrade
Date: 2025-10-15 14:21:29
Message-ID: ly6rss443iajiv5cfypzu6fgrmxdbwzdtuujkddr4eis7s2gcq@gcdytigety6e
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

I found a much easier way.

create.sql:
> drop database if exists segtest;
> create database segtest;
> \c segtest;
> create table tcv_scene_datas(cv_scene_id bigint primary key) partition by range (cv_scene_id);
> do $$
> declare
> i int;
> range_start bigint;
> range_end bigint;
> partition_name text;
> begin
> for i in 0..100 loop
> range_start := 1 + (i * 10000);
> range_end := range_start + 10000;
> partition_name := 'tcv_scene_datas_' || LPAD(i::TEXT, 3, '0');
> execute format(
> 'create table %I partition of tcv_scene_datas for values from (%s) to (%s)',
> partition_name,
> range_start,
> range_end
> );
> end loop;
> end $$;
> insert into tcv_scene_datas(cv_scene_id) select id from generate_series(1,1_000_000) id;

crash.sql:
> \c segtest
> with ids as (select (random()*1_000_000)::int id from generate_series(1,1000))
> update tcv_scene_datas set cv_scene_id=cv_scene_id where cv_scene_id in(select id from ids);

Launch crash.sql in 16 threads of infinite loops:
> seq 16 | xargs -P 16 -I {} sh -c 'while true; do psql -f crash.sql; done'

In 1-2 minutes, 5 processes died with segfault.
Also I expected deadlocks with such query, strangely database did not report them.

Let me know if you need more data.

__
Best wishes, Yuri

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Nathan Bossart 2025-10-15 16:24:34 Re: BUG #19086: pg_dump --data-only selects and do not uses index definitions for the dumped tables.
Previous Message Andrew Bille 2025-10-15 09:10:32 Re: BUG #19086: pg_dump --data-only selects and do not uses index definitions for the dumped tables.