-
Notifications
You must be signed in to change notification settings - Fork 43
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
from_env causes io-unsafety in child processes #64
Comments
I think removing the env arg makes sense? Since if you create a new jobserver, its fd is cloexec and there's no jobserver env setup. |
I suspect that in a typical case you do want to pass the created or inherited jobserver to children processes. In all cases caught by rust-lang/rust#113730 the right solution was to pass the jobserver further (except one case when it didn't matter much). |
#65 is a draft PR that reverses the current behavior - jobserver is inherited by default, but the inheritance can be disabled by explicitly calling a method. |
I think the best way to fix this is to use named fifo instead of annoymous pipe. Passing pipe by fd also shares its file description, meaning whenever one process sets I've got bitten by this the hard way in cc |
(copied from rust-lang/rust#113730 (comment))
These lines seem questionable:
jobserver-rs/src/unix.rs
Lines 152 to 153 in b4bc5db
They lead the fds not being available to child processes by default (unless reverted by
Client::configure
) but from_env_ext() does not remove the environment variables. Which means child processes are instructed to access file descriptor numbers for jobserver communication that aren't open anymore and may have been reopened to point to other files. This seems like a violation of IO-safety (rust-lang/rust#116059 (comment)).Either cloexec shouldn't be set or the environment variables should also be removed and only be added back via
configure
.The text was updated successfully, but these errors were encountered: