2005-10-12 21:50:36 +08:00
|
|
|
/
|
|
|
|
/ Copyright (C) Igor Sysoev
|
|
|
|
/
|
|
|
|
|
|
|
|
/ ngx_atomic_uint_t ngx_atomic_cmp_set(ngx_atomic_t *lock,
|
|
|
|
/ ngx_atomic_uint_t old, ngx_atomic_uint_t set);
|
|
|
|
/
|
2009-05-08 17:41:43 +08:00
|
|
|
/ the arguments are passed on stack (%esp), 4(%esp), 8(%esp)
|
2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
.inline ngx_atomic_cmp_set,0
|
|
|
|
movl (%esp), %ecx
|
|
|
|
movl 4(%esp), %eax
|
|
|
|
movl 8(%esp), %edx
|
|
|
|
lock
|
|
|
|
cmpxchgl %edx, (%ecx)
|
|
|
|
setz %al
|
|
|
|
movzbl %al, %eax
|
|
|
|
.end
|
|
|
|
|
|
|
|
|
|
|
|
/ ngx_atomic_int_t ngx_atomic_fetch_add(ngx_atomic_t *value,
|
|
|
|
/ ngx_atomic_int_t add);
|
|
|
|
/
|
2009-05-08 17:41:43 +08:00
|
|
|
/ the arguments are passed on stack (%esp), 4(%esp)
|
2005-10-12 21:50:36 +08:00
|
|
|
|
|
|
|
.inline ngx_atomic_fetch_add,0
|
|
|
|
movl (%esp), %ecx
|
|
|
|
movl 4(%esp), %eax
|
|
|
|
lock
|
|
|
|
xaddl %eax, (%ecx)
|
|
|
|
.end
|
2007-07-16 16:54:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
/ ngx_cpu_pause()
|
2009-05-08 17:41:43 +08:00
|
|
|
/
|
|
|
|
/ the "rep; nop" is used instead of "pause" to avoid the "[ PAUSE ]" hardware
|
|
|
|
/ capability added by linker because Solaris/i386 does not know about it:
|
|
|
|
/
|
|
|
|
/ ld.so.1: nginx: fatal: hardware capability unsupported: 0x2000 [ PAUSE ]
|
2007-07-16 16:54:04 +08:00
|
|
|
|
|
|
|
.inline ngx_cpu_pause,0
|
2009-05-08 17:41:43 +08:00
|
|
|
rep; nop
|
2007-07-16 16:54:04 +08:00
|
|
|
.end
|