2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) Igor Sysoev
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#if (NGX_PTR_SIZE == 4)
|
|
|
|
#define NGX_CASA ngx_casa
|
|
|
|
#else
|
|
|
|
#define NGX_CASA ngx_casxa
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
ngx_atomic_uint_t
|
|
|
|
ngx_casa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, ngx_atomic_t *lock);
|
|
|
|
|
|
|
|
ngx_atomic_uint_t
|
|
|
|
ngx_casxa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, ngx_atomic_t *lock);
|
|
|
|
|
|
|
|
/* the code in src/os/unix/ngx_sunpro_sparc64.il */
|
|
|
|
|
|
|
|
|
|
|
|
static ngx_inline ngx_atomic_uint_t
|
|
|
|
ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old,
|
|
|
|
ngx_atomic_uint_t set)
|
|
|
|
{
|
2007-04-27 22:36:28 +08:00
|
|
|
set = NGX_CASA(set, old, lock);
|
2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
return (set == old);
|
2005-11-15 21:30:52 +08:00
|
|
|
}
|
2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
|
|
|
|
static ngx_inline ngx_atomic_int_t
|
|
|
|
ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add)
|
|
|
|
{
|
|
|
|
ngx_atomic_uint_t old, res;
|
|
|
|
|
|
|
|
old = *value;
|
|
|
|
|
|
|
|
for ( ;; ) {
|
|
|
|
|
|
|
|
res = old + add;
|
|
|
|
|
2007-04-27 22:36:28 +08:00
|
|
|
res = NGX_CASA(res, old, value);
|
2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
if (res == old) {
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
old = res;
|
|
|
|
}
|
|
|
|
}
|
2005-10-19 20:33:58 +08:00
|
|
|
|
|
|
|
|
|
|
|
#define ngx_memory_barrier() \
|
|
|
|
__asm (".volatile"); \
|
|
|
|
__asm ("membar #LoadLoad | #LoadStore | #StoreStore | #StoreLoad"); \
|
|
|
|
__asm (".nonvolatile")
|
2006-02-08 23:33:12 +08:00
|
|
|
|
|
|
|
#define ngx_cpu_pause()
|