aboutsummaryrefslogtreecommitdiff
path: root/libdiskfs/node-nrele.c
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2016-10-31 19:18:41 +0100
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2016-10-31 19:18:41 +0100
commit9ddc4f2a1717455e50eb6fd010cda4e5f4080c42 (patch)
treee5ace664784f41c2c743a62db5d6e21d5b261e01 /libdiskfs/node-nrele.c
parent74bfb99acf027265b8b588ea3fa15204c426f919 (diff)
downloadhurd-9ddc4f2a1717455e50eb6fd010cda4e5f4080c42.tar.gz
hurd-9ddc4f2a1717455e50eb6fd010cda4e5f4080c42.tar.bz2
hurd-9ddc4f2a1717455e50eb6fd010cda4e5f4080c42.zip
libdiskfs: Factorize code for last hard reference being released
* libdiskfs/node-lastref.c: New file * libdiskfs/Makefile (OTHERSRCS): Add node-lastref.c * libdiskfs/libdiskfs/node-nput.c (diskfs_nput): Replace last hard reference code with a call to _diskfs_lastref. * libdiskfs/node-nrele.c (diskfs_nrele): Likewise.
Diffstat (limited to 'libdiskfs/node-nrele.c')
-rw-r--r--libdiskfs/node-nrele.c22
1 files changed, 1 insertions, 21 deletions
diff --git a/libdiskfs/node-nrele.c b/libdiskfs/node-nrele.c
index 73688356..6b7b7072 100644
--- a/libdiskfs/node-nrele.c
+++ b/libdiskfs/node-nrele.c
@@ -40,27 +40,7 @@ diskfs_nrele (struct node *np)
{
locked = TRUE;
pthread_mutex_lock (&np->lock);
- /* This is our cue that something akin to "last process closes file"
- in the POSIX.1 sense happened, so make sure any pending node time
- updates now happen in a timely fashion. */
- diskfs_set_node_times (np);
- diskfs_lost_hardrefs (np);
- if (!np->dn_stat.st_nlink)
- {
- if (np->sockaddr != MACH_PORT_NULL)
- {
- mach_port_deallocate (mach_task_self (), np->sockaddr);
- np->sockaddr = MACH_PORT_NULL;
- }
-
- /* There are no links. If there are soft references that
- can be dropped, we can't let them postpone deallocation.
- So attempt to drop them. But that's a user-supplied
- routine, which might result in further recursive calls to
- the ref-counting system. This is not a problem, as we
- hold a weak reference ourselves. */
- diskfs_try_dropping_softrefs (np);
- }
+ _diskfs_lastref (np);
}
/* Finally get rid of our reference. */