Macros | Typedefs | Enumerations | Functions | Variables
Lock

The Eina lock libraries provide thread locking and sychronization capabilities similar to POISIX threads (pthreads), but it takes care of the platform specific details so you don't have to. More...

Macros

#define EINA_MAIN_LOOP_CHECK_RETURN_VAL(val)
 The macro doesn't do anything unless EINA_HAVE_DEBUG_THREADS is defined. More...
 
#define EINA_MAIN_LOOP_CHECK_RETURN
 The macro doesn't do anything unless EINA_HAVE_DEBUG_THREADS is defined.
 

Typedefs

typedef void(* Eina_TLS_Delete_Cb )(void *ptr)
 Type definition for deallocation callbacks for thread level sotrage data. More...
 
typedef struct _Eina_Barrier Eina_Barrier
 An opaque type for working with barrier locks.
 
typedef struct _Eina_Lock Eina_Lock
 An opaque type for working with locks.
 
typedef struct _Eina_Condition Eina_Condition
 An opaque type that represents a condition variable.
 
typedef struct _Eina_RWLock Eina_RWLock
 An opaque type for working with read/write locks.
 
typedef pthread_key_t Eina_TLS
 An opaque type for working with thread level storage.
 
typedef sem_t Eina_Semaphore
 An opaque type for working with semaphores.
 
typedef Eina_Lock Eina_Spinlock
 An opaque type for working with spinlocks.
 

Enumerations

enum  Eina_Lock_Result {
  EINA_LOCK_FAIL = EINA_FALSE,
  EINA_LOCK_SUCCEED = EINA_TRUE,
  EINA_LOCK_DEADLOCK
}
 Return codes for lock operations. More...
 

Functions

static Eina_Bool eina_lock_new (Eina_Lock *mutex)
 Initializes a new Eina_Lock. More...
 
static void eina_lock_free (Eina_Lock *mutex)
 Deallocates an Eina_Lock. More...
 
static Eina_Lock_Result eina_lock_take (Eina_Lock *mutex)
 Attempts to take a lock. More...
 
static Eina_Lock_Result eina_lock_take_try (Eina_Lock *mutex)
 Attempts to take a lock. More...
 
static Eina_Lock_Result eina_lock_release (Eina_Lock *mutex)
 Releases a lock. More...
 
static void eina_lock_debug (const Eina_Lock *mutex)
 Print debug information about a lock. More...
 
static Eina_Bool eina_condition_new (Eina_Condition *cond, Eina_Lock *mutex)
 Initializes a new condition variable. More...
 
static void eina_condition_free (Eina_Condition *cond)
 Deallocates a condition variable. More...
 
static Eina_Bool eina_condition_wait (Eina_Condition *cond)
 Causes a thread to wait until signaled by the condition. More...
 
static Eina_Bool eina_condition_timedwait (Eina_Condition *cond, double t)
 Causes a thread to wait until signaled by the condition or a timeout is reached. More...
 
static Eina_Bool eina_condition_broadcast (Eina_Condition *cond)
 Signal all threads waiting for a condition. More...
 
static Eina_Bool eina_condition_signal (Eina_Condition *cond)
 Signal a thread waiting for a condition. More...
 
static Eina_Bool eina_rwlock_new (Eina_RWLock *mutex)
 Initializes a new Eina_RWLock. More...
 
static void eina_rwlock_free (Eina_RWLock *mutex)
 Deallocates an Eina_RWLock. More...
 
static Eina_Lock_Result eina_rwlock_take_read (Eina_RWLock *mutex)
 Attempts to take a read lock. More...
 
static Eina_Lock_Result eina_rwlock_take_write (Eina_RWLock *mutex)
 Attempts to take a write lock. More...
 
static Eina_Lock_Result eina_rwlock_release (Eina_RWLock *mutex)
 Releases a lock. More...
 
