Commit b1d65389 authored by Thomas Munro's avatar Thomas Munro

Fix race condition when sharing tuple descriptors.

Parallel query processes that called BlessTupleDesc() for identical
tuple descriptors at the same moment could crash.  There was code to
handle that rare case, but it dereferenced a bogus DSA pointer.  Repair.

Back-patch to 11, where commit cc5f8136 added support for sharing tuple
descriptors in parallel queries.
Reported-by: default avatarEric Thinnes <e.thinnes@gmx.de>
Discussion: https://postgr.es/m/99aaa2eb-e194-bf07-c29a-1a76b4f2bcf9%40gmx.de
parent d69fcb9c
...@@ -2822,7 +2822,7 @@ find_or_make_matching_shared_tupledesc(TupleDesc tupdesc) ...@@ -2822,7 +2822,7 @@ find_or_make_matching_shared_tupledesc(TupleDesc tupdesc)
Assert(record_table_entry->key.shared); Assert(record_table_entry->key.shared);
result = (TupleDesc) result = (TupleDesc)
dsa_get_address(CurrentSession->area, dsa_get_address(CurrentSession->area,
record_table_entry->key.shared); record_table_entry->key.u.shared_tupdesc);
Assert(result->tdrefcount == -1); Assert(result->tdrefcount == -1);
return result; return result;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment