2016-05-03 12:28:06 +08:00
|
|
|
// Functions that we may safely call after fork(), of which there are very few. In particular we
|
|
|
|
// cannot allocate memory, since we're insane enough to call fork from a multithreaded process.
|
2012-02-28 11:20:27 +08:00
|
|
|
#ifndef FISH_POSTFORK_H
|
|
|
|
#define FISH_POSTFORK_H
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
2017-02-13 12:24:22 +08:00
|
|
|
#include <stddef.h>
|
2016-04-21 14:00:54 +08:00
|
|
|
#include <unistd.h>
|
2012-08-15 15:57:56 +08:00
|
|
|
#if HAVE_SPAWN_H
|
|
|
|
#include <spawn.h>
|
|
|
|
#endif
|
|
|
|
#ifndef FISH_USE_POSIX_SPAWN
|
2012-11-19 08:30:30 +08:00
|
|
|
#define FISH_USE_POSIX_SPAWN HAVE_SPAWN_H
|
2012-08-15 15:57:56 +08:00
|
|
|
#endif
|
|
|
|
|
2019-01-29 06:35:56 +08:00
|
|
|
class dup2_list_t;
|
2016-04-21 14:00:54 +08:00
|
|
|
class job_t;
|
|
|
|
class process_t;
|
2012-08-15 15:57:56 +08:00
|
|
|
|
2017-08-07 07:05:51 +08:00
|
|
|
bool set_child_group(job_t *j, pid_t child_pid); // called by parent
|
|
|
|
bool child_set_group(job_t *j, process_t *p); // called by child
|
2012-03-01 03:27:14 +08:00
|
|
|
|
2016-05-03 12:28:06 +08:00
|
|
|
/// Initialize a new child process. This should be called right away after forking in the child
|
|
|
|
/// process. If job control is enabled for this job, the process is put in the process group of the
|
|
|
|
/// job, all signal handlers are reset, signals are unblocked (this function may only be called
|
|
|
|
/// inside the exec function, which blocks all signals), and all IO redirections and other file
|
|
|
|
/// descriptor actions are performed.
|
|
|
|
///
|
2019-07-02 01:57:09 +08:00
|
|
|
/// Assign the terminal to new_termowner unless it is INVALID_PID.
|
|
|
|
///
|
2019-10-19 09:36:03 +08:00
|
|
|
/// \return 0 on success, -1 on failure. When this function returns, signals are always unblocked.
|
2019-07-02 01:57:09 +08:00
|
|
|
/// On failure, signal handlers, io redirections and process group of the process is undefined.
|
2020-04-05 16:24:26 +08:00
|
|
|
int child_setup_process(pid_t new_termowner, const job_t &job, bool is_forked, const dup2_list_t &dup2s);
|
2012-02-28 11:20:27 +08:00
|
|
|
|
2019-11-24 04:36:44 +08:00
|
|
|
/// Call fork(), retrying on failure a few times.
|
|
|
|
pid_t execute_fork();
|
2012-02-29 07:11:46 +08:00
|
|
|
|
2016-05-03 12:28:06 +08:00
|
|
|
/// Report an error from failing to exec or posix_spawn a command.
|
|
|
|
void safe_report_exec_error(int err, const char *actual_cmd, const char *const *argv,
|
|
|
|
const char *const *envv);
|
2012-08-15 15:57:56 +08:00
|
|
|
|
|
|
|
#if FISH_USE_POSIX_SPAWN
|
2016-05-03 12:28:06 +08:00
|
|
|
/// Initializes and fills in a posix_spawnattr_t; on success, the caller should destroy it via
|
|
|
|
/// posix_spawnattr_destroy.
|
|
|
|
bool fork_actions_make_spawn_properties(posix_spawnattr_t *attr,
|
2019-01-29 16:34:38 +08:00
|
|
|
posix_spawn_file_actions_t *actions, const job_t *j,
|
|
|
|
const dup2_list_t &dup2s);
|
2012-08-15 15:57:56 +08:00
|
|
|
#endif
|
|
|
|
|
2012-02-28 11:20:27 +08:00
|
|
|
#endif
|