2009-02-13  Ulrich Drepper  <drepper@redhat.com>
	[BZ #5381]
	* nscd/nscd.h: Remove definitions and declarations for mem_in_flight.
	Change mempool_alloc prototype.
	* nscd/mem.c (gc): Don't handle mem_in_flight.
	(mempool_alloc): Third parameter now only indicates whether this is the
	first call (to allocate data) or not.  If it is, get db rdlock.
	Release it on error.  Don't handle mem_in_flight.
	* nscd/aicache.c (addhstaiX): Mark he parameter as const.
	Adjust third parameter of mempool_alloc calls.
	Nothing to do here in case mempool_alloc fails.
	Avoid local variable shadowing parameter.  No need to get db rdlock
	before calling cache_add.
	* nscd/cache.c (cache_add): Adjust call to mempool_alloc.  There is
	no mem_in_flight array anymore.
	* nscd/connections.c: Remove definition and handling of mem_in_flight.
	* nscd/grpcache.c (cache_addgr): Adjust third parameter of
	mempool_alloc calls.  Mark he parameter as const.  Nothing to do here
	in case mempool_alloc fails. No need to get db rdlock before calling
	cache_add.
	* nscd/hstcache.c (cache_addhst): Likewise.
	* nscd/initgrcache.c (addinitgroupsX): Likewise.
	* nscd/servicescache.c (cache_addserv): Likewise.
	* nscd/pwdcache.c (cache_addpw): Likewise.  Remove some debugging code.
This commit is contained in:
Ulrich Drepper 2009-02-13 20:36:37 +00:00
parent d8111eac54
commit 20e498bdb0
11 changed files with 83 additions and 236 deletions

View File

@ -1,3 +1,29 @@
2009-02-13 Ulrich Drepper <drepper@redhat.com>
[BZ #5381]
* nscd/nscd.h: Remove definitions and declarations for mem_in_flight.
Change mempool_alloc prototype.
* nscd/mem.c (gc): Don't handle mem_in_flight.
(mempool_alloc): Third parameter now only indicates whether this is the
first call (to allocate data) or not. If it is, get db rdlock.
Release it on error. Don't handle mem_in_flight.
* nscd/aicache.c (addhstaiX): Mark he parameter as const.
Adjust third parameter of mempool_alloc calls.
Nothing to do here in case mempool_alloc fails.
Avoid local variable shadowing parameter. No need to get db rdlock
before calling cache_add.
* nscd/cache.c (cache_add): Adjust call to mempool_alloc. There is
no mem_in_flight array anymore.
* nscd/connections.c: Remove definition and handling of mem_in_flight.
* nscd/grpcache.c (cache_addgr): Adjust third parameter of
mempool_alloc calls. Mark he parameter as const. Nothing to do here
in case mempool_alloc fails. No need to get db rdlock before calling
cache_add.
* nscd/hstcache.c (cache_addhst): Likewise.
* nscd/initgrcache.c (addinitgroupsX): Likewise.
* nscd/servicescache.c (cache_addserv): Likewise.
* nscd/pwdcache.c (cache_addpw): Likewise. Remove some debugging code.
2009-02-11 Ulrich Drepper <drepper@redhat.com> 2009-02-11 Ulrich Drepper <drepper@redhat.com>
* po/lt.po: Update from translation team. * po/lt.po: Update from translation team.

View File

@ -1,5 +1,5 @@
/* Cache handling for host lookup. /* Cache handling for host lookup.
Copyright (C) 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. Copyright (C) 2004-2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@redhat.com>, 2004. Contributed by Ulrich Drepper <drepper@redhat.com>, 2004.
@ -60,7 +60,8 @@ static const ai_response_header notfound =
static void static void
addhstaiX (struct database_dyn *db, int fd, request_header *req, addhstaiX (struct database_dyn *db, int fd, request_header *req,
void *key, uid_t uid, struct hashentry *he, struct datahead *dh) void *key, uid_t uid, struct hashentry *const he,
struct datahead *dh)
{ {
/* Search for the entry matching the key. Please note that we don't /* Search for the entry matching the key. Please note that we don't
look again in the table whether the dataset is now available. We look again in the table whether the dataset is now available. We
@ -172,13 +173,8 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
/* Now we can allocate the data structure. If the TTL of the /* Now we can allocate the data structure. If the TTL of the
entry is reported as zero do not cache the entry at all. */ entry is reported as zero do not cache the entry at all. */
if (ttl != 0 && he == NULL) if (ttl != 0 && he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total
dataset = (struct dataset *) mempool_alloc (db, total + req->key_len, 1);
+ req->key_len,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -300,9 +296,9 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
} }
else else
{ {
struct hostent *he = NULL; struct hostent *hstent = NULL;
int herrno; int herrno;
struct hostent he_mem; struct hostent hstent_mem;
void *addr; void *addr;
size_t addrlen; size_t addrlen;
int addrfamily; int addrfamily;
@ -326,8 +322,8 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
while (1) while (1)
{ {
rc = __gethostbyaddr2_r (addr, addrlen, addrfamily, rc = __gethostbyaddr2_r (addr, addrlen, addrfamily,
&he_mem, tmpbuf, tmpbuflen, &hstent_mem, tmpbuf, tmpbuflen,
&he, &herrno, NULL); &hstent, &herrno, NULL);
if (rc != ERANGE || herrno != NETDB_INTERNAL) if (rc != ERANGE || herrno != NETDB_INTERNAL)
break; break;
tmpbuf = extend_alloca (tmpbuf, tmpbuflen, tmpbuf = extend_alloca (tmpbuf, tmpbuflen,
@ -336,8 +332,8 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
if (rc == 0) if (rc == 0)
{ {
if (he != NULL) if (hstent != NULL)
canon = he->h_name; canon = hstent->h_name;
else else
canon = key; canon = key;
} }
@ -352,13 +348,8 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
/* Now we can allocate the data structure. If the TTL of the /* Now we can allocate the data structure. If the TTL of the
entry is reported as zero do not cache the entry at all. */ entry is reported as zero do not cache the entry at all. */
if (ttl != 0 && he == NULL) if (ttl != 0 && he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total
dataset = (struct dataset *) mempool_alloc (db, total + req->key_len, 1);
+ req->key_len,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -436,7 +427,7 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
appropriate memory and copy it. */ appropriate memory and copy it. */
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, total + req->key_len, = (struct dataset *) mempool_alloc (db, total + req->key_len,
IDX_result_data); 1);
if (__builtin_expect (newp != NULL, 1)) if (__builtin_expect (newp != NULL, 1))
{ {
/* Adjust pointer into the memory block. */ /* Adjust pointer into the memory block. */
@ -445,8 +436,6 @@ addhstaiX (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + req->key_len); dataset = memcpy (newp, dataset, total + req->key_len);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
dh->usable = false; dh->usable = false;
@ -515,8 +504,7 @@ next_nip:
if (fd != -1) if (fd != -1)
TEMP_FAILURE_RETRY (send (fd, &notfound, total, MSG_NOSIGNAL)); TEMP_FAILURE_RETRY (send (fd, &notfound, total, MSG_NOSIGNAL));
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, 1);
IDX_result_data);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -535,8 +523,6 @@ next_nip:
/* Copy the key data. */ /* Copy the key data. */
key_copy = memcpy (dataset->strdata, key, req->key_len); key_copy = memcpy (dataset->strdata, key, req->key_len);
} }
else
++db->head->addfailed;
} }
out: out:
@ -554,9 +540,6 @@ next_nip:
MS_ASYNC); MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, key_copy, req->key_len, &dataset->head, (void) cache_add (req->type, key_copy, req->key_len, &dataset->head,
true, db, uid, he == NULL); true, db, uid, he == NULL);

View File

@ -1,4 +1,4 @@
/* Copyright (c) 1998, 1999, 2003-2007, 2008 Free Software Foundation, Inc. /* Copyright (c) 1998, 1999, 2003-2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -155,21 +155,15 @@ cache_add (int type, const void *key, size_t len, struct datahead *packet,
unsigned long int hash = __nis_hash (key, len) % table->head->module; unsigned long int hash = __nis_hash (key, len) % table->head->module;
struct hashentry *newp; struct hashentry *newp;
newp = mempool_alloc (table, sizeof (struct hashentry), IDX_record_data); newp = mempool_alloc (table, sizeof (struct hashentry), 0);
/* If we cannot allocate memory, just do not do anything. */ /* If we cannot allocate memory, just do not do anything. */
if (newp == NULL) if (newp == NULL)
{ {
++table->head->addfailed;
/* If necessary mark the entry as unusable so that lookups will /* If necessary mark the entry as unusable so that lookups will
not use it. */ not use it. */
if (first) if (first)
packet->usable = false; packet->usable = false;
/* Mark the in-flight memory as unused. */
for (enum in_flight idx = 0; idx < IDX_record_data; ++idx)
mem_in_flight.block[idx].dbidx = -1;
return -1; return -1;
} }
@ -234,10 +228,6 @@ cache_add (int type, const void *key, size_t len, struct datahead *packet,
pthread_cond_signal (&table->prune_cond); pthread_cond_signal (&table->prune_cond);
} }
/* Mark the in-flight memory as unused. */
for (enum in_flight idx = 0; idx < IDX_last; ++idx)
mem_in_flight.block[idx].dbidx = -1;
return 0; return 0;
} }