static Eina_Bool eina_tls_new (Eina_TLS *key)
 Initializes a new Eina_TLS, or thread level storage, to store thread specific data. More...
 
static Eina_Bool eina_tls_cb_new (Eina_TLS *key, Eina_TLS_Delete_Cb delete_cb)
 Initializes a new Eina_TLS, or thread level storage, to store thread specific data. More...
 
static void eina_tls_free (Eina_TLS key)
 Frees an allocated Eina_TLS. More...
 
static void * eina_tls_get (Eina_TLS key)
 Gets the value in Eina_TLS for this thread. More...
 
static Eina_Bool eina_tls_set (Eina_TLS key, const void *data)
 Sets the value in Eina_TLS for this thread. More...
 
static Eina_Bool eina_semaphore_new (Eina_Semaphore *sem, int count_init)
 Initializes a new Eina_Semaphore. More...
 
static Eina_Bool eina_semaphore_free (Eina_Semaphore *sem)
 Frees an allocated Eina_Semaphore. More...
 
static Eina_Bool eina_semaphore_lock (Eina_Semaphore *sem)
 Gets a lock on an Eina_Semaphore. More...
 
static Eina_Bool eina_semaphore_release (Eina_Semaphore *sem, int count_release)
 Releases a lock on an Eina_Semaphore. More...
 
static Eina_Bool eina_barrier_new (Eina_Barrier *barrier, int needed)
 Initializes a new Eina_Barrier. More...
 
static void eina_barrier_free (Eina_Barrier *barrier)
 Frees an allocated Eina_Barrier. More...
 
static Eina_Bool eina_barrier_wait (Eina_Barrier *barrier)
 Increments the count of threads that are waiting on barrier. More...
 
static Eina_Bool eina_spinlock_new (Eina_Spinlock *spinlock)
 Initializes a new Eina_Spinlock. More...
 
static Eina_Lock_Result eina_spinlock_take (Eina_Spinlock *spinlock)
 Attempts to take a spinlock. More...
 
static Eina_Lock_Result eina_spinlock_take_try (Eina_Spinlock *spinlock)
 Attempts to take a spinlock. More...
 
static Eina_Lock_Result eina_spinlock_release (Eina_Spinlock *spinlock)
 Releases a spinlock. More...
 
static void eina_spinlock_free (Eina_Spinlock *spinlock)
 Deallocates an Eina_Spinlock. More...
 

Variables

Eina_Error EINA_ERROR_NOT_MAIN_LOOP
 A type definition for warning that a function was called from somewhere other than the EFL main loop. More...
 

Detailed Description

The Eina lock libraries provide thread locking and sychronization capabilities similar to POISIX threads (pthreads), but it takes care of the platform specific details so you don't have to.

If you know how pthreads work, this library will look familiar to you. If you are not familiar with pthreads, a good overview is available here

The Eina lock functions are grouped into several categories to handle different thread locking and sychronization methods:

Macro Definition Documentation

#define EINA_MAIN_LOOP_CHECK_RETURN_VAL (   val)

The macro doesn't do anything unless EINA_HAVE_DEBUG_THREADS is defined.

Parameters
valThe value to be returned.

