diff options
author | Alexandre Ratchov <ratchov@cvs.openbsd.org> | 2011-05-02 22:24:24 +0000 |
---|---|---|
committer | Alexandre Ratchov <ratchov@cvs.openbsd.org> | 2011-05-02 22:24:24 +0000 |
commit | eec210b2e4d847c224112c6cd053f26f9f3139da (patch) | |
tree | edba8d7c0ae30cd561b59cdcf5986a908e0510bc | |
parent | 7b60f187e0287739322daa3a573c7e5880d51293 (diff) |
set the TCP_NODELAY option for TCP connections
-rw-r--r-- | lib/libsndio/aucat.c | 11 | ||||
-rw-r--r-- | usr.bin/aucat/listen.c | 14 |
2 files changed, 21 insertions, 4 deletions
diff --git a/lib/libsndio/aucat.c b/lib/libsndio/aucat.c index 76e71153e24..ba8016b43a1 100644 --- a/lib/libsndio/aucat.c +++ b/lib/libsndio/aucat.c @@ -1,4 +1,4 @@ -/* $OpenBSD: aucat.c,v 1.46 2011/04/28 06:19:57 ratchov Exp $ */ +/* $OpenBSD: aucat.c,v 1.47 2011/05/02 22:24:23 ratchov Exp $ */ /* * Copyright (c) 2008 Alexandre Ratchov <alex@caoua.org> * @@ -21,6 +21,7 @@ #include <sys/un.h> #include <netinet/in.h> +#include <netinet/tcp.h> #include <netdb.h> #include <errno.h> @@ -281,7 +282,7 @@ bad_gen: int aucat_connect_tcp(struct aucat *hdl, char *host, char *unit, int isaudio) { - int s, error; + int s, error, opt; struct addrinfo *ailist, *ai, aihints; unsigned port; char serv[NI_MAXSERV]; @@ -321,6 +322,12 @@ aucat_connect_tcp(struct aucat *hdl, char *host, char *unit, int isaudio) freeaddrinfo(ailist); if (s < 0) return 0; + opt = 1; + if (setsockopt(s, IPPROTO_TCP, TCP_NODELAY, &opt, sizeof(int)) < 0) { + DPERROR("setsockopt"); + close(s); + return 0; + } hdl->fd = s; return 1; } diff --git a/usr.bin/aucat/listen.c b/usr.bin/aucat/listen.c index d99d3d9f543..df6e1eb412f 100644 --- a/usr.bin/aucat/listen.c +++ b/usr.bin/aucat/listen.c @@ -1,4 +1,4 @@ -/* $OpenBSD: listen.c,v 1.14 2011/04/28 06:19:57 ratchov Exp $ */ +/* $OpenBSD: listen.c,v 1.15 2011/05/02 22:24:23 ratchov Exp $ */ /* * Copyright (c) 2008 Alexandre Ratchov <alex@caoua.org> * @@ -21,6 +21,7 @@ #include <sys/un.h> #include <netinet/in.h> +#include <netinet/tcp.h> #include <netdb.h> #include <err.h> @@ -175,7 +176,7 @@ listen_revents(struct file *file, struct pollfd *pfd) struct listen *f = (struct listen *)file; struct sockaddr caddr; socklen_t caddrlen; - int sock; + int sock, opt; if (pfd->revents & POLLIN) { caddrlen = sizeof(caddrlen); @@ -190,6 +191,15 @@ listen_revents(struct file *file, struct pollfd *pfd) close(sock); return 0; } + if (f->path == NULL) { + opt = 1; + if (setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, + &opt, sizeof(int)) < 0) { + perror("setsockopt"); + close(sock); + return 0; + } + } if (sock_new(&sock_ops, sock) == NULL) { close(sock); return 0; |