View File

@ -250,11 +250,6 @@ static int have_accept4;
/* Number of times clients had to wait. */ /* Number of times clients had to wait. */
unsigned long int client_queued; unsigned long int client_queued;
/* Data structure for recording in-flight memory allocation. */
__thread struct mem_in_flight mem_in_flight attribute_tls_model_ie;
/* Global list of the mem_in_flight variables of all the threads. */
struct mem_in_flight *mem_in_flight_list;
ssize_t ssize_t
writeall (int fd, const void *buf, size_t len) writeall (int fd, const void *buf, size_t len)
@ -1584,16 +1579,6 @@ nscd_run_worker (void *p)
{ {
char buf[256]; char buf[256];
/* Initialize the memory-in-flight list. */
for (enum in_flight idx = 0; idx < IDX_last; ++idx)
mem_in_flight.block[idx].dbidx = -1;
/* And queue this threads structure. */
do
mem_in_flight.next = mem_in_flight_list;
while (atomic_compare_and_exchange_bool_acq (&mem_in_flight_list,
&mem_in_flight,
mem_in_flight.next) != 0);
/* Initial locking. */ /* Initial locking. */
pthread_mutex_lock (&readylist_lock); pthread_mutex_lock (&readylist_lock);

View File

@ -1,5 +1,5 @@
/* Cache handling for group lookup. /* Cache handling for group lookup.
Copyright (C) 1998-2005, 2006, 2007, 2008 Free Software Foundation, Inc. Copyright (C) 1998-2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -74,7 +74,7 @@ static const gr_response_header notfound =
static void static void
cache_addgr (struct database_dyn *db, int fd, request_header *req, cache_addgr (struct database_dyn *db, int fd, request_header *req,
const void *key, struct group *grp, uid_t owner, const void *key, struct group *grp, uid_t owner,
struct hashentry *he, struct datahead *dh, int errval) struct hashentry *const he, struct datahead *dh, int errval)
{ {
ssize_t total; ssize_t total;
ssize_t written; ssize_t written;
@ -114,7 +114,7 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
MSG_NOSIGNAL)); MSG_NOSIGNAL));
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len,
IDX_result_data); 1);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -143,9 +143,6 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
+ sizeof (struct dataset) + req->key_len, MS_ASYNC); + sizeof (struct dataset) + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, &dataset->strdata, req->key_len, (void) cache_add (req->type, &dataset->strdata, req->key_len,
&dataset->head, true, db, owner, he == NULL); &dataset->head, true, db, owner, he == NULL);
@ -155,8 +152,6 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
if (dh != NULL) if (dh != NULL)
dh->usable = false; dh->usable = false;
} }
else
++db->head->addfailed;
} }
} }
else else
@ -202,12 +197,7 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
dataset = NULL; dataset = NULL;
if (he == NULL) if (he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total + n, 1);
dataset = (struct dataset *) mempool_alloc (db, total + n,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -277,8 +267,7 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
/* We have to create a new record. Just allocate /* We have to create a new record. Just allocate
appropriate memory and copy it. */ appropriate memory and copy it. */
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, total + n, = (struct dataset *) mempool_alloc (db, total + n, 1);
IDX_result_data);
if (newp != NULL) if (newp != NULL)
{ {
/* Adjust pointers into the memory block. */ /* Adjust pointers into the memory block. */
@ -289,8 +278,6 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + n); dataset = memcpy (newp, dataset, total + n);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
dh->usable = false; dh->usable = false;
@ -343,9 +330,6 @@ cache_addgr (struct database_dyn *db, int fd, request_header *req,
MS_ASYNC); MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
/* NB: in the following code we always must add the entry /* NB: in the following code we always must add the entry
marked with FIRST first. Otherwise we end up with marked with FIRST first. Otherwise we end up with
dangling "pointers" in case a latter hash entry cannot be dangling "pointers" in case a latter hash entry cannot be

View File

@ -1,5 +1,5 @@
/* Cache handling for host lookup. /* Cache handling for host lookup.
Copyright (C) 1998-2005, 2006, 2007, 2008 Free Software Foundation, Inc. Copyright (C) 1998-2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -80,7 +80,7 @@ static const hst_response_header notfound =
static void static void
cache_addhst (struct database_dyn *db, int fd, request_header *req, cache_addhst (struct database_dyn *db, int fd, request_header *req,
const void *key, struct hostent *hst, uid_t owner, const void *key, struct hostent *hst, uid_t owner,
struct hashentry *he, struct datahead *dh, int errval, struct hashentry *const he, struct datahead *dh, int errval,
int32_t ttl) int32_t ttl)
{ {
bool all_written = true; bool all_written = true;
@ -120,7 +120,7 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
all_written = false; all_written = false;
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len,
IDX_result_data); 1);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -150,9 +150,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
+ sizeof (struct dataset) + req->key_len, MS_ASYNC); + sizeof (struct dataset) + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, &dataset->strdata, req->key_len, (void) cache_add (req->type, &dataset->strdata, req->key_len,
&dataset->head, true, db, owner, he == NULL); &dataset->head, true, db, owner, he == NULL);
@ -162,8 +159,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
if (dh != NULL) if (dh != NULL)
dh->usable = false; dh->usable = false;
} }
else
++db->head->addfailed;
} }
} }
else else
@ -221,13 +216,8 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
questionable whether it is worthwhile complicating the cache questionable whether it is worthwhile complicating the cache
handling just for handling such a special case. */ handling just for handling such a special case. */
if (he == NULL && h_addr_list_cnt == 1) if (he == NULL && h_addr_list_cnt == 1)
{ dataset = (struct dataset *) mempool_alloc (db, total + req->key_len,
dataset = (struct dataset *) mempool_alloc (db, 1);
total + req->key_len,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -316,7 +306,7 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, = (struct dataset *) mempool_alloc (db,
total + req->key_len, total + req->key_len,
IDX_result_data); 1);
if (newp != NULL) if (newp != NULL)
{ {
/* Adjust pointers into the memory block. */ /* Adjust pointers into the memory block. */
@ -329,8 +319,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + req->key_len); dataset = memcpy (newp, dataset, total + req->key_len);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
} }
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
@ -400,9 +388,6 @@ cache_addhst (struct database_dyn *db, int fd, request_header *req,
addr_list_type = (hst->h_length == NS_INADDRSZ addr_list_type = (hst->h_length == NS_INADDRSZ
? GETHOSTBYADDR : GETHOSTBYADDRv6); ? GETHOSTBYADDR : GETHOSTBYADDRv6);
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
/* NB: the following code is really complicated. It has /* NB: the following code is really complicated. It has
seemlingly duplicated code paths which do the same. The seemlingly duplicated code paths which do the same. The
problem is that we always must add the hash table entry problem is that we always must add the hash table entry

View File

@ -1,5 +1,5 @@
/* Cache handling for host lookup. /* Cache handling for host lookup.
Copyright (C) 2004, 2005, 2006, 2008 Free Software Foundation, Inc. Copyright (C) 2004, 2005, 2006, 2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@redhat.com>, 2004. Contributed by Ulrich Drepper <drepper@redhat.com>, 2004.
@ -54,7 +54,7 @@ static const initgr_response_header notfound =
static void static void
addinitgroupsX (struct database_dyn *db, int fd, request_header *req, addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
void *key, uid_t uid, struct hashentry *he, void *key, uid_t uid, struct hashentry *const he,
struct datahead *dh) struct datahead *dh)
{ {
/* Search for the entry matching the key. Please note that we don't /* Search for the entry matching the key. Please note that we don't
@ -198,7 +198,7 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
MSG_NOSIGNAL)); MSG_NOSIGNAL));
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len,
IDX_result_data); 1);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -227,9 +227,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
+ sizeof (struct dataset) + req->key_len, MS_ASYNC); + sizeof (struct dataset) + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, key_copy, req->key_len, (void) cache_add (req->type, key_copy, req->key_len,
&dataset->head, true, db, uid, he == NULL); &dataset->head, true, db, uid, he == NULL);
@ -239,8 +236,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
if (dh != NULL) if (dh != NULL)
dh->usable = false; dh->usable = false;
} }
else
++db->head->addfailed;
} }
} }
else else
@ -257,13 +252,8 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
dataset = NULL; dataset = NULL;
if (he == NULL) if (he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total + req->key_len,
dataset = (struct dataset *) mempool_alloc (db, 1);
total + req->key_len,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -334,7 +324,7 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
appropriate memory and copy it. */ appropriate memory and copy it. */
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, total + req->key_len, = (struct dataset *) mempool_alloc (db, total + req->key_len,
IDX_result_data); 1);
if (newp != NULL) if (newp != NULL)
{ {
/* Adjust pointer into the memory block. */ /* Adjust pointer into the memory block. */
@ -343,8 +333,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + req->key_len); dataset = memcpy (newp, dataset, total + req->key_len);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
dh->usable = false; dh->usable = false;
@ -398,9 +386,6 @@ addinitgroupsX (struct database_dyn *db, int fd, request_header *req,
req->key_len, MS_ASYNC); req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (INITGROUPS, cp, req->key_len, &dataset->head, true, (void) cache_add (INITGROUPS, cp, req->key_len, &dataset->head, true,
db, uid, he == NULL); db, uid, he == NULL);

View File

@ -197,32 +197,6 @@ gc (struct database_dyn *db)
} }
assert (cnt == db->head->nentries); assert (cnt == db->head->nentries);
/* Go through the list of in-flight memory blocks. */
struct mem_in_flight *mrunp = mem_in_flight_list;
while (mrunp != NULL)
{
/* NB: There can be no race between this test and another thread
setting the field to the index we are looking for because
this would require the other thread to also have the memlock
for the database.
NB2: we do not have to look at latter blocks (higher indices) if
earlier blocks are not in flight. They are always allocated in
sequence. */
for (enum in_flight idx = IDX_result_data;
idx < IDX_last && mrunp->block[idx].dbidx == db - dbs; ++idx)
{
assert (mrunp->block[idx].blockoff >= 0);
assert (mrunp->block[idx].blocklen < db->memsize);
assert (mrunp->block[idx].blockoff
+ mrunp->block[0].blocklen <= db->memsize);
markrange (mark, mrunp->block[idx].blockoff,
mrunp->block[idx].blocklen);
}
mrunp = mrunp->next;
}
/* Sort the entries by the addresses of the referenced data. All /* Sort the entries by the addresses of the referenced data. All
the entries pointing to the same DATAHEAD object will have the the entries pointing to the same DATAHEAD object will have the
same key. Stability of the sorting is unimportant. */ same key. Stability of the sorting is unimportant. */
@ -540,13 +514,16 @@ gc (struct database_dyn *db)
void * void *
mempool_alloc (struct database_dyn *db, size_t len, enum in_flight idx) mempool_alloc (struct database_dyn *db, size_t len, int data_alloc)
{ {
/* Make sure LEN is a multiple of our maximum alignment so we can /* Make sure LEN is a multiple of our maximum alignment so we can
keep track of used memory is multiples of this alignment value. */ keep track of used memory is multiples of this alignment value. */
if ((len & BLOCK_ALIGN_M1) != 0) if ((len & BLOCK_ALIGN_M1) != 0)
len += BLOCK_ALIGN - (len & BLOCK_ALIGN_M1); len += BLOCK_ALIGN - (len & BLOCK_ALIGN_M1);
if (data_alloc)
pthread_rwlock_rdlock (&db->lock);
pthread_mutex_lock (&db->memlock); pthread_mutex_lock (&db->memlock);
assert ((db->head->first_free & BLOCK_ALIGN_M1) == 0); assert ((db->head->first_free & BLOCK_ALIGN_M1) == 0);
@ -589,6 +566,9 @@ mempool_alloc (struct database_dyn *db, size_t len, enum in_flight idx)
} }
} }
if (data_alloc)
pthread_rwlock_unlock (&db->lock);
if (! db->last_alloc_failed) if (! db->last_alloc_failed)
{ {
dbg_log (_("no more memory for database '%s'"), dbnames[db - dbs]); dbg_log (_("no more memory for database '%s'"), dbnames[db - dbs]);
@ -596,17 +576,13 @@ mempool_alloc (struct database_dyn *db, size_t len, enum in_flight idx)
db->last_alloc_failed = true; db->last_alloc_failed = true;
} }
++db->head->addfailed;
/* No luck. */ /* No luck. */
res = NULL; res = NULL;
} }
else else
{ {
/* Remember that we have allocated this memory. */
assert (idx >= 0 && idx < IDX_last);
mem_in_flight.block[idx].dbidx = db - dbs;
mem_in_flight.block[idx].blocklen = len;
mem_in_flight.block[idx].blockoff = db->head->first_free;
db->head->first_free += len; db->head->first_free += len;
db->last_alloc_failed = false; db->last_alloc_failed = false;

View File

@ -1,5 +1,4 @@
/* Copyright (c) 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007, 2008 /* Copyright (c) 1998-2001, 2003-2008, 2009 Free Software Foundation, Inc.
Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Thorsten Kukuk <kukuk@suse.de>, 1998. Contributed by Thorsten Kukuk <kukuk@suse.de>, 1998.
@ -184,31 +183,6 @@ extern uid_t old_uid;
extern gid_t old_gid; extern gid_t old_gid;
/* Memory allocation in flight. Each thread can have a limited number
of allocation in flight. No need to create dynamic data
structures. We use fixed indices. */
enum in_flight
{
IDX_result_data = 0,
/* Keep the IDX_record_data entry last at all times. */
IDX_record_data = 1,
IDX_last
};
extern __thread struct mem_in_flight
{
struct
{
int dbidx;
nscd_ssize_t blocklen;
nscd_ssize_t blockoff;
} block[IDX_last];
struct mem_in_flight *next;
} mem_in_flight attribute_tls_model_ie;
/* Global list of the mem_in_flight variables of all the threads. */
extern struct mem_in_flight *mem_in_flight_list;
/* Prototypes for global functions. */ /* Prototypes for global functions. */
/* nscd.c */ /* nscd.c */
@ -301,7 +275,7 @@ extern void readdservbyport (struct database_dyn *db, struct hashentry *he,
/* mem.c */ /* mem.c */
extern void *mempool_alloc (struct database_dyn *db, size_t len, extern void *mempool_alloc (struct database_dyn *db, size_t len,
enum in_flight idx); int data_alloc);
extern void gc (struct database_dyn *db); extern void gc (struct database_dyn *db);

View File

@ -1,5 +1,5 @@
/* Cache handling for passwd lookup. /* Cache handling for passwd lookup.
Copyright (C) 1998-2005, 2006, 2007, 2008 Free Software Foundation, Inc. Copyright (C) 1998-2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -80,7 +80,7 @@ static const pw_response_header notfound =
static void static void
cache_addpw (struct database_dyn *db, int fd, request_header *req, cache_addpw (struct database_dyn *db, int fd, request_header *req,
const void *key, struct passwd *pwd, uid_t owner, const void *key, struct passwd *pwd, uid_t owner,
struct hashentry *he, struct datahead *dh, int errval) struct hashentry *const he, struct datahead *dh, int errval)
{ {
ssize_t total; ssize_t total;
ssize_t written; ssize_t written;
@ -121,7 +121,7 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
MSG_NOSIGNAL)); MSG_NOSIGNAL));
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len,
IDX_result_data); 1);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -150,9 +150,6 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
+ sizeof (struct dataset) + req->key_len, MS_ASYNC); + sizeof (struct dataset) + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, key_copy, req->key_len, (void) cache_add (req->type, key_copy, req->key_len,
&dataset->head, true, db, owner, he == NULL); &dataset->head, true, db, owner, he == NULL);
@ -162,8 +159,6 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
if (dh != NULL) if (dh != NULL)
dh->usable = false; dh->usable = false;
} }
else
++db->head->addfailed;
} }
} }
else else
@ -197,12 +192,7 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
dataset = NULL; dataset = NULL;
if (he == NULL) if (he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total + n, 1);
dataset = (struct dataset *) mempool_alloc (db, total + n,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -257,19 +247,10 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
{ {
assert (fd == -1); assert (fd == -1);
#if 0 if (dataset->head.allocsize == dh->allocsize
if (dataset->head.datasize == dh->allocsize
&& dataset->head.recsize == dh->recsize && dataset->head.recsize == dh->recsize
&& memcmp (&dataset->resp, dh->data, && memcmp (&dataset->resp, dh->data,
dh->allocsize - offsetof (struct dataset, resp)) == 0) dh->allocsize - offsetof (struct dataset, resp)) == 0)
#else
if (dataset->head.allocsize != dh->allocsize)
goto nnn;
if (dataset->head.recsize != dh->recsize)
goto nnn;
if(memcmp (&dataset->resp, dh->data,
dh->allocsize - offsetof (struct dataset, resp)) == 0)
#endif
{ {
/* The data has not changed. We will just bump the /* The data has not changed. We will just bump the
timeout value. Note that the new record has been timeout value. Note that the new record has been
@ -279,12 +260,10 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
} }
else else
{ {
nnn:;
/* We have to create a new record. Just allocate /* We have to create a new record. Just allocate
appropriate memory and copy it. */ appropriate memory and copy it. */
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, total + n, = (struct dataset *) mempool_alloc (db, total + n, 1);
IDX_result_data);
if (newp != NULL) if (newp != NULL)
{ {
/* Adjust pointer into the memory block. */ /* Adjust pointer into the memory block. */
@ -294,8 +273,6 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + n); dataset = memcpy (newp, dataset, total + n);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
dh->usable = false; dh->usable = false;
@ -349,9 +326,6 @@ cache_addpw (struct database_dyn *db, int fd, request_header *req,
MS_ASYNC); MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
/* NB: in the following code we always must add the entry /* NB: in the following code we always must add the entry
marked with FIRST first. Otherwise we end up with marked with FIRST first. Otherwise we end up with
dangling "pointers" in case a latter hash entry cannot be dangling "pointers" in case a latter hash entry cannot be

View File

@ -1,5 +1,5 @@
/* Cache handling for services lookup. /* Cache handling for services lookup.
Copyright (C) 2007, 2008 Free Software Foundation, Inc. Copyright (C) 2007, 2008, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@drepper.com>, 2007. Contributed by Ulrich Drepper <drepper@drepper.com>, 2007.
@ -64,7 +64,7 @@ static const serv_response_header notfound =
static void static void
cache_addserv (struct database_dyn *db, int fd, request_header *req, cache_addserv (struct database_dyn *db, int fd, request_header *req,
const void *key, struct servent *serv, uid_t owner, const void *key, struct servent *serv, uid_t owner,
struct hashentry *he, struct datahead *dh, int errval) struct hashentry *const he, struct datahead *dh, int errval)
{ {
ssize_t total; ssize_t total;
ssize_t written; ssize_t written;
@ -104,7 +104,7 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
MSG_NOSIGNAL)); MSG_NOSIGNAL));
dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len, dataset = mempool_alloc (db, sizeof (struct dataset) + req->key_len,
IDX_result_data); 1);
/* If we cannot permanently store the result, so be it. */ /* If we cannot permanently store the result, so be it. */
if (dataset != NULL) if (dataset != NULL)
{ {
@ -133,9 +133,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
+ sizeof (struct dataset) + req->key_len, MS_ASYNC); + sizeof (struct dataset) + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, &dataset->strdata, req->key_len, (void) cache_add (req->type, &dataset->strdata, req->key_len,
&dataset->head, true, db, owner, he == NULL); &dataset->head, true, db, owner, he == NULL);
@ -145,8 +142,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
if (dh != NULL) if (dh != NULL)
dh->usable = false; dh->usable = false;
} }
else
++db->head->addfailed;
} }
} }
else else
@ -187,13 +182,8 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
dataset = NULL; dataset = NULL;
if (he == NULL) if (he == NULL)
{ dataset = (struct dataset *) mempool_alloc (db, total + req->key_len,
dataset = (struct dataset *) mempool_alloc (db, 1);
total + req->key_len,
IDX_result_data);
if (dataset == NULL)
++db->head->addfailed;
}
if (dataset == NULL) if (dataset == NULL)
{ {
@ -262,7 +252,7 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
appropriate memory and copy it. */ appropriate memory and copy it. */
struct dataset *newp struct dataset *newp
= (struct dataset *) mempool_alloc (db, total + req->key_len, = (struct dataset *) mempool_alloc (db, total + req->key_len,
IDX_result_data); 1);
if (newp != NULL) if (newp != NULL)
{ {
/* Adjust pointers into the memory block. */ /* Adjust pointers into the memory block. */
@ -273,8 +263,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
dataset = memcpy (newp, dataset, total + req->key_len); dataset = memcpy (newp, dataset, total + req->key_len);
alloca_used = false; alloca_used = false;
} }
else
++db->head->addfailed;
/* Mark the old record as obsolete. */ /* Mark the old record as obsolete. */
dh->usable = false; dh->usable = false;
@ -327,9 +315,6 @@ cache_addserv (struct database_dyn *db, int fd, request_header *req,
+ total + req->key_len, MS_ASYNC); + total + req->key_len, MS_ASYNC);
} }
/* Now get the lock to safely insert the records. */
pthread_rwlock_rdlock (&db->lock);
(void) cache_add (req->type, key_copy, req->key_len, (void) cache_add (req->type, key_copy, req->key_len,
&dataset->head, true, db, owner, he == NULL); &dataset->head, true, db, owner, he == NULL);