X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fbasic%2Fsocket-util.c;h=a983c67a826a0ddcd2a49ed09f11177669b764f4;hp=d8006e66ebb38ea1fac1f03b8f399156f1131998;hb=322da0f2742236197ddc08fc29a68ce9f5fdee0f;hpb=e4818ba5276510602ff5550a1e5a058fca51e9d4 diff --git a/src/basic/socket-util.c b/src/basic/socket-util.c index d8006e66e..a983c67a8 100644 --- a/src/basic/socket-util.c +++ b/src/basic/socket-util.c @@ -1066,3 +1066,20 @@ struct cmsghdr* cmsg_find(struct msghdr *mh, int level, int type, socklen_t leng return NULL; } + +int socket_ioctl_fd(void) { + int fd; + + /* Create a socket to invoke the various network interface ioctl()s on. Traditionally only AF_INET was good for + * that. Since kernel 4.6 AF_NETLINK works for this too. We first try to use AF_INET hence, but if that's not + * available (for example, because it is made unavailable via SECCOMP or such), we'll fall back to the more + * generic AF_NETLINK. */ + + fd = socket(AF_INET, SOCK_DGRAM|SOCK_CLOEXEC, 0); + if (fd < 0) + fd = socket(AF_NETLINK, SOCK_RAW|SOCK_CLOEXEC, NETLINK_GENERIC); + if (fd < 0) + return -errno; + + return fd; +}