BUG #18360: Invalid memory access occurs when using geqo - Mailing list pgsql-bugs
From | PG Bug reporting form |
---|---|
Subject | BUG #18360: Invalid memory access occurs when using geqo |
Date | |
Msg-id | 18360-a23caf3157f34e62@postgresql.org Whole thread Raw |
Responses |
Re: BUG #18360: Invalid memory access occurs when using geqo
|
List | pgsql-bugs |
The following bug has been logged on the website: Bug reference: 18360 Logged by: Alexander Lakhin Email address: exclusion@gmail.com PostgreSQL version: 16.2 Operating system: Ubuntu 22.04 Description: The following script: SET enable_partitionwise_join = on; SET geqo_threshold = 2; CREATE TABLE t (i int) PARTITION BY LIST (i); CREATE TABLE tp1 PARTITION OF t FOR VALUES IN (1); SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i); leads to a server crash with the following stack trace: Core was generated by `postgres: law regression [local] SELECT '. Program terminated with signal SIGSEGV, Segmentation fault. #0 0x000055a4a06b0ecd in create_unique_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1ae8ca0, flags=2) at createplan.c:1747 1747 Expr *uniqexpr = lfirst(l); (gdb) bt #0 0x000055a4a06b0ecd in create_unique_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1ae8ca0, flags=2) at createplan.c:1747 #1 0x000055a4a06aedb2 in create_plan_recurse (root=0x55a4a1ae1ba8, best_path=0x55a4a1ae8ca0, flags=2) at createplan.c:477 #2 0x000055a4a06b7309 in create_hashjoin_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1af8e40) at createplan.c:4734 #3 0x000055a4a06afa93 in create_join_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1af8e40) at createplan.c:1072 #4 0x000055a4a06aebdc in create_plan_recurse (root=0x55a4a1ae1ba8, best_path=0x55a4a1af8e40, flags=1) at createplan.c:416 #5 0x000055a4a06aff84 in create_append_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1af53d8, flags=1) at createplan.c:1288 #6 0x000055a4a06aebfb in create_plan_recurse (root=0x55a4a1ae1ba8, best_path=0x55a4a1af53d8, flags=1) at createplan.c:420 #7 0x000055a4a06aeaa8 in create_plan (root=0x55a4a1ae1ba8, best_path=0x55a4a1af53d8) at createplan.c:347 #8 0x000055a4a06c34dd in standard_planner (parse=0x55a4a19f3f50, query_string=0x55a4a19f2a08 "SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i);", cursorOptions=2048, boundParams=0x0) at planner.c:420 #9 0x000055a4a06c31b2 in planner (parse=0x55a4a19f3f50, query_string=0x55a4a19f2a08 "SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i);", cursorOptions=2048, boundParams=0x0) at planner.c:281 #10 0x000055a4a0812e93 in pg_plan_query (querytree=0x55a4a19f3f50, query_string=0x55a4a19f2a08 "SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i);", cursorOptions=2048, boundParams=0x0) at postgres.c:904 #11 0x000055a4a0812fed in pg_plan_queries (querytrees=0x55a4a1acb308, query_string=0x55a4a19f2a08 "SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i);", cursorOptions=2048, boundParams=0x0) at postgres.c:996 #12 0x000055a4a0813402 in exec_simple_query (query_string=0x55a4a19f2a08 "SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i);") at postgres.c:1193 #13 0x000055a4a0818600 in PostgresMain (dbname=0x55a4a1a2db78 "regression", username=0x55a4a19ef068 "law") at postgres.c:4637 #14 0x000055a4a073933b in BackendRun (port=0x55a4a1a25dc0) at postmaster.c:4464 #15 0x000055a4a0738bc7 in BackendStartup (port=0x55a4a1a25dc0) at postmaster.c:4192 (gdb) p best_path->uniq_exprs $1 = (List *) 0x55a4a1aedca0 (gdb) p *best_path->uniq_exprs $2 = {type = 2139062143, length = 2139062143, max_length = 2139062143, elements = 0x7f7f7f7f7f7f7f7f, initial_elements = 0x55a4a1aedcb8} Valgrind detects an invalid read, with the following diagnostics: 2024-02-23 15:13:54.387 MSK|law|regression|65d88bd7.2d9b63|STATEMENT: SELECT t1.* FROM t t1 WHERE EXISTS (SELECT 1 FROM t t2 WHERE t1.i = t2.i); ==00:00:00:47.886 2988899== Invalid read of size 4 ==00:00:00:47.887 2988899== at 0x4EF847: create_unique_plan (createplan.c:1745) ==00:00:00:47.887 2988899== by 0x4EF5D8: create_plan_recurse (createplan.c:477) ==00:00:00:47.887 2988899== by 0x4F07F6: create_hashjoin_plan (createplan.c:4734) ... ==00:00:00:47.887 2988899== Address 0x10b16524 is 5,540 bytes inside a recently re-allocated block of size 8,192 alloc'd ==00:00:00:47.887 2988899== at 0x4848899: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) ==00:00:00:47.887 2988899== by 0x762646: AllocSetContextCreateInternal (aset.c:438) ==00:00:00:47.887 2988899== by 0x4C7DD1: geqo_eval (geqo_eval.c:75) ==00:00:00:47.887 2988899== by 0x4C829D: random_init_pool (geqo_pool.c:109) ==00:00:00:47.887 2988899== by 0x4C7FB4: geqo (geqo_main.c:114) ==00:00:00:47.887 2988899== by 0x4CD14D: make_rel_from_joinlist (allpaths.c:3383) ==00:00:00:47.887 2988899== by 0x4CD226: make_one_rel (allpaths.c:229) ==00:00:00:47.887 2988899== by 0x4F7878: query_planner (planmain.c:278) ==00:00:00:47.887 2988899== by 0x4FF6C3: grouping_planner (planner.c:1495) ==00:00:00:47.887 2988899== by 0x501084: subquery_planner (planner.c:1064) ==00:00:00:47.887 2988899== by 0x501680: standard_planner (planner.c:413) ==00:00:00:47.887 2988899== by 0x501C4A: planner (planner.c:281) It looks like uniq_exprs points to memory located in a short-lived context created in geqo_eval().
pgsql-bugs by date: