From a500fbcd53e4735fbfa0a3f3e909750884e825a3 Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Sun, 20 May 2001 02:27:44 +0000 Subject: 2001-05-19 Roland McGrath * hurd/hurdlookup.c (__hurd_file_name_lookup_retry): Don't leak the result port when failing with ELOOP. Do the ELOOP check when following an absolute symlink target as well as relative. Remove #ifdef SYMLOOP_MAX conditional--it should always be defined. --- hurd/hurdlookup.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'hurd/hurdlookup.c') diff --git a/hurd/hurdlookup.c b/hurd/hurdlookup.c index 7e5f9afa99..5a54cfb9d8 100644 --- a/hurd/hurdlookup.c +++ b/hurd/hurdlookup.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1992, 93, 94, 95, 96, 97, 99 Free Software Foundation, Inc. +/* Copyright (C) 1992,93,94,95,96,97,99,2001 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -164,10 +164,11 @@ __hurd_file_name_lookup_retry (error_t (*use_init_port) /* Fall through. */ case FS_RETRY_NORMAL: -#ifdef SYMLOOP_MAX if (nloops++ >= SYMLOOP_MAX) - return ELOOP; -#endif + { + __mach_port_deallocate (__mach_task_self (), *result); + return ELOOP; + } /* An empty RETRYNAME indicates we have the final port. */ if (retryname[0] == '\0' && @@ -240,6 +241,8 @@ __hurd_file_name_lookup_retry (error_t (*use_init_port) dirport = INIT_PORT_CRDIR; if (*result != MACH_PORT_NULL) __mach_port_deallocate (__mach_task_self (), *result); + if (nloops++ >= SYMLOOP_MAX) + return ELOOP; file_name = &retryname[1]; break; -- cgit v1.2.3