aboutsummaryrefslogtreecommitdiff
path: root/nscd/servicescache.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@gmail.com>2012-01-20 22:39:54 -0500
committerUlrich Drepper <drepper@gmail.com>2012-01-20 22:39:54 -0500
commit3e1aa84e7f9f38815f5db9cd7654b1a9497cf6e4 (patch)
tree3cf76f1f45fae89588ea78e62a41ea6f71895ca0 /nscd/servicescache.c
parent6e4b210745556ea4d74d4dc6637994756bf2d6b5 (diff)
downloadglibc-3e1aa84e7f9f38815f5db9cd7654b1a9497cf6e4.zip
glibc-3e1aa84e7f9f38815f5db9cd7654b1a9497cf6e4.tar.gz
glibc-3e1aa84e7f9f38815f5db9cd7654b1a9497cf6e4.tar.bz2
Do not cache negative results in nscd if these are transient
Diffstat (limited to 'nscd/servicescache.c')
-rw-r--r--nscd/servicescache.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/nscd/servicescache.c b/nscd/servicescache.c
index d3d5dce..a6337e3 100644
--- a/nscd/servicescache.c
+++ b/nscd/servicescache.c
@@ -1,5 +1,5 @@
/* Cache handling for services lookup.
- Copyright (C) 2007, 2008, 2009, 2011 Free Software Foundation, Inc.
+ Copyright (C) 2007, 2008, 2009, 2011, 2012 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@drepper.com>, 2007.
@@ -108,8 +108,9 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
written = TEMP_FAILURE_RETRY (send (fd, &notfound, total,
MSG_NOSIGNAL));
- /* If we cannot permanently store the result, so be it. */
- if (__builtin_expect (db->negtimeout == 0, 0))
+ /* If we have a transient error or cannot permanently store
+ the result, so be it. */
+ if (errval == EAGAIN || __builtin_expect (db->negtimeout == 0, 0))
{
/* Mark the old entry as obsolete. */
if (dh != NULL)