From 4ee543e58c5e6cf5ef0b94dfec752dadbbd063d3 Mon Sep 17 00:00:00 2001 From: rsc Date: Fri, 18 Mar 2005 19:03:25 +0000 Subject: try harder to put background jobs in background; do not print in response to SIGPIPE --- src/cmd/rc/exec.c | 32 +++++++++++++++++++++++++++++++- src/cmd/rc/havefork.c | 10 ++++++++++ src/cmd/rc/plan9ish.c | 1 + src/cmd/rc/rc.h | 3 +++ 4 files changed, 45 insertions(+), 1 deletion(-) (limited to 'src/cmd') diff --git a/src/cmd/rc/exec.c b/src/cmd/rc/exec.c index fc7b630b..e6cde9e1 100644 --- a/src/cmd/rc/exec.c +++ b/src/cmd/rc/exec.c @@ -1,3 +1,6 @@ +#include +#include +#include #include "rc.h" #include "getflags.h" #include "exec.h" @@ -220,6 +223,7 @@ void Xappend(void){ } void Xasync(void){ int null=open("/dev/null", 0); + int tty; int pid; char npid[10]; if(null<0){ @@ -232,7 +236,33 @@ void Xasync(void){ Xerror("try again"); break; case 0: - pushredir(ROPEN, null, 0); + /* + * I don't know what the right thing to do here is, + * so this is all experimentally determined. + * If we just dup /dev/null onto 0, then running + * ssh foo & will reopen /dev/tty, try to read a password, + * get a signal, and repeat, in a tight loop, forever. + * Arguably this is a bug in ssh (it behaves the same + * way under bash as under rc) but I'm fixing it here + * anyway. If we dissociate the process from the tty, + * then it won't be able to open /dev/tty ever again. + * The SIG_IGN on SIGTTOU makes writing the tty + * (via fd 1 or 2, for example) succeed even though + * our pgrp is not the terminal's controlling pgrp. + */ + if((tty=open("/dev/tty", OREAD)) >= 0){ + /* + * Should make reads of tty fail, writes succeed. + */ + signal(SIGTTIN, SIG_IGN); + signal(SIGTTOU, SIG_IGN); + ioctl(tty, TIOCNOTTY); + close(tty); + } + if(isatty(0)) + pushredir(ROPEN, null, 0); + else + close(null); start(runq->code, runq->pc+1, runq->local); runq->ret=0; break; diff --git a/src/cmd/rc/havefork.c b/src/cmd/rc/havefork.c index e81046d6..6e4aa924 100644 --- a/src/cmd/rc/havefork.c +++ b/src/cmd/rc/havefork.c @@ -1,3 +1,5 @@ +#include +#include #include "rc.h" #include "getflags.h" #include "exec.h" @@ -11,7 +13,9 @@ Xasync(void) { int null = open("/dev/null", 0); int pid; + int tcpgrp, pgrp; char npid[10]; + if(null<0){ Xerror("Can't open /dev/null\n"); return; @@ -22,6 +26,12 @@ Xasync(void) Xerror("try again"); break; case 0: + /* + * Should make reads of tty fail, writes succeed. + */ + signal(SIGTTIN, SIG_IGN); + signal(SIGTTOU, SIG_IGN); + pushredir(ROPEN, null, 0); start(runq->code, runq->pc+1, runq->local); runq->ret = 0; diff --git a/src/cmd/rc/plan9ish.c b/src/cmd/rc/plan9ish.c index 387fbbb8..33d19f43 100644 --- a/src/cmd/rc/plan9ish.c +++ b/src/cmd/rc/plan9ish.c @@ -403,6 +403,7 @@ notifyf(void *unused0, char *s) } goto Out; } + if(strcmp(s, "sys: write on closed pipe") != 0) if(strcmp(s, "sys: child") != 0) pfmt(err, "rc: note: %s\n", s); noted(NDFLT); diff --git a/src/cmd/rc/rc.h b/src/cmd/rc/rc.h index 0996eec5..3e79617d 100644 --- a/src/cmd/rc/rc.h +++ b/src/cmd/rc/rc.h @@ -9,6 +9,9 @@ #ifdef Plan9 #include #include +#undef NSIG +#undef SIGINT +#undef SIGQUIT #define NSIG 32 #define SIGINT 2 #define SIGQUIT 3 -- cgit v1.2.3