Assert that we don't acquire a heavyweight lock on another object after
authorAmit Kapila <akapila@postgresql.org>
Wed, 18 Mar 2020 01:50:17 +0000 (07:20 +0530)
committerAmit Kapila <akapila@postgresql.org>
Wed, 18 Mar 2020 01:50:17 +0000 (07:20 +0530)
commit15ef6ff4b985276c386adf3e11ebf7f955ea6f1f
tree88d146b5798bcb8961967cd96ecadd3129f7a37f
parentb897b3aae6b525922fe3d074d4bdf5f2674954dd
Assert that we don't acquire a heavyweight lock on another object after
relation extension lock.

The only exception to the rule is that we can try to acquire the same
relation extension lock more than once.  This is allowed as we are not
creating any new lock for this case.  This restriction implies that the
relation extension lock won't ever participate in the deadlock cycle
because we can never wait for any other heavyweight lock after acquiring
this lock.

Such a restriction is okay for relation extension locks as unlike other
heavyweight locks these are not held till the transaction end.  These are
taken for a short duration to extend a particular relation and then
released.

Author: Dilip Kumar, with few changes by Amit Kapila
Reviewed-by: Amit Kapila, Kuntal Ghosh and Sawada Masahiko
Discussion: https://postgr.es/m/CAD21AoCmT3cFQUN4aVvzy5chw7DuzXrJCbrjTU05B+Ss=Gn1LA@mail.gmail.com
src/backend/storage/lmgr/lock.c
src/include/storage/lock.h