Acquire the event waiters lock.
data:image/s3,"s3://crabby-images/f0f7e/f0f7e018a4adf2565c687fded8132114e57ed6bc" alt=""
C# | Visual Basic | Visual C++ |
public static void LockEventWaiters( MonoUsbSessionHandle sessionHandle )
Public Shared Sub LockEventWaiters ( _ sessionHandle As MonoUsbSessionHandle _ )
public: static void LockEventWaiters( [InAttribute] MonoUsbSessionHandle^ sessionHandle )
data:image/s3,"s3://crabby-images/f0f7e/f0f7e018a4adf2565c687fded8132114e57ed6bc" alt=""
- sessionHandle (MonoUsbSessionHandle)
- A valid MonoUsbSessionHandle.
data:image/s3,"s3://crabby-images/f0f7e/f0f7e018a4adf2565c687fded8132114e57ed6bc" alt=""
This lock is designed to be obtained under the situation where you want to be aware when events are completed, but some other thread is event handling so calling libusb_handle_events is not allowed.
You then obtain this lock, re-check that another thread is still handling events, then call libusb_wait_for_event.
You only need to use this lock if you are developing an application which calls poll() or select() on libusb's file descriptors directly, and may potentially be handling events from 2 threads simultaenously. If you stick to libusb's event handling loop functions (e.g. libusb_handle_events) then you do not need to be concerned with this locking.
data:image/s3,"s3://crabby-images/a9792/a979293104a5d08b085fe60c0d6c5da7ce772a08" alt=""