Server IP : 13.213.54.232 / Your IP : 216.73.217.11 Web Server : Apache/2.4.52 (Ubuntu) System : Linux ip-172-31-17-110 6.8.0-1029-aws #31~22.04.1-Ubuntu SMP Thu Apr 24 21:16:18 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 7.1.33-67+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /proc/246940/root/usr/lib/modules/6.8.0-1031-aws/build/include/linux/ |
Upload File : |
#ifndef _LINUX_CALL_ONCE_H #define _LINUX_CALL_ONCE_H #include <linux/types.h> #include <linux/mutex.h> #define ONCE_NOT_STARTED 0 #define ONCE_RUNNING 1 #define ONCE_COMPLETED 2 struct once { atomic_t state; struct mutex lock; }; static inline void __once_init(struct once *once, const char *name, struct lock_class_key *key) { atomic_set(&once->state, ONCE_NOT_STARTED); __mutex_init(&once->lock, name, key); } #define once_init(once) \ do { \ static struct lock_class_key __key; \ __once_init((once), #once, &__key); \ } while (0) /* * call_once - Ensure a function has been called exactly once * * @once: Tracking struct * @cb: Function to be called * * If @once has never completed successfully before, call @cb and, if * it returns a zero or positive value, mark @once as completed. Return * the value returned by @cb * * If @once has completed succesfully before, return 0. * * The call to @cb is implicitly surrounded by a mutex, though for * efficiency the * function avoids taking it after the first call. */ static inline int call_once(struct once *once, int (*cb)(struct once *)) { int r, state; /* Pairs with atomic_set_release() below. */ if (atomic_read_acquire(&once->state) == ONCE_COMPLETED) return 0; guard(mutex)(&once->lock); state = atomic_read(&once->state); if (unlikely(state != ONCE_NOT_STARTED)) return WARN_ON_ONCE(state != ONCE_COMPLETED) ? -EINVAL : 0; atomic_set(&once->state, ONCE_RUNNING); r = cb(once); if (r < 0) atomic_set(&once->state, ONCE_NOT_STARTED); else atomic_set_release(&once->state, ONCE_COMPLETED); return r; } #endif /* _LINUX_CALL_ONCE_H */