work around broken Solaris sys/socket.h
This commit is contained in:
parent
c169ae9b4a
commit
f0e9a2afc9
@ -8,8 +8,10 @@ int io_passfd(int64 sock,int64 fd) {
|
|||||||
#else
|
#else
|
||||||
|
|
||||||
#define _XOPEN_SOURCE
|
#define _XOPEN_SOURCE
|
||||||
|
#define _XOPEN_SOURCE_EXTENDED 1
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/time.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/uio.h>
|
#include <sys/uio.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
@ -25,8 +27,11 @@ union fdmsg {
|
|||||||
int io_passfd(int64 sock,int64 fd) {
|
int io_passfd(int64 sock,int64 fd) {
|
||||||
struct msghdr msg;
|
struct msghdr msg;
|
||||||
struct iovec iov;
|
struct iovec iov;
|
||||||
#ifdef CMSG_LEN
|
#ifdef CMSG_FIRSTHDR
|
||||||
struct cmsghdr *cmsg;
|
struct cmsghdr *cmsg;
|
||||||
|
#ifndef CMSG_SPACE
|
||||||
|
#define CMSG_SPACE(x) x+100
|
||||||
|
#endif
|
||||||
char buf[CMSG_SPACE(sizeof(int))];
|
char buf[CMSG_SPACE(sizeof(int))];
|
||||||
#endif
|
#endif
|
||||||
iov.iov_len=1;
|
iov.iov_len=1;
|
||||||
@ -35,12 +40,15 @@ int io_passfd(int64 sock,int64 fd) {
|
|||||||
msg.msg_iovlen=1;
|
msg.msg_iovlen=1;
|
||||||
msg.msg_name=0;
|
msg.msg_name=0;
|
||||||
msg.msg_namelen=0;
|
msg.msg_namelen=0;
|
||||||
#ifdef CMSG_LEN
|
#ifdef CMSG_FIRSTHDR
|
||||||
msg.msg_control = buf;
|
msg.msg_control = buf;
|
||||||
msg.msg_controllen = sizeof(buf);
|
msg.msg_controllen = sizeof(buf);
|
||||||
cmsg = CMSG_FIRSTHDR(&msg);
|
cmsg = CMSG_FIRSTHDR(&msg);
|
||||||
cmsg->cmsg_level = SOL_SOCKET;
|
cmsg->cmsg_level = SOL_SOCKET;
|
||||||
cmsg->cmsg_type = SCM_RIGHTS;
|
cmsg->cmsg_type = SCM_RIGHTS;
|
||||||
|
#ifndef CMSG_LEN
|
||||||
|
#define CMSG_LEN(x) x
|
||||||
|
#endif
|
||||||
cmsg->cmsg_len = CMSG_LEN(sizeof(int));
|
cmsg->cmsg_len = CMSG_LEN(sizeof(int));
|
||||||
msg.msg_controllen = cmsg->cmsg_len;
|
msg.msg_controllen = cmsg->cmsg_len;
|
||||||
*((int*)CMSG_DATA(cmsg))=fd;
|
*((int*)CMSG_DATA(cmsg))=fd;
|
||||||
|
@ -8,6 +8,7 @@ int64 io_receivefd(int64 sock) {
|
|||||||
#else
|
#else
|
||||||
|
|
||||||
#define _XOPEN_SOURCE
|
#define _XOPEN_SOURCE
|
||||||
|
#define _XOPEN_SOURCE_EXTENDED 1
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
@ -23,7 +24,7 @@ union fdmsg {
|
|||||||
int64 io_receivefd(int64 sock) {
|
int64 io_receivefd(int64 sock) {
|
||||||
struct iovec iov;
|
struct iovec iov;
|
||||||
struct msghdr msg;
|
struct msghdr msg;
|
||||||
#ifdef CMSG_LEN
|
#ifdef CMSG_FIRSTHDR
|
||||||
union fdmsg cmsg;
|
union fdmsg cmsg;
|
||||||
struct cmsghdr* h;
|
struct cmsghdr* h;
|
||||||
#else
|
#else
|
||||||
@ -35,7 +36,7 @@ int64 io_receivefd(int64 sock) {
|
|||||||
iov.iov_len=100;
|
iov.iov_len=100;
|
||||||
msg.msg_name=name;
|
msg.msg_name=name;
|
||||||
msg.msg_namelen=100;
|
msg.msg_namelen=100;
|
||||||
#ifdef CMSG_LEN
|
#ifdef CMSG_FIRSTHDR
|
||||||
msg.msg_control=cmsg.buf;
|
msg.msg_control=cmsg.buf;
|
||||||
msg.msg_controllen=sizeof(union fdmsg);
|
msg.msg_controllen=sizeof(union fdmsg);
|
||||||
#else
|
#else
|
||||||
@ -44,9 +45,12 @@ int64 io_receivefd(int64 sock) {
|
|||||||
#endif
|
#endif
|
||||||
msg.msg_iov = &iov;
|
msg.msg_iov = &iov;
|
||||||
msg.msg_iovlen = 1;
|
msg.msg_iovlen = 1;
|
||||||
#ifdef CMSG_LEN
|
#ifdef CMSG_FIRSTHDR
|
||||||
msg.msg_flags=0;
|
msg.msg_flags=0;
|
||||||
h=CMSG_FIRSTHDR(&msg);
|
h=CMSG_FIRSTHDR(&msg);
|
||||||
|
#ifndef CMSG_LEN
|
||||||
|
#define CMSG_LEN(x) x
|
||||||
|
#endif
|
||||||
h->cmsg_len=CMSG_LEN(sizeof(int));
|
h->cmsg_len=CMSG_LEN(sizeof(int));
|
||||||
h->cmsg_level=SOL_SOCKET;
|
h->cmsg_level=SOL_SOCKET;
|
||||||
h->cmsg_type=SCM_RIGHTS;
|
h->cmsg_type=SCM_RIGHTS;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user