Skip to content

Conversation

@yshui
Copy link
Contributor

@yshui yshui commented Aug 7, 2025

Description

Add prototype for sigqueue

Sources

https://github.com/bminor/glibc/blob/8543577b04ded6d979ffcc5a818930e4d74d0645/include/signal.h#L50-L51
https://github.com/bminor/musl/blob/8fd5d031876345e42ae3d11cc07b962f8625bc3b/include/signal.h#L228

Checklist

  • Relevant tests in libc-test/semver have been updated
  • No placeholder or unstable values like *LAST or *MAX are
    included (see #3131)
  • Tested locally (cd libc-test && cargo test --target mytarget);
    especially relevant for platforms that may not be checked in CI

@rustbot rustbot added the O-unix label Aug 7, 2025
@yshui yshui force-pushed the main branch 6 times, most recently from c895135 to 50e3c82 Compare August 7, 2025 23:50
@yshui yshui marked this pull request as ready for review August 8, 2025 00:09
Copy link
Contributor

@tgross35 tgross35 left a comment

Choose a reason for hiding this comment

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

Please also update the PR description with permalinks to the relevant headers.

@tgross35
Copy link
Contributor

@rustbot author

@rustbot
Copy link
Collaborator

rustbot commented Aug 11, 2025

Reminder, once the PR becomes ready for a review, use @rustbot ready.

@yshui
Copy link
Contributor Author

yshui commented Aug 11, 2025

@rustbot ready

Copy link
Contributor

@tgross35 tgross35 left a comment

Choose a reason for hiding this comment

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

One more thing, from the PR template:

>     * [ ]  Relevant tests in `libc-test/semver` have been updated

@tgross35 tgross35 changed the title Add sigqueue Unix: Add sigqueue Aug 15, 2025
@tgross35
Copy link
Contributor

Looking into this more, I'm not seeing this for OpenBSD or for Android. I don't think it's a safe assumption that this is available on all Unix platforms except Apple and emscripten.

So, please add one definition in src/unix/bsd that excludes target_vendor = "apple", and add one in src/unix/linux_like/linux. Then the semver files freebsd.txt, linux.txt, and netbsd.txt should be updated.

@yshui
Copy link
Contributor Author

yshui commented Aug 15, 2025

kinda in a weird situation:

android has it.
illumos seems to have it. (can't find the header, though)
cygwin has it.
redox has it, IIUC
qnx neutrino has it
aix has it
haiku has it

i think openbsd and hurd are the ones that don't have it.

@yshui
Copy link
Contributor Author

yshui commented Aug 15, 2025

and sigqueue is POSIX.1-2001, not an os-specific extension

@tgross35
Copy link
Contributor

Thanks for the sources. Could you update to exclude OpenBSD and Hurd then?

Since there are exclusions, the semver files can't be in unix.txt unfortunately. Instead, it should go in the .txt files for all the platforms you mentioned (or at least the major ones).

illumos seems to have it. (can't find the header, though)

At least they seem to have a manpage https://smartos.org/man/3C/sigqueue

and sigqueue is POSIX.1-2001, not an os-specific extension

I figure you know already but just confirming, we try to match what the platform actually has available since they don't all always have the complete POSIX-defined API.

@yshui
Copy link
Contributor Author

yshui commented Aug 18, 2025

Comment on lines 235 to 240
setgrent
setpwent
sigqueue
setrlimit
setservent
sigtimedwait
Copy link
Contributor

Choose a reason for hiding this comment

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

sigqueue has to go after setservent here

After this, lgtm

Copy link
Contributor Author

Choose a reason for hiding this comment

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

🤦‍♂️

Copy link
Contributor

@tgross35 tgross35 left a comment

Choose a reason for hiding this comment

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

Thank you!

@tgross35 tgross35 enabled auto-merge August 18, 2025 23:54
@tgross35 tgross35 added this pull request to the merge queue Aug 19, 2025
Merged via the queue into rust-lang:main with commit 8c2810a Aug 19, 2025
48 of 52 checks passed
@tgross35 tgross35 added the stable-nominated This PR should be considered for cherry-pick to libc's stable release branch label Sep 19, 2025
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Sep 21, 2025
(backport <rust-lang#4620>)
(cherry picked from commit 8c2810a)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Sep 23, 2025
(backport <rust-lang#4620>)
(cherry picked from commit 8c2810a)
@tgross35 tgross35 mentioned this pull request Sep 23, 2025
github-merge-queue bot pushed a commit that referenced this pull request Sep 23, 2025
(backport <#4620>)
(cherry picked from commit 8c2810a)
@tgross35 tgross35 added stable-applied This PR has been cherry-picked to libc's stable release branch and removed stable-nominated This PR should be considered for cherry-pick to libc's stable release branch labels Sep 23, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

O-unix stable-applied This PR has been cherry-picked to libc's stable release branch

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants