about summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2005-09-26 16:56:27 +0000
committerUlrich Drepper <drepper@redhat.com>2005-09-26 16:56:27 +0000
commit407a551539baefb7ac3b3e2bf2e40aa5c922204d (patch)
tree817bd6b5ceea6849703a3f3b23d497fdc6a0470f
parent207cce4c4781fbd9928927d3bb6805bcc843a158 (diff)
downloadglibc-407a551539baefb7ac3b3e2bf2e40aa5c922204d.tar.gz
glibc-407a551539baefb7ac3b3e2bf2e40aa5c922204d.tar.xz
glibc-407a551539baefb7ac3b3e2bf2e40aa5c922204d.zip
[BZ #627]
	* libio/iofclose.c (_IO_new_fclose): Unlock the internal lock
	before destroying it as part of the _IO_FINISH call.
-rw-r--r--ChangeLog4
-rw-r--r--libio/iofclose.c4
2 files changed, 6 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index e5b24f6805..828605abc8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 2005-09-26  Ulrich Drepper  <drepper@redhat.com>
 
+	[BZ #627]
+	* libio/iofclose.c (_IO_new_fclose): Unlock the internal lock
+	before destroying it as part of the _IO_FINISH call.
+
 	[BZ #524]
 	* sysdeps/posix/getaddrinfo.c (match_prefix): Fix matching loop of
 	number of bits is multiple of 8.
diff --git a/libio/iofclose.c b/libio/iofclose.c
index a372ae2b24..aa2ba40064 100644
--- a/libio/iofclose.c
+++ b/libio/iofclose.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1993,1995,1997-2003,2004 Free Software Foundation, Inc.
+/* Copyright (C) 1993,1995,1997-2004,2005 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
@@ -62,8 +62,8 @@ _IO_new_fclose (fp)
     status = INTUSE(_IO_file_close_it) (fp);
   else
     status = fp->_flags & _IO_ERR_SEEN ? -1 : 0;
-  _IO_FINISH (fp);
   _IO_release_lock (fp);
+  _IO_FINISH (fp);
   if (fp->_mode > 0)
     {
 #if _LIBC