Mercurial > hg > nginx-ranges
annotate src/os/unix/rfork_thread.S @ 290:f745bf973510 NGINX_0_5_15
nginx 0.5.15
*) Feature: the mail proxy supports authenticated SMTP proxying and the
"smtp_auth", "smtp_capablities", and "xclient" directives.
Thanks to Anton Yuzhaninov and Maxim Dounin.
*) Feature: now the keep-alive connections are closed just after
receiving the reconfiguration signal.
*) Change: the "imap" and "auth" directives were renamed to the "mail"
and "pop3_auth" directives.
*) Bugfix: a segmentation fault occurred in worker process if the
CRAM-MD5 authentication method was used and the APOP method was
disabled.
*) Bugfix: if the "starttls only" directive was used in POP3 protocol,
then nginx allowed authentication without switching to the SSL mode.
*) Bugfix: worker processes did not exit after reconfiguration and did
not rotate logs if the eventport method was used.
*) Bugfix: a worker process may got caught in an endless loop, if the
"ip_hash" directive was used.
*) Bugfix: now nginx does not log some alerts if eventport or /dev/poll
methods are used.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Mon, 19 Mar 2007 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 |