summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexandre Ratchov <ratchov@cvs.openbsd.org>2011-05-02 22:24:24 +0000
committerAlexandre Ratchov <ratchov@cvs.openbsd.org>2011-05-02 22:24:24 +0000
commiteec210b2e4d847c224112c6cd053f26f9f3139da (patch)
treeedba8d7c0ae30cd561b59cdcf5986a908e0510bc
parent7b60f187e0287739322daa3a573c7e5880d51293 (diff)
set the TCP_NODELAY option for TCP connections
-rw-r--r--lib/libsndio/aucat.c11
-rw-r--r--usr.bin/aucat/listen.c14
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;