summaryrefslogtreecommitdiff
path: root/src/arch/arm64/include/armv8/arch/smp/spinlock.h
blob: 10278e72ae15ef915cc085e316e6168f74b8b8f6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#ifndef ARCH_SMP_SPINLOCK_H
#define ARCH_SMP_SPINLOCK_H

#include <arch/barrier.h>
#include <stdint.h>

typedef struct {
	volatile uint32_t lock;
} spinlock_t;

#define SPIN_LOCK_UNLOCKED (spinlock_t) { 0 }
#define DECLARE_SPIN_LOCK(x) static spinlock_t x = SPIN_LOCK_UNLOCKED;

static inline void spin_lock(spinlock_t *spin)
{
	while (1) {
		if (load_acquire_exclusive(&spin->lock) != 0)
			continue;
		if (store_release_exclusive(&spin->lock, 1))
			break;
	}
}

static inline void spin_unlock(spinlock_t *spin)
{
	store_release(&spin->lock, 0);
}

#endif