summaryrefslogtreecommitdiff
path: root/trans
diff options
context:
space:
mode:
authorJustus Winter <4winter@informatik.uni-hamburg.de>2013-12-05 23:38:53 +0100
committerJustus Winter <4winter@informatik.uni-hamburg.de>2013-12-09 15:08:00 +0100
commit7d20408ec4a5dbc973520dd78dd2531c6a1471c7 (patch)
treeeaad6dc7786df9977b5f343d1fca9532a027f156 /trans
parent61c77d679840e4c4455615295ac30215bb01cdf5 (diff)
trans: fix reference counting bug in fakeroot
The function new_node creates virtual nodes using netfs_make_node. Nodes created with netfs_make_node already have a reference count of one. Currently another reference is added in new_node. This prevents the destruction of the node causing bugs like this: % fakeroot-hurd sh -c 'l(){ flock /tmp/$$.lock true; }; l; l' <hangs> * trans/fakeroot.c (new_node): Fix reference count of newly created nodes.
Diffstat (limited to 'trans')
-rw-r--r--trans/fakeroot.c5
1 files changed, 1 insertions, 4 deletions
diff --git a/trans/fakeroot.c b/trans/fakeroot.c
index d5cb0e6d..5c4854d1 100644
--- a/trans/fakeroot.c
+++ b/trans/fakeroot.c
@@ -108,10 +108,7 @@ new_node (file_t file, mach_port_t idport, int locked, int openmodes,
pthread_mutex_lock (&idport_ihash_lock);
err = hurd_ihash_add (&idport_ihash, nn->idport, nn);
if (!err)
- {
- pthread_mutex_lock (&(*np)->lock);
- netfs_nref (*np); /* Return a reference to the caller. */
- }
+ pthread_mutex_lock (&(*np)->lock);
pthread_mutex_unlock (&idport_ihash_lock);
}
if (err)