diff options
author | dougb <dougb@FreeBSD.org> | 2009-05-31 05:42:58 +0000 |
---|---|---|
committer | dougb <dougb@FreeBSD.org> | 2009-05-31 05:42:58 +0000 |
commit | 1e9abbf9ca25c8e19cbc0405a365df5433813cd6 (patch) | |
tree | 21a5399cf53ce4f1ffedece1c1700a317f190f2e /contrib/bind9/lib/bind/bsd/writev.c | |
parent | 9babfe9f9b2fa8b533dad4a39b00918df9809aa7 (diff) | |
parent | fd553238c94c3abfef11bfdfc5cb05b32cbe5f76 (diff) | |
download | FreeBSD-src-1e9abbf9ca25c8e19cbc0405a365df5433813cd6.zip FreeBSD-src-1e9abbf9ca25c8e19cbc0405a365df5433813cd6.tar.gz |
Update BIND to version 9.6.1rc1. This version has better performance and
lots of new features compared to 9.4.x, including:
Full NSEC3 support
Automatic zone re-signing
New update-policy methods tcp-self and 6to4-self
DHCID support.
More detailed statistics counters including those supported in BIND 8.
Faster ACL processing.
Efficient LRU cache-cleaning mechanism.
NSID support.
Diffstat (limited to 'contrib/bind9/lib/bind/bsd/writev.c')
-rw-r--r-- | contrib/bind9/lib/bind/bsd/writev.c | 89 |
1 files changed, 0 insertions, 89 deletions
diff --git a/contrib/bind9/lib/bind/bsd/writev.c b/contrib/bind9/lib/bind/bsd/writev.c deleted file mode 100644 index 0e81c26..0000000 --- a/contrib/bind9/lib/bind/bsd/writev.c +++ /dev/null @@ -1,89 +0,0 @@ -#ifndef LINT -static const char rcsid[] = "$Id: writev.c,v 1.2.164.1 2005/04/27 05:00:47 sra Exp $"; -#endif - -#include "port_before.h" - -#include <sys/types.h> -#include <sys/uio.h> -#include <sys/stat.h> -#include <sys/socket.h> - -#include "port_after.h" - -#ifndef NEED_WRITEV -int __bindcompat_writev; -#else - -#ifdef _CRAY -#define OWN_WRITEV -int -__writev(int fd, struct iovec *iov, int iovlen) -{ - struct stat statbuf; - - if (fstat(fd, &statbuf) < 0) - return (-1); - - /* - * Allow for atomic writes to network. - */ - if (statbuf.st_mode & S_IFSOCK) { - struct msghdr mesg; - - memset(&mesg, 0, sizeof(mesg)); - mesg.msg_name = 0; - mesg.msg_namelen = 0; - mesg.msg_iov = iov; - mesg.msg_iovlen = iovlen; - mesg.msg_accrights = 0; - mesg.msg_accrightslen = 0; - return (sendmsg(fd, &mesg, 0)); - } else { - struct iovec *tv; - int i, rcode = 0, count = 0; - - for (i = 0, tv = iov; i <= iovlen; tv++) { - rcode = write(fd, tv->iov_base, tv->iov_len); - - if (rcode < 0) - break; - - count += rcode; - } - - if (count == 0) - return (rcode); - else - return (count); - } -} - -#else /*_CRAY*/ - -int -__writev(fd, vp, vpcount) - int fd; - const struct iovec *vp; - int vpcount; -{ - int count = 0; - - while (vpcount-- > 0) { - int written = write(fd, vp->iov_base, vp->iov_len); - - if (written < 0) - return (-1); - count += written; - if (written != vp->iov_len) - break; - vp++; - } - return (count); -} - -#endif /*_CRAY*/ - -#endif /*NEED_WRITEV*/ - -/*! \file */ |