+ExGetExclusiveWaiterCount()
[reactos.git] / ntoskrnl / ex / resource.c
index dfff5ac..9274c44 100644 (file)
@@ -395,8 +395,6 @@ ExAcquireResourceSharedLite (
    return(TRUE);
 }
 
-#ifndef LIBCAPTIVE
-
 VOID
 STDCALL
 ExConvertExclusiveToSharedLite (
@@ -441,12 +439,19 @@ ExConvertExclusiveToSharedLite (
        KeReleaseSpinLock(&Resource->SpinLock, oldIrql);
        return;
      }
+#ifndef LIBCAPTIVE
    /* else, awake the waiters */
    KeReleaseSemaphore(Resource->SharedWaiters,0,oldWaiters,0);
    KeReleaseSpinLock(&Resource->SpinLock, oldIrql);
    DPRINT("ExConvertExclusiveToSharedLite() finished\n");
+#else /* !LIBCAPTIVE */
+   /* no waiters allower for libcaptive */
+   KeBugCheck(0);
+#endif /* LIBCAPTIVE */
 }
 
+#ifndef LIBCAPTIVE
+
 VOID
 STDCALL
 ExDisableResourceBoostLite (
@@ -456,6 +461,8 @@ ExDisableResourceBoostLite (
    Resource->Flag |= ResourceDisableBoost;
 }
 
+#endif /* LIBCAPTIVE */
+
 ULONG
 STDCALL
 ExGetExclusiveWaiterCount (
@@ -465,7 +472,6 @@ ExGetExclusiveWaiterCount (
   return(Resource->NumberOfExclusiveWaiters);
 }
 
-#endif /* LIBCAPTIVE */
 
 BOOLEAN
 STDCALL
@@ -575,7 +581,6 @@ ExDeleteResourceLite (
    return(STATUS_SUCCESS);;
 }
 
-#ifndef LIBCAPTIVE
 
 ULONG
 STDCALL
@@ -586,6 +591,8 @@ ExGetSharedWaiterCount (
    return(Resource->NumberOfSharedWaiters);
 }
 
+#ifndef LIBCAPTIVE
+
 NTSTATUS
 STDCALL
 ExInitializeResource (
@@ -636,8 +643,6 @@ ExIsResourceAcquiredExclusiveLite (
          && Resource->OwnerThreads[0].OwnerThread==ExGetCurrentResourceThread());
 }
 
-#ifndef LIBCAPTIVE
-
 ULONG
 STDCALL
 ExIsResourceAcquiredSharedLite (
@@ -675,6 +680,7 @@ ExIsResourceAcquiredSharedLite (
    return(0);
 }
 
+
 VOID
 STDCALL
 ExReinitializeResourceLite (
@@ -699,7 +705,6 @@ ExReinitializeResourceLite (
    Resource->OwnerThreads[1].a.OwnerCount=0;
 }
 
-#endif /* LIBCAPTIVE */
 
 VOID
 FASTCALL