summaryrefslogtreecommitdiff
path: root/src/backend/optimizer/util/inherit.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2021-07-11 12:54:24 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2021-07-11 12:54:24 -0400
commit626731db26ae2617e41536678440c3817128a006 (patch)
tree9b3dbee2234a86b01099854685bcd1a04f93d201 /src/backend/optimizer/util/inherit.c
parent0e39a608ed5545cc6b9d538ac937c3c1ee8cdc36 (diff)
Lock the extension during ALTER EXTENSION ADD/DROP.
Although we were careful to lock the object being added or dropped, we failed to get any sort of lock on the extension itself. This allowed the ALTER to proceed in parallel with a DROP EXTENSION, which is problematic for a couple of reasons. If both commands succeeded we'd be left with a dangling link in pg_depend, which would cause problems later. Also, if the ALTER failed for some reason, it might try to print the extension's name, and that could result in a crash or (in older branches) a silly error message complaining about extension "(null)". Per bug #17098 from Alexander Lakhin. Back-patch to all supported branches. Discussion: https://postgr.es/m/17098-b960f3616c861f83@postgresql.org
Diffstat (limited to 'src/backend/optimizer/util/inherit.c')
0 files changed, 0 insertions, 0 deletions