2003-12-19 16:15:11 +08:00
|
|
|
#ifndef _NGX_ATOMIC_H_INCLUDED_
|
|
|
|
#define _NGX_ATOMIC_H_INCLUDED_
|
|
|
|
|
|
|
|
|
|
|
|
#include <ngx_config.h>
|
|
|
|
#include <ngx_core.h>
|
|
|
|
|
|
|
|
|
2004-02-24 04:57:12 +08:00
|
|
|
#ifdef __i386__
|
|
|
|
|
|
|
|
typedef uint32_t ngx_atomic_t;
|
|
|
|
|
|
|
|
#if (NGX_SMP)
|
|
|
|
#define NGX_SMP_LOCK "lock"
|
|
|
|
#else
|
|
|
|
#define NGX_SMP_LOCK
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
static ngx_inline uint32_t ngx_atomic_inc(ngx_atomic_t *value)
|
|
|
|
{
|
|
|
|
uint32_t old;
|
|
|
|
|
|
|
|
__asm__ __volatile ("
|
|
|
|
|
|
|
|
movl $1, %0
|
|
|
|
" NGX_SMP_LOCK
|
|
|
|
" xaddl %0, %1
|
|
|
|
|
|
|
|
": "=a" (old) : "m" (*value));
|
|
|
|
|
|
|
|
return old;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static ngx_inline uint32_t ngx_atomic_dec(ngx_atomic_t *value)
|
|
|
|
{
|
|
|
|
uint32_t old;
|
|
|
|
|
|
|
|
__asm__ __volatile ("
|
|
|
|
|
|
|
|
movl $-1, %0
|
|
|
|
" NGX_SMP_LOCK
|
|
|
|
" xaddl %0, %1
|
|
|
|
|
|
|
|
": "=a" (old) : "m" (*value));
|
|
|
|
|
|
|
|
return old;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static ngx_inline uint32_t ngx_atomic_cmp_set(ngx_atomic_t *lock,
|
|
|
|
ngx_atomic_t old,
|
|
|
|
ngx_atomic_t set)
|
|
|
|
{
|
|
|
|
uint32_t res;
|
|
|
|
|
|
|
|
__asm__ __volatile ("
|
|
|
|
|
|
|
|
" NGX_SMP_LOCK
|
|
|
|
" cmpxchgl %3, %1
|
|
|
|
setzb %%al
|
|
|
|
movzbl %%al, %0
|
|
|
|
|
|
|
|
": "=a" (res) : "m" (*lock), "a" (old), "q" (set));
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
typedef uint32_t ngx_atomic_t;
|
|
|
|
|
2003-12-19 20:45:27 +08:00
|
|
|
/* STUB */
|
2003-12-19 16:15:11 +08:00
|
|
|
#define ngx_atomic_inc(x) x++;
|
|
|
|
#define ngx_atomic_dec(x) x--;
|
2004-02-24 04:57:12 +08:00
|
|
|
#define ngx_atomic_cmp_set(lock, old, set) 1;
|
|
|
|
/**/
|
|
|
|
|
|
|
|
#endif
|
2003-12-19 16:15:11 +08:00
|
|
|
|
|
|
|
|
|
|
|
#endif /* _NGX_ATOMIC_H_INCLUDED_ */
|