]>
Commit | Line | Data |
---|---|---|
fea681da MK |
1 | .\" Copyright (c) 1983, 1991 The Regents of the University of California. |
2 | .\" All rights reserved. | |
3 | .\" | |
4 | .\" Redistribution and use in source and binary forms, with or without | |
5 | .\" modification, are permitted provided that the following conditions | |
6 | .\" are met: | |
7 | .\" 1. Redistributions of source code must retain the above copyright | |
8 | .\" notice, this list of conditions and the following disclaimer. | |
9 | .\" 2. Redistributions in binary form must reproduce the above copyright | |
10 | .\" notice, this list of conditions and the following disclaimer in the | |
11 | .\" documentation and/or other materials provided with the distribution. | |
12 | .\" 3. All advertising materials mentioning features or use of this software | |
13 | .\" must display the following acknowledgement: | |
14 | .\" This product includes software developed by the University of | |
15 | .\" California, Berkeley and its contributors. | |
16 | .\" 4. Neither the name of the University nor the names of its contributors | |
17 | .\" may be used to endorse or promote products derived from this software | |
18 | .\" without specific prior written permission. | |
19 | .\" | |
20 | .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND | |
21 | .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
22 | .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
23 | .\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE | |
24 | .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
25 | .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
26 | .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
27 | .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | |
28 | .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | |
29 | .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |
30 | .\" SUCH DAMAGE. | |
31 | .\" | |
32 | .\" $Id: listen.2,v 1.6 1999/05/18 14:10:32 freitag Exp $ | |
33 | .\" | |
34 | .\" Modified Fri Jul 23 22:07:54 1993 by Rik Faith <faith@cs.unc.edu> | |
35 | .\" Modified 950727 by aeb, following a suggestion by Urs Thuermann | |
36 | .\" <urs@isnogud.escape.de> | |
37 | .\" Modified Tue Oct 22 08:11:14 EDT 1996 by Eric S. Raymond <esr@thyrsus.com> | |
c13182ef | 38 | .\" Modified 1998 by Andi Kleen |
fea681da MK |
39 | .\" Modified 11 May 2001 by Sam Varshavchik <mrsam@courier-mta.com> |
40 | .\" | |
41 | .TH LISTEN 2 1993-07-23 "BSD Man Page" "Linux Programmer's Manual" | |
42 | .SH NAME | |
43 | listen \- listen for connections on a socket | |
44 | .SH SYNOPSIS | |
45 | .B #include <sys/socket.h> | |
46 | .sp | |
3e6b03a0 | 47 | .BI "int listen(int " sockfd ", int " backlog ); |
fea681da MK |
48 | .SH DESCRIPTION |
49 | To accept connections, a socket is first created with | |
50 | .BR socket (2), | |
51 | a willingness to accept incoming connections and a queue limit for incoming | |
52 | connections are specified with | |
884dda7b | 53 | .BR listen (), |
fea681da MK |
54 | and then the connections are |
55 | accepted with | |
56 | .BR accept (2). | |
57 | The | |
884dda7b | 58 | .BR listen () |
fea681da MK |
59 | call applies only to sockets of type |
60 | .B SOCK_STREAM | |
61 | or | |
62 | .BR SOCK_SEQPACKET . | |
63 | .PP | |
64 | The | |
65 | .I backlog | |
66 | parameter defines the maximum length the queue of pending connections may | |
c13182ef MK |
67 | grow to. |
68 | If a connection request arrives with the queue full the client | |
fea681da MK |
69 | may receive an error with an indication of |
70 | .B ECONNREFUSED | |
71 | or, if the underlying protocol supports retransmission, the request may be | |
72 | ignored so that retries succeed. | |
73 | .SH NOTES | |
c13182ef MK |
74 | The behaviour of the |
75 | .I backlog | |
fea681da | 76 | parameter on TCP sockets changed with Linux 2.2. |
c13182ef MK |
77 | Now it specifies the queue length for |
78 | .I completely | |
fea681da | 79 | established sockets waiting to be accepted, instead of the number of incomplete |
c13182ef MK |
80 | connection requests. |
81 | The maximum length of the queue for incomplete sockets | |
82 | can be set using the | |
fea681da MK |
83 | .B tcp_max_syn_backlog |
84 | sysctl. | |
c13182ef | 85 | When syncookies are enabled there is no logical maximum |
fea681da | 86 | length and this sysctl setting is ignored. |
c13182ef | 87 | See |
fea681da MK |
88 | .BR tcp (7) |
89 | for more information. | |
fea681da | 90 | .SH "RETURN VALUE" |
c13182ef MK |
91 | On success, zero is returned. |
92 | On error, \-1 is returned, and | |
fea681da MK |
93 | .I errno |
94 | is set appropriately. | |
95 | .SH ERRORS | |
96 | .TP | |
97 | .B EADDRINUSE | |
98 | Another socket is already listening on the same port. | |
99 | .TP | |
100 | .B EBADF | |
101 | The argument | |
3e6b03a0 | 102 | .I sockfd |
fea681da MK |
103 | is not a valid descriptor. |
104 | .TP | |
105 | .B ENOTSOCK | |
106 | The argument | |
3e6b03a0 | 107 | .I sockfd |
fea681da MK |
108 | is not a socket. |
109 | .TP | |
110 | .B EOPNOTSUPP | |
111 | The socket is not of a type that supports the | |
884dda7b | 112 | .BR listen () |
fea681da MK |
113 | operation. |
114 | .SH "CONFORMING TO" | |
97c1eac8 MK |
115 | 4.4BSD, POSIX.1-2001. |
116 | The | |
884dda7b | 117 | .BR listen () |
c13182ef | 118 | function call first appeared in 4.2BSD. |
fea681da | 119 | .SH BUGS |
c13182ef MK |
120 | If the socket is of type |
121 | .BR AF_INET , | |
fea681da MK |
122 | and the |
123 | .I backlog | |
124 | argument is greater | |
c13182ef MK |
125 | than the constant |
126 | .B SOMAXCONN | |
fea681da | 127 | (128 in Linux 2.0 & 2.2), it is silently truncated |
c13182ef MK |
128 | to |
129 | .BR SOMAXCONN . | |
884dda7b MK |
130 | .\" The following is now rather historic information (MTK, Jun 05) |
131 | .\" Don't rely on this value in portable applications since BSD | |
132 | .\" (and some BSD-derived systems) limit the backlog to 5. | |
fea681da MK |
133 | .SH "SEE ALSO" |
134 | .BR accept (2), | |
884dda7b | 135 | .BR bind (2), |
fea681da MK |
136 | .BR connect (2), |
137 | .BR socket (2) |