Referenced by _ecore_timer_interval_get(), _ecore_timer_pending_get(), ecore_animator_del(), ecore_animator_frametime_get(), ecore_animator_source_get(), ecore_event_add(), ecore_event_current_event_get(), ecore_event_current_type_get(), ecore_event_del(), ecore_event_filter_add(), ecore_event_filter_del(), ecore_event_handler_add(), ecore_event_handler_data_get(), ecore_event_handler_data_set(), ecore_event_handler_del(), ecore_event_type_new(), ecore_exe_cmd_get(), ecore_exe_data_get(), ecore_exe_data_set(), ecore_exe_event_data_get(), ecore_exe_flags_get(), ecore_exe_free(), ecore_exe_pid_get(), ecore_exe_pipe_run(), ecore_exe_run(), ecore_exe_run_priority_get(), ecore_exe_send(), ecore_exe_tag_get(), ecore_idle_enterer_del(), ecore_idle_exiter_del(), ecore_idler_del(), ecore_job_del(), ecore_main_fd_handler_active_get(), ecore_main_fd_handler_add(), ecore_main_fd_handler_del(), ecore_main_fd_handler_fd_get(), ecore_main_fd_handler_file_add(), ecore_main_loop_iterate_may_block(), ecore_main_loop_select_func_get(), ecore_pipe_del(), ecore_poller_del(), ecore_poller_poll_interval_get(), ecore_thread_active_get(), ecore_thread_feedback_run(), ecore_thread_max_get(), ecore_thread_pending_feedback_get(), ecore_thread_pending_get(), ecore_thread_pending_total_get(), ecore_thread_run(), ecore_throttle_get(), ecore_timer_add(), ecore_timer_del(), and ecore_timer_precision_get().

Typedef Documentation

typedef void(* Eina_TLS_Delete_Cb)(void *ptr)

Type definition for deallocation callbacks for thread level sotrage data.

A simple function pointer.

Enumeration Type Documentation

Return codes for lock operations.

Enumerator
EINA_LOCK_FAIL 

Indicates that the lock operation failed.

EINA_LOCK_SUCCEED 

Indicates that the lock operation succeeded.

EINA_LOCK_DEADLOCK 

Indicates that the lock is deadlocked.

Function Documentation

static Eina_Bool eina_lock_new ( Eina_Lock mutex)
inlinestatic

Initializes a new Eina_Lock.

This function initializes an Eina_Lock with appropriate values. These values are platform dependent as is the structure of the Eina_Lock itself.

Parameters
mutexThe Eina_Lock structure to be initialized.
Returns
EINA_TRUE on success, else EINA_FALSE.
Examples:
ecore_thread_example.c.

Referenced by ecore_init(), ecore_main_loop_thread_safe_call_sync(), ecore_thread_main_loop_begin(), eet_init(), eina_file_open(), eina_file_virtualize(), and eio_init().

static void eina_lock_free ( Eina_Lock mutex)
inlinestatic

Deallocates an Eina_Lock.

This function deallocates an Eina_Lock and does any platform dependent cleanup that is required.

Parameters
mutexThe Eina_Lock structure to be deallocated.
Examples:
ecore_thread_example.c.

Referenced by ecore_shutdown(), eet_shutdown(), and eio_shutdown().

static Eina_Lock_Result eina_lock_take ( Eina_Lock mutex)
inlinestatic

Attempts to take a lock.

This function attempts to gain a lock on the indicated Eina_Lock. If the underlying Eina_Lock is locked already, this call will block until the lock is released. This is appropriate in many cases, but consider using eina_lock_take_try if you don't need to block.

Parameters
mutexThe Eina_Lock to take.
Returns
Returns EINA_LOCK_SUCCEED on success. If the operation fails because a deadlock condition exists, it will return EINA_LOCK_DEADLOCK. If some other condition causes the take to fail, EINA_LOCK_FAIL is returned.
Examples:
ecore_thread_example.c.

Referenced by ecore_fork_reset(), ecore_main_loop_thread_safe_call_sync(), ecore_thread_main_loop_begin(), ecore_thread_main_loop_end(), efreet_desktop_category_add(), efreet_desktop_category_del(), efreet_desktop_free(), efreet_desktop_new(), efreet_desktop_ref(), efreet_desktop_x_field_del(), efreet_desktop_x_field_set(), efreet_util_path_to_file_id(), eina_file_close(), eina_file_dup(), eina_file_flush(), eina_file_map_all(), eina_file_map_faulted(), eina_file_map_free(), eina_file_map_lines(), eina_file_map_new(), eina_file_map_populate(), eina_file_open(), eina_file_virtual_map_all(), eina_file_virtual_map_free(), eina_file_virtual_map_new(), eina_tmpstr_add_length(), eina_tmpstr_del(), eina_tmpstr_strlen(), and eio_memory_burst_limit_set().

