annotate src/os/unix/ngx_sunpro_amd64.il @ 635:e67b227c8dbb default tip

Merge with current.
author Maxim Dounin <mdounin@mdounin.ru>
date Mon, 25 Apr 2011 04:07:55 +0400
parents be4f34123024
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
110
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1 /
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 / Copyright (C) Igor Sysoev
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 /
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 / ngx_atomic_uint_t ngx_atomic_cmp_set(ngx_atomic_t *lock,
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6 / ngx_atomic_uint_t old, ngx_atomic_uint_t set);
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 /
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 / the arguments are passed in %rdi, %rsi, %rdx
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 / the result is returned in the %rax
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11 .inline ngx_atomic_cmp_set,0
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 movq %rsi, %rax
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 lock
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14 cmpxchgq %rdx, (%rdi)
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 setz %al
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16 movzbq %al, %rax
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 .end
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 / ngx_atomic_int_t ngx_atomic_fetch_add(ngx_atomic_t *value,
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21 / ngx_atomic_int_t add);
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22 /
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23 / the arguments are passed in %rdi, %rsi
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24 / the result is returned in the %rax
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26 .inline ngx_atomic_fetch_add,0
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27 movq %rsi, %rax
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28 lock
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29 xaddq %rax, (%rdi)
dad2fe8ecf08 nginx 0.3.2
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30 .end
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
31
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
32
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
33 / ngx_cpu_pause()
579
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
34 /
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
35 / the "rep; nop" is used instead of "pause" to avoid the "[ PAUSE ]" hardware
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
36 / capability added by linker because Solaris/amd64 does not know about it:
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
37 /
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
38 / ld.so.1: nginx: fatal: hardware capability unsupported: 0x2000 [ PAUSE ]
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
39
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
40 .inline ngx_cpu_pause,0
579
be4f34123024 nginx 0.8.35
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
41 rep; nop
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
42 .end