Subversion Repositories HelenOS-historic

Rev

Rev 625 | Rev 1001 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 625 Rev 990
Line 31... Line 31...
31
 
31
 
32
#include <arch/types.h>
32
#include <arch/types.h>
33
 
33
 
34
typedef struct { volatile __u32 count; } atomic_t;
34
typedef struct { volatile __u32 count; } atomic_t;
35
 
35
 
36
/*
-
 
37
 * TODO: these are just placeholders for real implementations of atomic_inc and atomic_dec.
-
 
38
 * WARNING: the following functions cause the code to be preemption-unsafe !!!
-
 
39
 */
-
 
40
 
-
 
41
static inline void atomic_inc(atomic_t *val) {
36
static inline void atomic_inc(atomic_t *val) {
42
    val->count++;
37
    __u32 tmp;
-
 
38
 
-
 
39
    asm __volatile__ (
-
 
40
        "1:\n"
-
 
41
        "lwarx %0, 0, %2\n"
-
 
42
        "addic %0, %0, 1\n"
-
 
43
        "stwcx. %0, 0, %2\n"
-
 
44
        "bne- 1b"
-
 
45
        : "=&r" (tmp), "=m" (val->count)
-
 
46
        : "r" (&val->count), "m" (val->count)
-
 
47
        : "cc");
43
}
48
}
44
 
49
 
45
static inline void atomic_dec(atomic_t *val) {
50
static inline void atomic_dec(atomic_t *val) {
46
    val->count--;
51
    __u32 tmp;
-
 
52
 
-
 
53
    asm __volatile__(
-
 
54
        "1:\n"
-
 
55
        "lwarx %0, 0, %2\n"
-
 
56
        "addic %0, %0, -1\n"
-
 
57
        "stwcx. %0, 0, %2\n"
-
 
58
        "bne- 1b"
-
 
59
        : "=&r" (tmp), "=m" (val->count)
-
 
60
        : "r" (&val->count), "m" (val->count)
-
 
61
        : "cc");
47
}
62
}
48
 
63
 
49
static inline void atomic_set(atomic_t *val, __u32 i)
64
static inline void atomic_set(atomic_t *val, __u32 i)
50
{
65
{
51
    val->count = i;
66
    val->count = i;