Subversion Repositories HelenOS-historic

Rev

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

Rev 248 Rev 259
Line 31... Line 31...
31
 
31
 
32
#include <arch/types.h>
32
#include <arch/types.h>
33
 
33
 
34
static inline void atomic_inc(volatile int *val) {
34
static inline void atomic_inc(volatile int *val) {
35
#ifdef __SMP__
35
#ifdef __SMP__
36
    __asm__ volatile ("lock incl (%0)\n" : : "r" (val));
36
    __asm__ volatile ("lock incl %0\n" : "=m" (*val));
37
#else
37
#else
38
    __asm__ volatile ("incl (%0)\n" : : "r" (val));
38
    __asm__ volatile ("incl %0\n" : "=m" (*val));
39
#endif /* __SMP__ */
39
#endif /* __SMP__ */
40
}
40
}
41
 
41
 
42
static inline void atomic_dec(volatile int *val) {
42
static inline void atomic_dec(volatile int *val) {
43
#ifdef __SMP__
43
#ifdef __SMP__
44
    __asm__ volatile ("lock decl (%0)\n" : : "r" (val));
44
    __asm__ volatile ("lock decl %0\n" : "=m" (*val));
45
#else
45
#else
46
    __asm__ volatile ("decl (%0)\n" : : "r" (val));
46
    __asm__ volatile ("decl %0\n" : "=m" (*val));
47
#endif /* __SMP__ */
47
#endif /* __SMP__ */
48
}
48
}
49
 
49
 
50
static inline int test_and_set(volatile int *val) {
50
static inline int test_and_set(volatile int *val) {
51
    int v;
51
    int v;
52
   
52
   
53
    __asm__ volatile (
53
    __asm__ volatile (
54
        "movl $1, %0\n"
54
        "movl $1, %0\n"
55
        "xchgl %0, (%1)\n"
55
        "xchgl %0, %1\n"
56
        : "=r" (v)
-
 
57
        : "r" (val)
56
        : "=r" (v),"=m" (*val)
58
    );
57
    );
59
   
58
   
60
    return v;
59
    return v;
61
}
60
}
62
 
61