Index: mozilla/security/nss/lib/libpkix/pkix_pl_nss/system/pkix_pl_rwlock.c |
=================================================================== |
--- mozilla/security/nss/lib/libpkix/pkix_pl_nss/system/pkix_pl_rwlock.c (revision 191424) |
+++ mozilla/security/nss/lib/libpkix/pkix_pl_nss/system/pkix_pl_rwlock.c (working copy) |
@@ -1,217 +0,0 @@ |
-/* This Source Code Form is subject to the terms of the Mozilla Public |
- * License, v. 2.0. If a copy of the MPL was not distributed with this |
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
-/* |
- * pkix_pl_rwlock.c |
- * |
- * Read/Write Lock Functions |
- * |
- */ |
- |
-#include "pkix_pl_rwlock.h" |
- |
-/* --Private-Functions-------------------------------------------- */ |
- |
-static PKIX_Error * |
-pkix_pl_RWLock_Destroy( |
- PKIX_PL_Object *object, |
- void *plContext) |
-{ |
- PKIX_PL_RWLock* rwlock = NULL; |
- |
- PKIX_ENTER(RWLOCK, "pkix_pl_RWLock_Destroy"); |
- PKIX_NULLCHECK_ONE(object); |
- |
- PKIX_CHECK(pkix_CheckType(object, PKIX_RWLOCK_TYPE, plContext), |
- PKIX_OBJECTNOTRWLOCK); |
- |
- rwlock = (PKIX_PL_RWLock*) object; |
- |
- PKIX_RWLOCK_DEBUG("Calling PR_DestroyRWLock)\n"); |
- PR_DestroyRWLock(rwlock->lock); |
- rwlock->lock = NULL; |
- |
-cleanup: |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-/* |
- * FUNCTION: pkix_pl_RWLock_RegisterSelf |
- * DESCRIPTION: |
- * Registers PKIX_RWLOCK_TYPE and its related functions with systemClasses[] |
- * THREAD SAFETY: |
- * Not Thread Safe - for performance and complexity reasons |
- * |
- * Since this function is only called by PKIX_PL_Initialize, which should |
- * only be called once, it is acceptable that this function is not |
- * thread-safe. |
- */ |
-PKIX_Error * |
-pkix_pl_RWLock_RegisterSelf( |
- void *plContext) |
-{ |
- |
- extern pkix_ClassTable_Entry systemClasses[PKIX_NUMTYPES]; |
- pkix_ClassTable_Entry entry; |
- |
- PKIX_ENTER(RWLOCK, "pkix_pl_RWLock_RegisterSelf"); |
- |
- entry.description = "RWLock"; |
- entry.objCounter = 0; |
- entry.typeObjectSize = sizeof(PKIX_PL_RWLock); |
- entry.destructor = pkix_pl_RWLock_Destroy; |
- entry.equalsFunction = NULL; |
- entry.hashcodeFunction = NULL; |
- entry.toStringFunction = NULL; |
- entry.comparator = NULL; |
- entry.duplicateFunction = NULL; |
- |
- systemClasses[PKIX_RWLOCK_TYPE] = entry; |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-/* --Public-Functions--------------------------------------------- */ |
- |
-PKIX_Error * |
-PKIX_PL_RWLock_Create( |
- PKIX_PL_RWLock **pNewLock, |
- void *plContext) |
-{ |
- PKIX_PL_RWLock *rwLock = NULL; |
- |
- PKIX_ENTER(RWLOCK, "PKIX_PL_RWLock_Create"); |
- PKIX_NULLCHECK_ONE(pNewLock); |
- |
- PKIX_CHECK(PKIX_PL_Object_Alloc |
- (PKIX_RWLOCK_TYPE, |
- sizeof (PKIX_PL_RWLock), |
- (PKIX_PL_Object **)&rwLock, |
- plContext), |
- PKIX_ERRORALLOCATINGRWLOCK); |
- |
- PKIX_RWLOCK_DEBUG("\tCalling PR_NewRWLock)\n"); |
- rwLock->lock = PR_NewRWLock(PR_RWLOCK_RANK_NONE, "PKIX RWLock"); |
- |
- if (rwLock->lock == NULL) { |
- PKIX_DECREF(rwLock); |
- PKIX_ERROR(PKIX_OUTOFMEMORY); |
- } |
- |
- rwLock->readCount = 0; |
- rwLock->writeLocked = PKIX_FALSE; |
- |
- *pNewLock = rwLock; |
- |
-cleanup: |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_AcquireReaderLock( |
- PKIX_PL_RWLock *lock, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_AcquireReaderLock"); |
- PKIX_NULLCHECK_ONE(lock); |
- |
- PKIX_RWLOCK_DEBUG("\tCalling PR_RWLock_Rlock)\n"); |
- (void) PR_RWLock_Rlock(lock->lock); |
- |
- lock->readCount++; |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_ReleaseReaderLock( |
- PKIX_PL_RWLock *lock, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_ReleaseReaderLock"); |
- PKIX_NULLCHECK_ONE(lock); |
- |
- PKIX_RWLOCK_DEBUG("\tCalling PR_RWLock_Unlock)\n"); |
- (void) PR_RWLock_Unlock(lock->lock); |
- |
- lock->readCount--; |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_IsReaderLockHeld( |
- PKIX_PL_RWLock *lock, |
- PKIX_Boolean *pIsHeld, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_IsReaderLockHeld"); |
- PKIX_NULLCHECK_TWO(lock, pIsHeld); |
- |
- *pIsHeld = (lock->readCount > 0)?PKIX_TRUE:PKIX_FALSE; |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_AcquireWriterLock( |
- PKIX_PL_RWLock *lock, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_AcquireWriterLock"); |
- PKIX_NULLCHECK_ONE(lock); |
- |
- PKIX_RWLOCK_DEBUG("\tCalling PR_RWLock_Wlock\n"); |
- (void) PR_RWLock_Wlock(lock->lock); |
- |
- if (lock->readCount > 0) { |
- PKIX_ERROR(PKIX_LOCKHASNONZEROREADCOUNT); |
- } |
- |
- /* We should never acquire a write lock if the lock is held */ |
- lock->writeLocked = PKIX_TRUE; |
- |
-cleanup: |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_ReleaseWriterLock( |
- PKIX_PL_RWLock *lock, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_ReleaseWriterLock"); |
- PKIX_NULLCHECK_ONE(lock); |
- |
- if (lock->readCount > 0) { |
- PKIX_ERROR(PKIX_LOCKHASNONZEROREADCOUNT); |
- } |
- |
- PKIX_RWLOCK_DEBUG("\tCalling PR_RWLock_Unlock)\n"); |
- (void) PR_RWLock_Unlock(lock->lock); |
- |
- /* XXX Need to think about thread safety here */ |
- /* There should be a single lock holder */ |
- lock->writeLocked = PKIX_FALSE; |
- |
-cleanup: |
- |
- PKIX_RETURN(RWLOCK); |
-} |
- |
-PKIX_Error * |
-PKIX_PL_IsWriterLockHeld( |
- PKIX_PL_RWLock *lock, |
- PKIX_Boolean *pIsHeld, |
- void *plContext) |
-{ |
- PKIX_ENTER(RWLOCK, "PKIX_PL_IsWriterLockHeld"); |
- PKIX_NULLCHECK_TWO(lock, pIsHeld); |
- |
- *pIsHeld = lock->writeLocked; |
- |
- PKIX_RETURN(RWLOCK); |
-} |