From: Zbigniew Jędrzejewski-Szmek Date: Thu, 3 Dec 2015 07:20:39 +0000 (-0500) Subject: journal: unbreak sd_journal_sendv X-Git-Tag: v229.1~1^2~91 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=228222e070b7830f08a41ecfd815aa047e7fc03e journal: unbreak sd_journal_sendv Borked since commit 3ee897d6c2401effbc82f5eef35fce405781d6c8 Author: Lennart Poettering Date: Wed Sep 23 01:00:04 2015 +0200 tree-wide: port more code to use send_one_fd() and receive_one_fd() because here our fd is not connected and we need to specify the address. --- diff --git a/src/basic/socket-util.c b/src/basic/socket-util.c index 467a50092..ee08a9c9c 100644 --- a/src/basic/socket-util.c +++ b/src/basic/socket-util.c @@ -876,16 +876,24 @@ int getpeersec(int fd, char **ret) { return 0; } -int send_one_fd(int transport_fd, int fd, int flags) { +int send_one_fd_sa( + int transport_fd, + int fd, + const struct sockaddr *sa, socklen_t len, + int flags) { + union { struct cmsghdr cmsghdr; uint8_t buf[CMSG_SPACE(sizeof(int))]; } control = {}; + struct cmsghdr *cmsg; + struct msghdr mh = { + .msg_name = (struct sockaddr*) sa, + .msg_namelen = len, .msg_control = &control, .msg_controllen = sizeof(control), }; - struct cmsghdr *cmsg; assert(transport_fd >= 0); assert(fd >= 0);