From The Linux Programming Interface
In an interactive shell, these three file descriptors 0, 1 and 2 normally refer to the terminal under which the shell is running.
Does "the terminal under which the shell is running" mean the controlling terminal of the session to which the interactive shell belongs?
If yes, what if the shell's session doesn't have a controlling terminal?
When the shell is created from its parent process, will the shell automatically create connection betwee file descriptors 0, 1 and 2 and the terminal, in each of the following cases (inheritance from the parent process of the shell):
if "the terminal under which the shell is running" or the controlling terminal has already been opened at a file descriptor which is not 0, 1 and 2?
if the file descriptors 0, 1 and 2 have already been connected to a file which is not "the terminal under which the shell is running" or the controlling terminal?
- What if the shell in the quote is noninteractive?
Thanks.
Btw, just assume "shell" is POSIX or bash.
Related How can we disconnect a file descriptor from any file?
init
spawnsgetty
which opens the port and waits for a terminal to connect then execslogin
which verifies the userid/password and usually (except for a restricted userid) execs a shell -- all with 0,1,2 on the terminal. – dave_thompson_085 May 29 '18 at 03:28