blob: 86b6edec9da065138df10d382aedc6ada3b51a71 (
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
/* $OpenBSD: atomic.h,v 1.7 2009/03/04 19:37:14 miod Exp $ */
/* Public Domain */
#ifndef __M88K_ATOMIC_H__
#define __M88K_ATOMIC_H__
#if defined(_KERNEL)
#ifdef MULTIPROCESSOR
/* actual implementation is hairy, see atomic.S */
void atomic_setbits_int(__volatile unsigned int *, unsigned int);
void atomic_clearbits_int(__volatile unsigned int *, unsigned int);
#else
#include <machine/asm_macro.h>
#include <machine/psl.h>
static __inline void
atomic_setbits_int(__volatile unsigned int *uip, unsigned int v)
{
u_int psr;
psr = get_psr();
set_psr(psr | PSR_IND);
*uip |= v;
set_psr(psr);
}
static __inline void
atomic_clearbits_int(__volatile unsigned int *uip, unsigned int v)
{
u_int psr;
psr = get_psr();
set_psr(psr | PSR_IND);
*uip &= ~v;
set_psr(psr);
}
#endif /* MULTIPROCESSOR */
static __inline__ unsigned int
atomic_clear_int(__volatile unsigned int *uip)
{
u_int oldval;
oldval = 0;
__asm__ __volatile__
("xmem %0, %2, r0" : "+r"(oldval), "+m"(*uip) : "r"(uip));
return oldval;
}
#endif /* defined(_KERNEL) */
#endif /* __M88K_ATOMIC_H__ */
|