Mercurial > hg > nginx-vendor-current
annotate src/os/unix/rfork_thread.S @ 654:753f505670e0 NGINX_1_1_11
nginx 1.1.11
*) Feature: the "so_keepalive" parameter of the "listen" directive.
Thanks to Vsevolod Stakhov.
*) Feature: the "if_not_empty" parameter of the
"fastcgi/scgi/uwsgi_param" directives.
*) Feature: the $https variable.
*) Feature: the "proxy_redirect" directive supports variables in the
first parameter.
*) Feature: the "proxy_redirect" directive supports regular expressions.
*) Bugfix: the $sent_http_cache_control variable might contain a wrong
value if the "expires" directive was used.
Thanks to Yichun Zhang.
*) Bugfix: the "read_ahead" directive might not work combined with
"try_files" and "open_file_cache".
*) Bugfix: a segmentation fault might occur in a worker process if small
time was used in the "inactive" parameter of the "proxy_cache_path"
directive.
*) Bugfix: responses from cache might hang.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Mon, 12 Dec 2011 00:00:00 +0400 |
parents | da8c190bdaba |
children | d0f7a625f27c |
rev | line source |
---|---|
0 | 1 |
2 /* | |
3 * Copyright (C) Igor Sysoev | |
4 */ | |
5 | |
6 | |
7 #include <sys/syscall.h> | |
8 #include <machine/asm.h> | |
9 | |
10 /* | |
11 * rfork_thread(3) - rfork_thread(flags, stack, func, arg); | |
12 */ | |
13 | |
14 #define KERNCALL int $0x80 | |
15 | |
16 ENTRY(rfork_thread) | |
17 push %ebp | |
18 mov %esp, %ebp | |
19 push %esi | |
20 | |
32 | 21 mov 12(%ebp), %esi # the thread stack address |
0 | 22 |
23 sub $4, %esi | |
24 mov 20(%ebp), %eax # the thread argument | |
25 mov %eax, (%esi) | |
26 | |
27 sub $4, %esi | |
32 | 28 mov 16(%ebp), %eax # the thread start address |
0 | 29 mov %eax, (%esi) |
30 | |
31 push 8(%ebp) # rfork(2) flags | |
32 push $0 | |
33 mov $SYS_rfork, %eax | |
34 KERNCALL | |
35 jc error | |
36 | |
37 cmp $0, %edx | |
38 jne child | |
39 | |
40 parent: | |
41 add $8, %esp | |
42 pop %esi | |
32 | 43 leave |
0 | 44 ret |
45 | |
46 child: | |
47 mov %esi, %esp | |
48 pop %eax | |
49 call *%eax # call a thread start address ... | |
50 add $4, %esp | |
51 | |
52 push %eax | |
53 push $0 | |
54 mov $SYS_exit, %eax # ... and exit(2) after a thread would return | |
55 KERNCALL | |
56 | |
57 error: | |
58 add $8, %esp | |
59 pop %esi | |
32 | 60 leave |
0 | 61 PIC_PROLOGUE |
62 | |
63 /* libc's cerror: jmp PIC_PLT(HIDENAME(cerror)) */ | |
64 | |
65 push %eax | |
66 call PIC_PLT(CNAME(__error)) | |
67 pop %ecx | |
68 PIC_EPILOGUE | |
69 mov %ecx, (%eax) | |
70 mov $-1, %eax | |
71 mov $-1, %edx | |
72 ret |