static Eina_Lock_Result eina_lock_take_try ( Eina_Lock mutex)
inlinestatic

Attempts to take a lock.

This function attempts to gain a lock on the indicated Eina_Lock. Identical to eina_lock_take, but returns immediately if the lock is already taken.

Parameters
mutexThe Eina_Lock to take.
Returns
Returns EINA_LOCK_SUCCEED on success. If the operation fails because a deadlock condition exists, it will return EINA_LOCK_DEADLOCK. If some other condition causes the take to fail, EINA_LOCK_FAIL is returned.
Examples:
ecore_thread_example.c.
static Eina_Lock_Result eina_lock_release ( Eina_Lock mutex)
inlinestatic

Releases a lock.

This function will release the lock on the indicated Eina_Lock. If successful, and EINA_HAVE_DEBUG_THREADS is defined, mutex is updated and information about the locking process is removed (e.g. thread number and backtrace for POSIX).

Parameters
mutexThe Eina_Lock to release.
Returns
Returns EINA_LOCK_SUCCEED on success. If it fails, EINA_LOCK_FAIL is returned.
Examples:
ecore_thread_example.c.

Referenced by ecore_fork_reset(), ecore_main_loop_thread_safe_call_sync(), ecore_thread_main_loop_begin(), ecore_thread_main_loop_end(), efreet_desktop_category_add(), efreet_desktop_category_del(), efreet_desktop_free(), efreet_desktop_new(), efreet_desktop_ref(), efreet_desktop_x_field_del(), efreet_desktop_x_field_set(), efreet_util_path_to_file_id(), eina_file_close(), eina_file_dup(), eina_file_flush(), eina_file_map_all(), eina_file_map_faulted(), eina_file_map_free(), eina_file_map_lines(), eina_file_map_new(), eina_file_map_populate(), eina_file_open(), eina_file_virtual_map_all(), eina_file_virtual_map_free(), eina_file_virtual_map_new(), eina_tmpstr_add_length(), eina_tmpstr_del(), eina_tmpstr_strlen(), and eio_memory_burst_limit_set().

static void eina_lock_debug ( const Eina_Lock mutex)
inlinestatic

Print debug information about a lock.

This function will print debug information for mutex. The information is platform dependant. On POSIX systems it will print the address of mutex, lock state, thread number and a backtrace.

Parameters
mutexThe Eina_Lock to print debug info for.
Note
If EINA_HAVE_DEBUG_THREADS is not defined, this function does nothing.
This function is implemented on Win32 or WinCE, but it will not produce any output, regardless of EINA_HAVE_DEBUG_THREADS being set.

Referenced by eina_threads_shutdown().

static Eina_Bool eina_condition_new ( Eina_Condition cond,
Eina_Lock mutex 
)
inlinestatic

Initializes a new condition variable.

This function initializes an Eina_Condition structure and associates it with an existing lock.

Condition variables are used to coordinate actions between threads. See Condition Varable Overview for an introduction to condition variables and their use.

Parameters
condThe condition variable to create.
mutexThe _Eina_Lock structure that controls access to this condition variable.
Returns
EINA_TRUE on success, else EINA_FALSE.
Examples:
ecore_thread_example.c.

Referenced by ecore_init(), ecore_main_loop_thread_safe_call_sync(), ecore_thread_main_loop_begin(), and eio_init().

static void eina_condition_free ( Eina_Condition cond)
inlinestatic

Deallocates a condition variable.

This function deallocates a condition variable and does any platform dependent cleanup that is required.

Parameters
condThe condition variable to be deallocated.
Examples:
ecore_thread_example.c.

Referenced by ecore_shutdown(), and eio_shutdown().

