1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __LINUX_SPINLOCK_H_
3#define __LINUX_SPINLOCK_H_
4
5#include <pthread.h>
6#include <stdbool.h>
7
8#define spinlock_t		pthread_mutex_t
9#define DEFINE_SPINLOCK(x)	pthread_mutex_t x = PTHREAD_MUTEX_INITIALIZER
10#define __SPIN_LOCK_UNLOCKED(x)	(pthread_mutex_t)PTHREAD_MUTEX_INITIALIZER
11#define spin_lock_init(x)	pthread_mutex_init(x, NULL)
12
13#define spin_lock(x)			pthread_mutex_lock(x)
14#define spin_lock_nested(x, subclass)	pthread_mutex_lock(x)
15#define spin_unlock(x)			pthread_mutex_unlock(x)
16#define spin_lock_bh(x)			pthread_mutex_lock(x)
17#define spin_unlock_bh(x)		pthread_mutex_unlock(x)
18#define spin_lock_irq(x)		pthread_mutex_lock(x)
19#define spin_unlock_irq(x)		pthread_mutex_unlock(x)
20#define spin_lock_irqsave(x, f)		(void)f, pthread_mutex_lock(x)
21#define spin_unlock_irqrestore(x, f)	(void)f, pthread_mutex_unlock(x)
22
23#define arch_spinlock_t pthread_mutex_t
24#define __ARCH_SPIN_LOCK_UNLOCKED PTHREAD_MUTEX_INITIALIZER
25
26static inline void arch_spin_lock(arch_spinlock_t *mutex)
27{
28	pthread_mutex_lock(mutex);
29}
30
31static inline void arch_spin_unlock(arch_spinlock_t *mutex)
32{
33	pthread_mutex_unlock(mutex);
34}
35
36static inline bool arch_spin_is_locked(arch_spinlock_t *mutex)
37{
38	return true;
39}
40
41#endif
42