mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-19 15:49:24 +03:00 
			
		
		
		
	Update obsolete comments in lwlock.h.
The typical size of an LWLock is now 16 bytes even on 64-bit platforms,
and the size of slock_t is now irrelevant.  But pg_atomic_uint32 can
(perhaps surprisingly) still be larger than 4 bytes, so there's still
some marginal point to allowing LWLOCK_MINIMAL_SIZE == 64.
Commit 008608b9d5 made the changes
that led to the need for these updates.
			
			
This commit is contained in:
		| @@ -58,16 +58,17 @@ typedef struct LWLock | ||||
|  * LWLockPadded can be used for cases where we want each lock to be an entire | ||||
|  * cache line. | ||||
|  * | ||||
|  * On 32-bit platforms, an LWLockMinimallyPadded might actually contain more | ||||
|  * than the absolute minimum amount of padding required to keep a lock from | ||||
|  * crossing a cache line boundary, because an unpadded LWLock might fit into | ||||
|  * 16 bytes.  We ignore that possibility when determining the minimal amount | ||||
|  * of padding.  Older releases had larger LWLocks, so 32 really was the | ||||
|  * minimum, and packing them in tighter might hurt performance. | ||||
|  * An LWLockMinimallyPadded might contain more than the absolute minimum amount | ||||
|  * of padding required to keep a lock from crossing a cache line boundary, | ||||
|  * because an unpadded LWLock will normally fit into 16 bytes.  We ignore that | ||||
|  * possibility when determining the minimal amount of padding.  Older releases | ||||
|  * had larger LWLocks, so 32 really was the minimum, and packing them in | ||||
|  * tighter might hurt performance. | ||||
|  * | ||||
|  * LWLOCK_MINIMAL_SIZE should be 32 on basically all common platforms, but | ||||
|  * because slock_t is more than 2 bytes on some obscure platforms, we allow | ||||
|  * for the possibility that it might be 64. | ||||
|  * because pg_atomic_uint32 is more than 4 bytes on some obscure platforms, we | ||||
|  * allow for the possibility that it might be 64.  Even on those platforms, | ||||
|  * we probably won't exceed 32 bytes unless LOCK_DEBUG is defined. | ||||
|  */ | ||||
| #define LWLOCK_PADDED_SIZE	PG_CACHE_LINE_SIZE | ||||
| #define LWLOCK_MINIMAL_SIZE (sizeof(LWLock) <= 32 ? 32 : 64) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user