diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2016-10-31 19:18:41 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2016-10-31 19:18:41 +0100 |
commit | 9ddc4f2a1717455e50eb6fd010cda4e5f4080c42 (patch) | |
tree | e5ace664784f41c2c743a62db5d6e21d5b261e01 /libdiskfs/node-nrele.c | |
parent | 74bfb99acf027265b8b588ea3fa15204c426f919 (diff) | |
download | hurd-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.c | 22 |
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. */ |