]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
stdio-common: In tst-setvbuf2, close helper thread descriptor only if opened
authorFlorian Weimer <fweimer@redhat.com>
Tue, 8 Apr 2025 08:39:44 +0000 (10:39 +0200)
committerFlorian Weimer <fweimer@redhat.com>
Tue, 8 Apr 2025 08:39:44 +0000 (10:39 +0200)
The helper thread may get canceled before the open system
call succeds.  Then ThreadData.fd remains zero, and eventually
the xclose call in end_reader_thread fails because descriptor 0
is not open.

Instead, initialize the fd member to -1 (not a valid descriptor)
and close the descriptor only if valid.  Do this in a new end_thread
helper routine.

Also add more error checking to close operations.

Fixes commit 95b780c1d0549678c0a244c6e2112ec97edf0839 ("stdio: Add
more setvbuf tests").

stdio-common/tst-setvbuf2.c

index 6cc83355f391afabde64f686df4b7b97416f5fe1..84d8b43a5811b4be257ab65dfa30cc610270b76a 100644 (file)
@@ -240,6 +240,21 @@ typedef struct {
 /* It's OK if this is static, we only run one at a time.  */
 ThreadData thread_data;
 
+static void
+end_thread (pthread_t *ptid)
+{
+  if (*ptid)
+    {
+      pthread_cancel (*ptid);
+      xpthread_join (*ptid);
+      /* The descriptor was passed in, or the helper thread made
+        sufficient progress and opened the file.  */
+      if (thread_data.fd >= 0)
+       xclose (thread_data.fd);
+      *ptid = 0;
+    }
+}
+
 static void *
 writer_thread_proc (void *closure)
 {
@@ -306,7 +321,7 @@ static void
 start_writer_thread_n (const char *fname)
 {
   debug;
-  thread_data.fd = 0;
+  thread_data.fd = -1;
   thread_data.fname = fname;
   writer_thread_tid = xpthread_create (NULL, writer_thread_proc,
                                       (void *)&thread_data);
@@ -316,13 +331,7 @@ static void
 end_writer_thread (void)
 {
   debug;
-  if (writer_thread_tid)
-    {
-      pthread_cancel (writer_thread_tid);
-      xpthread_join (writer_thread_tid);
-      xclose (thread_data.fd);
-      writer_thread_tid = 0;
-    }
+  end_thread (&writer_thread_tid);
 }
 
 static void
@@ -339,7 +348,7 @@ static void
 start_reader_thread_n (const char *fname)
 {
   debug;
-  thread_data.fd = 0;
+  thread_data.fd = -1;
   thread_data.fname = fname;
   reader_thread_tid = xpthread_create (NULL, reader_thread_proc,
                                       (void *)&thread_data);
@@ -349,13 +358,7 @@ static void
 end_reader_thread (void)
 {
   debug;
-  if (reader_thread_tid)
-    {
-      pthread_cancel (reader_thread_tid);
-      xpthread_join (reader_thread_tid);
-      xclose (thread_data.fd);
-      reader_thread_tid = 0;
-    }
+  end_thread (&reader_thread_tid);
 }
 
 /*------------------------------------------------------------*/
@@ -852,7 +855,7 @@ do_second_part (FILE *fp,
     }
 
 
-  fclose (fp);
+  xfclose (fp);
   return rv;
 }
 
@@ -939,7 +942,7 @@ recurse (FILE *fp,
       break;
 
     default: /* parent */
-      fclose (fp);
+      xfclose (fp);
       xwaitpid (pid, &status, 0);
       if (WIFEXITED (status)
          && WEXITSTATUS (status) == 0)