mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-08 18:30:18 +00:00
(_hurd_canonicalize_directory_name_internal): Don't deallocate DOTID & DOTDEVID until we're finished with them (we need to keep them at least until we've fetched the next level of id ports, so that mach will be able to use the same name if they're the same). Add inner_errlose: label, which deallocates DOTID & DOTDEVID and jumps to errlose, for those places where such cleanup is needed.
This commit is contained in:
parent
bba7bb78f3
commit
aeb0816f97
@ -131,8 +131,6 @@ _hurd_canonicalize_directory_name_internal (file_t thisdir,
|
|||||||
/* Get this directory's identity and figure out if it's a mount point. */
|
/* Get this directory's identity and figure out if it's a mount point. */
|
||||||
if (err = __io_identity (parent, &dotid, &dotdevid, &dotino))
|
if (err = __io_identity (parent, &dotid, &dotdevid, &dotino))
|
||||||
goto errlose;
|
goto errlose;
|
||||||
__mach_port_deallocate (__mach_task_self (), dotid);
|
|
||||||
__mach_port_deallocate (__mach_task_self (), dotdevid);
|
|
||||||
mount_point = dotdevid != thisdevid;
|
mount_point = dotdevid != thisdevid;
|
||||||
|
|
||||||
/* Search for the last directory. */
|
/* Search for the last directory. */
|
||||||
@ -186,7 +184,7 @@ _hurd_canonicalize_directory_name_internal (file_t thisdir,
|
|||||||
err = __io_identity (try, &id, &devid, &fileno);
|
err = __io_identity (try, &id, &devid, &fileno);
|
||||||
__mach_port_deallocate (__mach_task_self (), try);
|
__mach_port_deallocate (__mach_task_self (), try);
|
||||||
if (err)
|
if (err)
|
||||||
goto errlose;
|
goto inner_errlose;
|
||||||
__mach_port_deallocate (__mach_task_self (), id);
|
__mach_port_deallocate (__mach_task_self (), id);
|
||||||
__mach_port_deallocate (__mach_task_self (), devid);
|
__mach_port_deallocate (__mach_task_self (), devid);
|
||||||
if (id == thisid)
|
if (id == thisid)
|
||||||
@ -196,14 +194,19 @@ _hurd_canonicalize_directory_name_internal (file_t thisdir,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
|
{
|
||||||
|
inner_errlose: /* Goto ERRLOSE: after cleaning up. */
|
||||||
|
__mach_port_deallocate (__mach_task_self (), dotid);
|
||||||
|
__mach_port_deallocate (__mach_task_self (), dotdevid);
|
||||||
goto errlose;
|
goto errlose;
|
||||||
|
}
|
||||||
else if (nentries == 0)
|
else if (nentries == 0)
|
||||||
{
|
{
|
||||||
/* We got to the end of the directory without finding anything!
|
/* We got to the end of the directory without finding anything!
|
||||||
We are in a directory that has been unlinked, or something is
|
We are in a directory that has been unlinked, or something is
|
||||||
broken. */
|
broken. */
|
||||||
err = ENOENT;
|
err = ENOENT;
|
||||||
goto errlose;
|
goto inner_errlose;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
found:
|
found:
|
||||||
|
Loading…
Reference in New Issue
Block a user