about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--libio/fileops.c2
-rw-r--r--libio/iofclose.c3
3 files changed, 8 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 541c0e1f5f..910b561189 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2002-04-02  Ulrich Drepper  <drepper@redhat.com>
+
+	* libio/iofclose.c (_IO_new_fclose): Move freeing of backup buffer
+	to ...
+	* libio/fileops.c (_IO_new_file_close_it): ...here [PR libc/3190].
+
 2002-04-02  Jakub Jelinek  <jakub@redhat.com>
 
 	* inet/ether_ntoh.c (__nss_ethers_lookup): Add internal_function.
diff --git a/libio/fileops.c b/libio/fileops.c
index dbea6318f0..7144a87289 100644
--- a/libio/fileops.c
+++ b/libio/fileops.c
@@ -177,6 +177,8 @@ _IO_new_file_close_it (fp)
 #if defined _LIBC || defined _GLIBCPP_USE_WCHAR_T
   else
     {
+      if (_IO_have_wbackup (fp))
+	INTUSE(_IO_free_wbackup_area) (fp);
       INTUSE(_IO_wsetb) (fp, NULL, NULL, 0);
       _IO_wsetg (fp, NULL, NULL, NULL);
       _IO_wsetp (fp, NULL, NULL);
diff --git a/libio/iofclose.c b/libio/iofclose.c
index fb0f7ce19e..62d12244c5 100644
--- a/libio/iofclose.c
+++ b/libio/iofclose.c
@@ -76,9 +76,6 @@ _IO_new_fclose (fp)
       __gconv_release_step (cc->__cd_in.__cd.__steps);
       __gconv_release_step (cc->__cd_out.__cd.__steps);
 #endif
-
-      if (_IO_have_wbackup (fp))
-	INTUSE(_IO_free_wbackup_area) (fp);
     }
   else
     {