Skip to content

Conversation

@xingxue-ibm
Copy link
Contributor

Description

These non-POSIX functions were previously removed because they are guarded by the _KERNEL macro in AIX headers. After discussion, we thought they might be useful, so this patch restores them with fixes.

Sources

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
Copy link
Collaborator

rustbot commented Aug 1, 2025

Unknown labels: O-unix, S-waiting-on-review

Comment on lines 3237 to 3244
pub fn sctp_opt_info(
sd: c_int,
id: c_uint,
opt: c_int,
arg_size: *mut c_void,
size: *mut size_t,
) -> c_int;
Copy link
Contributor

Choose a reason for hiding this comment

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

Per https://www.ibm.com/docs/en/aix/7.2.0?topic=s-sctp-opt-info-subroutine, opt is sctp_assoc_t. I assume this is defined to unsigned, but is it worth a typedef?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Thanks for checking. Yeah, there seems to be some AIX header weirdness. The AIX man page specifies the type sctp_assoc_t for the argument id, but the prototype in the header files has type uint32_t for it.
Man page:

       int sctp_opt_info(sd, id, opt, *arg_size, *size);
       int sd;
       sctp_assoc_t id;
       int opt;
       void *arg_size;
       size_t *size;

net/proto_uipc.h:

int             sctp_opt_info PROTO((int, uint32_t, int, void *, size_t *));

I agree it makes it consistent with the man page if we define its type as sctp_assoc_t on the Rust side. The typedef of sctp_assoc_t is defined in header netinet/sctp.h so I am pulling the header in. sctp_peeloff and sctp_opt_info are also declared in netinet/sctp.h without the _KERNEL guard so I am removing them from the function skip list in build.rs.

typedef uint32_t sctp_assoc_t;
int sctp_peeloff(int s, uint32_t * assoc_id);
int sctp_opt_info(int s, uint32_t id, int opt, void *arg, size_t *size);
int sctp_getladdrs(int sd, sctp_assoc_t id, struct sockaddr **addrs);
int sctp_getpaddrs(int sd, sctp_assoc_t id, struct sockaddr **addrs);

pub fn semget(key: crate::key_t, nsems: c_int, semflag: c_int) -> c_int;
pub fn semop(semid: c_int, sops: *mut sembuf, nsops: size_t) -> c_int;
pub fn send_file(socket: *mut c_int, iobuf: *mut sf_parms, flags: c_uint) -> ssize_t;
pub fn sendmmsg(sockfd: c_int, msgvec: *mut mmsghdr, vlen: c_uint, flags: c_int) -> c_int;
Copy link
Contributor

Choose a reason for hiding this comment

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

It looks like this only has three fields at https://www.ibm.com/docs/en/aix/7.3.0?topic=s-sendmmsg-subroutine, is that inaccurate?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The online doc does not seem to be accurate. The prototype in AIX header net/proto_uipc.h is as follows. I will open an issue against the AIX doc.

int             sendmmsg PROTO((int, struct mmsghdr *, unsigned int, int));

Comment on lines 5741 to 5653
// These non-POSIX functions are guarded by the _KERNEL macro in the AIX headers.
"recvmmsg" | "sendmmsg" | "sctp_opt_info" | "sctp_peeloff" | "sethostid"
| "sethostname" | "splice" => true,

// 'mount' is available in the system's libc.a and has a man page, but it is
// not declared in the AIX headers."
"mount" => true,
Copy link
Contributor

Choose a reason for hiding this comment

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

Just checking, are these somewhat common to use on AIX even though they aren't defined? mount on other platforms usually has a void *data arg of fs-specific flags, I'm wondering if there's a chance the AIX version changes to take one as well.

sendmmsg/recvmmsg are pretty common, I'm surprised nobody has moved your #ifdef __KERNEL a few lines lower yet 🙂

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Thanks again for checking. I checked the documentation for the latest AIX release (v7.3), and mount still takes three arguments. By definition, _KERNEL is meant to guard code used for writing kernel extensions, but it seems some of these functions are also used in OSS. Yes, sendmmsg and recvmmsg should be moved out of the block. I will open an issue against the AIX headers for these functions as well as mount.

@tgross35 tgross35 enabled auto-merge August 13, 2025 07:56
@tgross35 tgross35 added the stable-nominated This PR should be considered for cherry-pick to libc's stable release branch label Aug 13, 2025
@tgross35
Copy link
Contributor

Thanks for the PR and the detailed followup, everything sounds reasonable to me.

@xingxue-ibm
Copy link
Contributor Author

Thank you for checking and pointing out the discrepancies in the man pages.

@tgross35 tgross35 added this pull request to the merge queue Aug 13, 2025
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Aug 13, 2025
@tgross35 tgross35 added this pull request to the merge queue Aug 13, 2025
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Aug 13, 2025
@tgross35 tgross35 added this pull request to the merge queue Aug 14, 2025
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Aug 14, 2025
@tgross35 tgross35 added this pull request to the merge queue Aug 14, 2025
Merged via the queue into rust-lang:main with commit b02c121 Aug 14, 2025
85 of 100 checks passed
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Sep 21, 2025
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Sep 21, 2025
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Sep 21, 2025
@tgross35 tgross35 mentioned this pull request Sep 21, 2025
github-merge-queue bot pushed a commit that referenced this pull request Sep 22, 2025
github-merge-queue bot pushed a commit that referenced this pull request Sep 22, 2025
@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 22, 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