diff options
author | Andreas Jaeger <aj@suse.de> | 2012-05-15 20:35:53 +0200 |
---|---|---|
committer | Andreas Jaeger <aj@suse.de> | 2012-05-15 20:37:05 +0200 |
commit | 509072a0f7f8a37bedf61a78c0cdd7783368c65a (patch) | |
tree | 32ac15ad1aba98673f42bc475d053fb1b4b3b864 /nscd/nscd-client.h | |
parent | ba75122dd93b6188d1be446df0502c4cbe5c32e6 (diff) | |
download | glibc-509072a0f7f8a37bedf61a78c0cdd7783368c65a.zip glibc-509072a0f7f8a37bedf61a78c0cdd7783368c65a.tar.gz glibc-509072a0f7f8a37bedf61a78c0cdd7783368c65a.tar.bz2 |
Avoid race in nscd
2012-05-15 Jeff Law <law@redhat.com>
Andreas Jaeger <aj@suse.de>
[BZ #13594]
* nscd/nscd-client.h (__nscd_acquire_maplock): New function, split
out from...
* nscd/nscd_helper.c (__nscd_get_map_ref): ... here.
* nscd/nscd-client.h: Add __nscd_acquire_maplock.
* nscd/nscd_gethst_r.c (__nscd_get_nl_timestamp): Add locking to
code changing __hst_map_handle.map.
Diffstat (limited to 'nscd/nscd-client.h')
-rw-r--r-- | nscd/nscd-client.h | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/nscd/nscd-client.h b/nscd/nscd-client.h index e57a23c..325368e 100644 --- a/nscd/nscd-client.h +++ b/nscd/nscd-client.h @@ -1,5 +1,4 @@ -/* Copyright (c) 1998, 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009, 2011 - Free Software Foundation, Inc. +/* Copyright (c) 1998-2012 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Thorsten Kukuk <kukuk@suse.de>, 1998. @@ -322,6 +321,24 @@ struct locked_map_ptr }; #define libc_locked_map_ptr(class, name) class struct locked_map_ptr name +/* Try acquiring lock for mapptr, returns true if it succeeds, false + if not. */ +static inline bool __nscd_acquire_maplock (volatile struct locked_map_ptr *mapptr) +{ + int cnt = 0; + while (__builtin_expect (atomic_compare_and_exchange_val_acq (&mapptr->lock, + 1, 0) != 0, 0)) + { + // XXX Best number of rounds? + if (__builtin_expect (++cnt > 5, 0)) + return false; + + atomic_delay (); + } + + return true; +} + /* Open socket connection to nscd server. */ extern int __nscd_open_socket (const char *key, size_t keylen, |