mirror of
https://git.musl-libc.org/git/musl
synced 2025-01-06 23:02:10 +03:00
increase sendmsg internal buffer to support SCM_MAX_FD
The kernel defines a limit on the number of fds that can be passed through an SCM_RIGHTS ancillary message as SCM_MAX_FD. The value was 255 before kernel 2.6.38 (after that it is 253), and an SCM_RIGHTS ancillary message with 255 fds requires 1040 bytes, slightly more than the current 1024 byte internal buffer in sendmsg. 1024 is an arbitrary size, so increase it to match the the arbitrary size limit in the kernel. This fixes tests that are verifying they support up to SCM_MAX_FD fds.
This commit is contained in:
parent
0ab97350f0
commit
f79b973d92
@ -8,13 +8,16 @@ ssize_t sendmsg(int fd, const struct msghdr *msg, int flags)
|
||||
{
|
||||
#if LONG_MAX > INT_MAX
|
||||
struct msghdr h;
|
||||
struct cmsghdr chbuf[1024/sizeof(struct cmsghdr)+1], *c;
|
||||
/* Kernels before 2.6.38 set SCM_MAX_FD to 255, allocate enough
|
||||
* space to support an SCM_RIGHTS ancillary message with 255 fds.
|
||||
* Kernels since 2.6.38 set SCM_MAX_FD to 253. */
|
||||
struct cmsghdr chbuf[CMSG_SPACE(255*sizeof(int))/sizeof(struct cmsghdr)+1], *c;
|
||||
if (msg) {
|
||||
h = *msg;
|
||||
h.__pad1 = h.__pad2 = 0;
|
||||
msg = &h;
|
||||
if (h.msg_controllen) {
|
||||
if (h.msg_controllen > 1024) {
|
||||
if (h.msg_controllen > sizeof chbuf) {
|
||||
errno = ENOMEM;
|
||||
return -1;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user