From: Rich Felker Date: Mon, 2 Apr 2012 03:22:16 +0000 (-0400) Subject: improve name lookup performance in corner cases X-Git-Tag: v0.8.8~57 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=4f346b08b33c9265c36fe8a14f5f908b1a9f296a;p=oweals%2Fmusl.git improve name lookup performance in corner cases the buffer in getaddrinfo really only matters when /etc/hosts is huge, but in that case, the huge number of syscalls resulting from a tiny buffer would seriously impact the performance of every name lookup. the buffer in __dns.c has also been enlarged a bit so that typical resolv.conf files will fit fully in the buffer. there's no need to make it so large as to dominate the syscall overhead for large files, because resolv.conf should never be large. --- diff --git a/src/network/__dns.c b/src/network/__dns.c index 786c054a..1464513d 100644 --- a/src/network/__dns.c +++ b/src/network/__dns.c @@ -29,7 +29,7 @@ int __dns_doqueries(unsigned char *dest, const char *name, int *rr, int rrcnt) time_t t0 = time(0); int fd; FILE *f, _f; - unsigned char _buf[64]; + unsigned char _buf[256]; char line[64], *s, *z; union { struct sockaddr_in sin; diff --git a/src/network/getaddrinfo.c b/src/network/getaddrinfo.c index e5fa5191..93c75160 100644 --- a/src/network/getaddrinfo.c +++ b/src/network/getaddrinfo.c @@ -61,7 +61,7 @@ int getaddrinfo(const char *host, const char *serv, const struct addrinfo *hint, //char hostbuf[256]; char line[512]; FILE *f, _f; - unsigned char _buf[64]; + unsigned char _buf[1024]; char *z; int result; int cnt;