git: ab41d7f371f5 - sh: Explain duplicate tcsetpgrp() calls

Jilles Tjoelker jilles at FreeBSD.org
Sat Dec 26 15:00:03 UTC 2020


The branch main has been updated by jilles:

URL: https://cgit.FreeBSD.org/src/commit/?id=ab41d7f371f52097ab0cb183565f1d8e7c122760

commit ab41d7f371f52097ab0cb183565f1d8e7c122760
Author:     Jilles Tjoelker <jilles at FreeBSD.org>
AuthorDate: 2020-12-26 14:27:33 +0000
Commit:     Jilles Tjoelker <jilles at FreeBSD.org>
CommitDate: 2020-12-26 14:27:33 +0000

    sh: Explain duplicate tcsetpgrp() calls
    
    This is a comment change only.
---
 bin/sh/jobs.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/bin/sh/jobs.c b/bin/sh/jobs.c
index c46e526eab67..c0ba7d75e16d 100644
--- a/bin/sh/jobs.c
+++ b/bin/sh/jobs.c
@@ -928,7 +928,12 @@ forkshell(struct job *jp, union node *n, int mode)
 				pgrp = jp->ps[0].pid;
 			if (setpgid(0, pgrp) == 0 && mode == FORK_FG &&
 			    ttyfd >= 0) {
-				/*** this causes superfluous TIOCSPGRPS ***/
+				/*
+				 * Each process in a pipeline must have the tty
+				 * pgrp set before running its code.
+				 * Only for pipelines of three or more processes
+				 * could this be reduced to two calls.
+				 */
 				if (tcsetpgrp(ttyfd, pgrp) < 0)
 					error("tcsetpgrp failed, errno=%d", errno);
 			}


More information about the dev-commits-src-all mailing list