Subversion Repositories HelenOS

Rev

Rev 3022 | Go to most recent revision | Show entire file | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 3022 Rev 4055
Line 56... Line 56...
56
    long tmp, v;
56
    long tmp, v;
57
 
57
   
58
    asm volatile (
58
    asm volatile (
59
        "1:\n"
59
        "1:\n"
60
        "   ll %0, %1\n"
60
        "   ll %0, %1\n"
61
        "   addiu %0, %0, %3\n" /* same as addi, but never traps on overflow */
61
        "   addu %0, %0, %3\n"  /* same as addi, but never traps on overflow */
62
        "       move %2, %0\n"
62
        "   move %2, %0\n"
63
        "   sc %0, %1\n"
63
        "   sc %0, %1\n"
64
        "   beq %0, %4, 1b\n"   /* if the atomic operation failed, try again */
64
        "   beq %0, %4, 1b\n"   /* if the atomic operation failed, try again */
65
        "   nop\n"
65
        "   nop\n"
66
        : "=r" (tmp), "=m" (val->count), "=r" (v)
66
        : "=&r" (tmp), "+m" (val->count), "=&r" (v)
67
        : "i" (i), "i" (0)
67
        : "r" (i), "i" (0)
-
 
68
    );
-
 
69
   
-
 
70
    return v;
-
 
71
}
-
 
72
 
-
 
73
static inline uint32_t test_and_set(atomic_t *val) {
-
 
74
    uint32_t tmp, v;
-
 
75
   
-
 
76
    asm volatile (
-
 
77
        "1:\n"
-
 
78
        "   ll %2, %1\n"
-
 
79
        "   bnez %2, 2f\n"
-
 
80
        "   li %0, %3\n"
-
 
81
        "   sc %0, %1\n"
-
 
82
        "   beqz %0, 1b\n"
-
 
83
        "2:\n"
-
 
84
        : "=&r" (tmp), "+m" (val->count), "=&r" (v)
-
 
85
        : "i" (1)
68
        );
86
    );
69
 
87
   
70
    return v;
88
    return v;
71
}
89
}
72
 
90