static Eina_Bool eina_condition_wait ( Eina_Condition cond)
inlinestatic

Causes a thread to wait until signaled by the condition.

This function makes a thread block until a signal is sent to it via cond.

Parameters
condThe Eina_Condition upon which the thread will wait.
Returns
EINA_TRUE on success, else EINA_FALSE.
Examples:
ecore_thread_example.c.

Referenced by ecore_main_loop_thread_safe_call_sync(), ecore_thread_main_loop_begin(), and ecore_thread_main_loop_end().

static Eina_Bool eina_condition_timedwait ( Eina_Condition cond,
double  t 
)
inlinestatic

Causes a thread to wait until signaled by the condition or a timeout is reached.

This function makes a thread block until either a signal is sent to it via cond or t seconds have passed.

Parameters
condThe Eina_Condition upon which the thread will wait.
tThe maximum amount of time to wait, in seconds.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_condition_broadcast ( Eina_Condition cond)
inlinestatic

Signal all threads waiting for a condition.

This function sends a signal to all the threads waiting on the condition cond. If you know for sure that there is only one thread waiting, use eina_condition_signal instead to gain a little optimization.

Parameters
condThe Eina_Condition that will signal all its waiting threads.
Returns
EINA_TRUE on success, else EINA_FALSE.

Referenced by ecore_thread_main_loop_end(), and eio_memory_burst_limit_set().

static Eina_Bool eina_condition_signal ( Eina_Condition cond)
inlinestatic

Signal a thread waiting for a condition.

This function sends a signal to a thread waiting on the condition cond. If you do not know for sure that there is only one thread waiting, use eina_condition_broadcast instead.

If there is more than one thread waiting on this condition, one of them will be signalled, but which one is undefined.

Parameters
condThe Eina_Condition that will signal its waiting thread.
Returns
EINA_TRUE on success, else EINA_FALSE.
Examples:
ecore_thread_example.c.
static Eina_Bool eina_rwlock_new ( Eina_RWLock mutex)
inlinestatic

Initializes a new Eina_RWLock.

This function initializes an Eina_RWLock with appropriate values. These values are platform dependent as is the structure of the Eina_RWLock itself.

Parameters
mutexThe Eina_RWLock to be initialized.
Returns
EINA_TRUE on success, else EINA_FALSE.
static void eina_rwlock_free ( Eina_RWLock mutex)
inlinestatic

Deallocates an Eina_RWLock.

This function deallocates an Eina_RWLock and does any platform dependent cleanup that is required.

Parameters
mutexThe Eina_RWLock structure to be deallocated.
static Eina_Lock_Result eina_rwlock_take_read ( Eina_RWLock mutex)
inlinestatic

Attempts to take a read lock.

This function attempts to gain a read lock on the indicated Eina_RWLock. If the Eina_RWLock is write locked, this call will block until the lock is released.

Parameters
mutexThe Eina_RWLock to take.
Returns
Returns EINA_LOCK_SUCCEED on success, EINA_LOCK_FAIL on failure.
Note
This function will never return EINA_LOCK_DEADLOCK.
static Eina_Lock_Result eina_rwlock_take_write ( Eina_RWLock mutex)
inlinestatic

Attempts to take a write lock.

This function attempts to gain a write lock on the indicated Eina_RWLock. If the Eina_RWLock is locked for reading or writing, this call will block until the lock is released.

Parameters
mutexThe Eina_RWLock to take.
Returns
Returns EINA_LOCK_SUCCEED on success, EINA_LOCK_FAIL on failure.
Note
This function will never return EINA_LOCK_DEADLOCK.
static Eina_Lock_Result eina_rwlock_release ( Eina_RWLock mutex)
inlinestatic

Releases a lock.

This function will release the lock on the indicated Eina_RWLock.

