Skip to content
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

std.process.Child: use clone() instead of fork() #22368

Open
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

ruihe774
Copy link
Contributor

@ruihe774 ruihe774 commented Dec 31, 2024

See discussions in #1620.

This PR depends on #22341. (merged)

@ruihe774 ruihe774 force-pushed the clone branch 2 times, most recently from 0b61b7d to 57ee91d Compare December 31, 2024 04:32
@ruihe774
Copy link
Contributor Author

clone() does not work in .stage2_c. I disabled it in this case.

@ruihe774 ruihe774 force-pushed the clone branch 14 times, most recently from 6f31e98 to 351ce97 Compare December 31, 2024 09:39
@ruihe774
Copy link
Contributor Author

ruihe774 commented Dec 31, 2024

I use clone3() in x86 and x86_64 so that I can use CLONE_CLEAR_SIGHAND if available. I'm not familiar with (and I cannot test) asm of other ISAs. Sorry.

@ruihe774 ruihe774 force-pushed the clone branch 2 times, most recently from 2ac3a31 to 0713379 Compare December 31, 2024 10:02
@ruihe774
Copy link
Contributor Author

@alexrp PTAL.

@ruihe774 ruihe774 force-pushed the clone branch 4 times, most recently from 27e8236 to 25c7f1b Compare December 31, 2024 13:16
@ruihe774 ruihe774 force-pushed the clone branch 2 times, most recently from e88bb54 to f57a745 Compare January 4, 2025 02:55
@ruihe774
Copy link
Contributor Author

@alexrp Is #22427 a blockade of this PR?

@alexrp
Copy link
Member

alexrp commented Jan 15, 2025

Probably not. The workaround can be removed once that bug has been fixed.

By the way, I'm not particularly familiar with the actual process management logic in std.process.Child. Someone else should probably review that.

@@ -15,6 +15,8 @@ const native_os = builtin.os.tag;
const Allocator = std.mem.Allocator;
const ChildProcess = @This();

const use_clone = native_os == .linux and builtin.zig_backend != .stage2_c;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
const use_clone = native_os == .linux and builtin.zig_backend != .stage2_c;
const use_clone = native_os == .linux and builtin.zig_backend != .stage2_c; // https://github.com/ziglang/zig/issues/22427

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants