Mercurial > hg > nginx-vendor-0-5
annotate src/os/unix/rfork_thread.S @ 330:c60beecc6ab5 NGINX_0_5_35
nginx 0.5.35
*) Change: now the ngx_http_userid_module adds start time microseconds
to the cookie field contains a pid value.
*) Change: now the uname(2) is used on Linux instead of procfs.
Thanks to Ilya Novikov.
*) Feature: the "If-Range" request header line support.
Thanks to Alexander V. Inyukhin.
*) Bugfix: in HTTPS mode requests might fail with the "bad write retry"
error; bug appeared in 0.5.13.
*) Bugfix: the STARTTLS in SMTP mode did not work.
Thanks to Oleg Motienko.
*) Bugfix: large_client_header_buffers did not freed before going to
keep-alive state.
Thanks to Olexander Shtepa.
*) Bugfix: the "limit_rate" directive did not allow to use full
throughput, even if limit value was very high.
*) Bugfix: the $status variable was equal to 0 if a proxied server
returned response in HTTP/0.9 version.
*) Bugfix: if the "?" character was in a "error_page" directive, then
it was escaped in a proxied request; bug appeared in 0.5.32.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Tue, 08 Jan 2008 00:00:00 +0300 |
parents | da8c190bdaba |
children |
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 |