Parameters
mutexThe Eina_RWLock to release.
Returns
Returns EINA_LOCK_SUCCEED on success. If it fails, EINA_LOCK_FAIL is returned.
static Eina_Bool eina_tls_new ( Eina_TLS key)
inlinestatic

Initializes a new Eina_TLS, or thread level storage, to store thread specific data.

This function initializes an Eina_TLS with key but does not set a callback to deallocate key when the thread exits. The implementation is platform dependent as is the structure of the Eina_TLS itself.

Parameters
keyThe Eina_TLS to be initialized.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_tls_cb_new ( Eina_TLS key,
Eina_TLS_Delete_Cb  delete_cb 
)
inlinestatic

Initializes a new Eina_TLS, or thread level storage, to store thread specific data.

This function initializes an Eina_TLS with key and sets a callback to deallocate key when the thread exits. The implementation is platform dependent as is the structure of the Eina_TLS itself.

Parameters
keyThe Eina_TLS to be initialized.
delete_cbA pointer to a function that will deallocate key.
Returns
EINA_TRUE on success, else EINA_FALSE.
static void eina_tls_free ( Eina_TLS  key)
inlinestatic

Frees an allocated Eina_TLS.

This function frees the Eina_TLS key. The implementation is platform dependent.

Parameters
keyThe Eina_TLS to be freed.
static void* eina_tls_get ( Eina_TLS  key)
inlinestatic

Gets the value in Eina_TLS for this thread.

This function gets a pointer to the data associated with Eina_TLS key for this thread. The implementation is platform dependent.

Parameters
keyThe Eina_TLS to be retrieved.
Returns
A pointer to the data associated with key.

Referenced by eina_error_get().

static Eina_Bool eina_tls_set ( Eina_TLS  key,
const void *  data 
)
inlinestatic

Sets the value in Eina_TLS for this thread.

This function sets the value associated with key to the pointer to the data data. The implementation is platform dependent.

Parameters
keyThe Eina_TLS to be set.
dataA pointer to the data to be stored.
Returns
EINA_TRUE on success, else EINA_FALSE.

Referenced by eina_error_set().

static Eina_Bool eina_semaphore_new ( Eina_Semaphore sem,
int  count_init 
)
inlinestatic

Initializes a new Eina_Semaphore.

This function initializes an unnamed Eina_Semaphore with appropriate values. These values are platform dependent.

Be aware that the behavior of the parameter count_init differs by platform.

  • POSIX: Indicates whether this semaphore can be shared by between processes. Greater than 0 == shared.
  • Win32: Indicates the initial count of threads waiting on this semaphore.
Note
Semaphores are not avialable on the WinCE platform.
Parameters
semThe Eina_Semaphore to be initialized.
count_initBehavior is platofrm specific. See above.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_semaphore_free ( Eina_Semaphore sem)
inlinestatic

Frees an allocated Eina_Semaphore.

This function frees the Eina_Semaphore sem. The implementation is platform dependent.

Parameters
semThe Eina_Semaphore to be freed.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_semaphore_lock ( Eina_Semaphore sem)
inlinestatic

Gets a lock on an Eina_Semaphore.

This function locks the Eina_Semaphore sem. The implementation is platform dependent.

Parameters
semThe Eina_Semaphore to lock.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_semaphore_release ( Eina_Semaphore sem,
int  count_release 
)
inlinestatic

Releases a lock on an Eina_Semaphore.

This function releases a lock on the Eina_Semaphore sem. The implementation is platform dependent.

Parameters
semThe Eina_Semaphore to release.
count_releaseNot used.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_barrier_new ( Eina_Barrier barrier,
int  needed 
)
inlinestatic

Initializes a new Eina_Barrier.

This function initializes a new Eina_Barrier. It will set the needed flag to the value of needed, set the barrier's count member to 0 and will create new Eina_Lock and Eina_Condition objects for the barrier.

