OSDN Git Service

* fhandler_procsys.cc (fhandler_procsys::opendir): Avoid SEGV if
authorcorinna <corinna>
Tue, 15 Feb 2011 14:44:11 +0000 (14:44 +0000)
committercorinna <corinna>
Tue, 15 Feb 2011 14:44:11 +0000 (14:44 +0000)
opening object directory fails.
* fhandler_virtual.cc (fhandler_virtual::opendir): Don't leak memory.

winsup/cygwin/ChangeLog
winsup/cygwin/fhandler_procsys.cc
winsup/cygwin/fhandler_virtual.cc

index 4efbd22..3d0880d 100644 (file)
@@ -1,5 +1,11 @@
 2011-02-15  Corinna Vinschen  <corinna@vinschen.de>
 
+       * fhandler_procsys.cc (fhandler_procsys::opendir): Avoid SEGV if
+       opening object directory fails.
+       * fhandler_virtual.cc (fhandler_virtual::opendir): Don't leak memory.
+
+2011-02-15  Corinna Vinschen  <corinna@vinschen.de>
+
        * fhandler_disk_file.cc (fhandler_disk_file::readdir_helper): Don't
        append slash if there is one already.
 
index 0f4cc17..6c91a2f 100644 (file)
@@ -1,6 +1,6 @@
 /* fhandler_procsys.cc: fhandler for native NT namespace.
 
-   Copyright 2010 Red Hat, Inc.
+   Copyright 2010, 2011 Red Hat, Inc.
 
 This file is part of Cygwin.
 
@@ -245,18 +245,20 @@ fhandler_procsys::opendir (int fd)
   OBJECT_ATTRIBUTES attr;
   NTSTATUS status;
   HANDLE h;
-  DIR *dir = fhandler_virtual::opendir (fd);
+  DIR *dir;
 
   mk_unicode_path (&path);
   InitializeObjectAttributes (&attr, &path, OBJ_CASE_INSENSITIVE, NULL, NULL);
   status = NtOpenDirectoryObject (&h, DIRECTORY_QUERY, &attr);
   if (!NT_SUCCESS (status))
     {
-      free (dir);
       __seterrno_from_nt_status (status);
       return NULL;
     }
-  dir->__handle = h;
+  if (!(dir = fhandler_virtual::opendir (fd)))
+    NtClose (h);
+  else
+    dir->__handle = h;
   return dir;
 }
 
index 6d515a3..1c4e710 100644 (file)
@@ -1,6 +1,6 @@
 /* fhandler_virtual.cc: base fhandler class for virtual filesystems
 
-   Copyright 2002, 2003, 2004, 2005, 2007, 2008, 2009 Red Hat, Inc.
+   Copyright 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011 Red Hat, Inc.
 
 This file is part of Cygwin.
 
@@ -59,6 +59,7 @@ fhandler_virtual::opendir (int fd)
   else if ((dir->__d_dirent =
       (struct dirent *) malloc (sizeof (struct dirent))) == NULL)
     {
+      free (dir->__d_dirname);
       free (dir);
       set_errno (ENOMEM);
     }