]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
osdep/unix/exec: Avoid atexit() handlers when child execvp() fails
authorDimitri John Ledkov <xnox@ubuntu.com>
Thu, 29 Apr 2021 11:34:34 +0000 (12:34 +0100)
committerDaniel Kiper <daniel.kiper@oracle.com>
Tue, 1 Jun 2021 15:20:20 +0000 (17:20 +0200)
The functions grub_util_exec_pipe() and grub_util_exec_pipe_stderr()
currently call execvp(). If the call fails for any reason, the child
currently calls exit(127). This in turn executes the parents
atexit() handlers from the forked child, and then the same handlers
are called again from parent. This is usually not desired, and can
lead to deadlocks, and undesired behavior. So, change the exit() calls
to _exit() calls to avoid calling atexit() handlers from child.

Fixes: e75cf4a58 (unix exec: avoid atexit handlers when child exits)
Signed-off-by: Dimitri John Ledkov <xnox@ubuntu.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
grub-core/osdep/unix/exec.c

index db3259f6504d5d5958cfa330bfd4a8b12b64f970..e8db9202fba282d6470c988bfe9bdf62a9cd4b91 100644 (file)
@@ -188,7 +188,7 @@ grub_util_exec_pipe (const char *const *argv, int *fd)
       close (pipe_fd[1]);
 
       execvp ((char *) argv[0], (char **) argv);
-      exit (127);
+      _exit (127);
     }
   else
     {
@@ -234,7 +234,7 @@ grub_util_exec_pipe_stderr (const char *const *argv, int *fd)
       close (pipe_fd[1]);
 
       execvp ((char *) argv[0], (char **) argv);
-      exit (127);
+      _exit (127);
     }
   else
     {