Parameters
barrierThe Eina_Barrier to be initialized.
neededThe number of thread waits that will cause this barrier to be reset.
Returns
EINA_TRUE on success, else EINA_FALSE.
static void eina_barrier_free ( Eina_Barrier barrier)
inlinestatic

Frees an allocated Eina_Barrier.

This function frees the Eina_Barrier barrier.

Parameters
barrierThe Eina_Barrier to be freed.
static Eina_Bool eina_barrier_wait ( Eina_Barrier barrier)
inlinestatic

Increments the count of threads that are waiting on barrier.

When the count of threads reaches the needed value for the barrier, all waiting threads will be notified via eina_condition_broadcast.

Parameters
barrierThe Eina_Barrier to be incremented.
Returns
EINA_TRUE on success, else EINA_FALSE.
static Eina_Bool eina_spinlock_new ( Eina_Spinlock spinlock)
inlinestatic

Initializes a new Eina_Spinlock.

This function initializes a new Eina_Spinlock, if spinlocks are available. If spinlocks are not avialable, it will create a new Eina_Lock.

Note
Spinlocks are only implemented on the POSIX platform and are only available if EINA_HAVE_POSIX_SPINLOCK is defined. All other platforms will get a new Eina_Lock.
Parameters
spinlockThe Eina_Spinlock to be initialized.
Returns
EINA_TRUE on success, else EINA_FALSE.

Referenced by eio_init().

static Eina_Lock_Result eina_spinlock_take ( Eina_Spinlock spinlock)
inlinestatic

Attempts to take a spinlock.

This function attempts to gain a lock on the indicated Eina_Spinlock. If the underlying Eina_Spinlock is locked already, this call will block until the lock is released. This is appropriate in many cases, but consider using eina_spinlock_take_try if you don't need to block.

Parameters
spinlockThe Eina_Spinlock to take.
Returns
Returns EINA_LOCK_SUCCEED on success. If the operation fails because a deadlock condition exists, it will return EINA_LOCK_DEADLOCK. If some other condition causes the take to fail, EINA_LOCK_FAIL is returned.

Referenced by eet_dictionary_string_check(), eina_stringshare_add_length(), eina_stringshare_del(), eina_stringshare_ref(), and evas_async_events_put().

static Eina_Lock_Result eina_spinlock_take_try ( Eina_Spinlock spinlock)
inlinestatic

Attempts to take a spinlock.

This function attempts to gain a lock on the indicated Eina_Spinlock. Identical to eina_lock_take, but returns immediately if the lock is already taken.

Parameters
spinlockThe Eina_Spinlock to take.
Returns
Returns EINA_LOCK_SUCCEED on success. If the operation fails because a deadlock condition exists, it will return EINA_LOCK_DEADLOCK. If some other condition causes the take to fail, EINA_LOCK_FAIL is returned.
static Eina_Lock_Result eina_spinlock_release ( Eina_Spinlock spinlock)
inlinestatic

Releases a spinlock.

This function will release the lock on the indicated Eina_Spinlock. If successful, and EINA_HAVE_DEBUG_THREADS is defined, mutex is updated and information about the locking process is removed (e.g. thread number and backtrace for POSIX).

Parameters
spinlockThe Eina_Spinlock to release.
Returns
Returns EINA_LOCK_SUCCEED on success, else EINA_LOCK_FAIL.

Referenced by eet_dictionary_string_check(), eina_stringshare_add_length(), eina_stringshare_del(), eina_stringshare_ref(), and evas_async_events_put().

static void eina_spinlock_free ( Eina_Spinlock spinlock)
inlinestatic

Deallocates an Eina_Spinlock.

This function deallocates an Eina_Spinlock and does any platform dependent cleanup that is required.

Parameters
spinlockThe Eina_Spinlock to be deallocated.

Referenced by eio_shutdown().

Variable Documentation

Eina_Error EINA_ERROR_NOT_MAIN_LOOP

A type definition for warning that a function was called from somewhere other than the EFL main loop.