summaryrefslogtreecommitdiff
path: root/src/backend/storage/lmgr
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend/storage/lmgr')
-rw-r--r--src/backend/storage/lmgr/lmgr.c40
-rw-r--r--src/backend/storage/lmgr/lock.c44
2 files changed, 56 insertions, 28 deletions
diff --git a/src/backend/storage/lmgr/lmgr.c b/src/backend/storage/lmgr/lmgr.c
index d4fa5f6ebc4..79068795af4 100644
--- a/src/backend/storage/lmgr/lmgr.c
+++ b/src/backend/storage/lmgr/lmgr.c
@@ -307,32 +307,26 @@ CheckRelationLockedByMe(Relation relation, LOCKMODE lockmode, bool orstronger)
relation->rd_lockInfo.lockRelId.dbId,
relation->rd_lockInfo.lockRelId.relId);
- if (LockHeldByMe(&tag, lockmode))
- return true;
+ return (orstronger ?
+ LockOrStrongerHeldByMe(&tag, lockmode) :
+ LockHeldByMe(&tag, lockmode));
+}
- if (orstronger)
- {
- LOCKMODE slockmode;
+/*
+ * CheckRelationOidLockedByMe
+ *
+ * Like the above, but takes an OID as argument.
+ */
+bool
+CheckRelationOidLockedByMe(Oid relid, LOCKMODE lockmode, bool orstronger)
+{
+ LOCKTAG tag;
- for (slockmode = lockmode + 1;
- slockmode <= MaxLockMode;
- slockmode++)
- {
- if (LockHeldByMe(&tag, slockmode))
- {
-#ifdef NOT_USED
- /* Sometimes this might be useful for debugging purposes */
- elog(WARNING, "lock mode %s substituted for %s on relation %s",
- GetLockmodeName(tag.locktag_lockmethodid, slockmode),
- GetLockmodeName(tag.locktag_lockmethodid, lockmode),
- RelationGetRelationName(relation));
-#endif
- return true;
- }
- }
- }
+ SetLocktagRelationOid(&tag, relid);
- return false;
+ return (orstronger ?
+ LockOrStrongerHeldByMe(&tag, lockmode) :
+ LockHeldByMe(&tag, lockmode));
}
/*
diff --git a/src/backend/storage/lmgr/lock.c b/src/backend/storage/lmgr/lock.c
index 31933693d66..bc888d2108d 100644
--- a/src/backend/storage/lmgr/lock.c
+++ b/src/backend/storage/lmgr/lock.c
@@ -579,11 +579,17 @@ DoLockModesConflict(LOCKMODE mode1, LOCKMODE mode2)
}
/*
- * LockHeldByMe -- test whether lock 'locktag' is held with mode 'lockmode'
- * by the current transaction
+ * LockHeldByMeExtended -- test whether lock 'locktag' is held by the current
+ * transaction
+ *
+ * Returns true if current transaction holds a lock on 'tag' of mode
+ * 'lockmode'. If 'orstronger' is true, a stronger lockmode is also OK.
+ * ("Stronger" is defined as "numerically higher", which is a bit
+ * semantically dubious but is OK for the purposes we use this for.)
*/
-bool
-LockHeldByMe(const LOCKTAG *locktag, LOCKMODE lockmode)
+static bool
+LockHeldByMeExtended(const LOCKTAG *locktag,
+ LOCKMODE lockmode, bool orstronger)
{
LOCALLOCKTAG localtag;
LOCALLOCK *locallock;
@@ -599,7 +605,35 @@ LockHeldByMe(const LOCKTAG *locktag, LOCKMODE lockmode)
(void *) &localtag,
HASH_FIND, NULL);
- return (locallock && locallock->nLocks > 0);
+ if (locallock && locallock->nLocks > 0)
+ return true;
+
+ if (orstronger)
+ {
+ LOCKMODE slockmode;
+
+ for (slockmode = lockmode + 1;
+ slockmode <= MaxLockMode;
+ slockmode++)
+ {
+ if (LockHeldByMeExtended(locktag, slockmode, false))
+ return true;
+ }
+ }
+
+ return false;
+}
+
+bool
+LockHeldByMe(const LOCKTAG *locktag, LOCKMODE lockmode)
+{
+ return LockHeldByMeExtended(locktag, lockmode, false);
+}
+
+bool
+LockOrStrongerHeldByMe(const LOCKTAG *locktag, LOCKMODE lockmode)
+{
+ return LockHeldByMeExtended(locktag, lockmode, true);
}
#ifdef USE_ASSERT_CHECKING