From: Tom Lane Date: Wed, 12 Oct 2005 16:55:59 +0000 (+0000) Subject: Fix another recently-changed place that was messing with spinlock- X-Git-Tag: REL8_1_0BETA4~87 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=fa72121594534dda6cc010f0bf6b3e8d22987526;p=postgresql Fix another recently-changed place that was messing with spinlock- protected data structures and not using a volatile pointer for same. --- diff --git a/src/backend/storage/lmgr/lwlock.c b/src/backend/storage/lmgr/lwlock.c index 8b7565a6aa..ce0606a3c4 100644 --- a/src/backend/storage/lmgr/lwlock.c +++ b/src/backend/storage/lmgr/lwlock.c @@ -15,7 +15,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/storage/lmgr/lwlock.c,v 1.32 2005/10/07 21:42:38 tgl Exp $ + * $PostgreSQL: pgsql/src/backend/storage/lmgr/lwlock.c,v 1.33 2005/10/12 16:55:59 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -226,7 +226,8 @@ LWLockId LWLockAssign(void) { LWLockId result; - int *LWLockCounter; + /* use volatile pointer to prevent code rearrangement */ + volatile int *LWLockCounter; LWLockCounter = (int *) ((char *) LWLockArray - 2 * sizeof(int)); SpinLockAcquire(ShmemLock);