mirror of
https://github.com/checkpoint-restore/criu
synced 2025-08-25 11:27:40 +00:00
util: move recv_fd and send_fd in a separate file
It will be used in the parasite Signed-off-by: Andrey Vagin <avagin@openvz.org> Acked-by: Pavel Emelyanov <xemul@parallels.com> Signed-off-by: Cyrill Gorcunov <gorcunov@openvz.org>
This commit is contained in:
parent
fd7c44dd86
commit
1465fade3b
1
Makefile
1
Makefile
@ -34,6 +34,7 @@ OBJS += proc_parse.o
|
|||||||
OBJS += cr-dump.o
|
OBJS += cr-dump.o
|
||||||
OBJS += cr-show.o
|
OBJS += cr-show.o
|
||||||
OBJS += util.o
|
OBJS += util.o
|
||||||
|
OBJS += util-net.o
|
||||||
OBJS += ptrace.o
|
OBJS += ptrace.o
|
||||||
OBJS += log.o
|
OBJS += log.o
|
||||||
OBJS += libnetlink.o
|
OBJS += libnetlink.o
|
||||||
|
78
files.c
78
files.c
@ -16,11 +16,9 @@
|
|||||||
#include "image.h"
|
#include "image.h"
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
#include "util-net.h"
|
||||||
#include "lock.h"
|
#include "lock.h"
|
||||||
|
|
||||||
#define UNIX_PATH_MAX (sizeof(struct sockaddr_un) - \
|
|
||||||
(size_t)((struct sockaddr_un *) 0)->sun_path)
|
|
||||||
|
|
||||||
enum fdinfo_states {
|
enum fdinfo_states {
|
||||||
FD_STATE_PREP, /* Create unix sockets */
|
FD_STATE_PREP, /* Create unix sockets */
|
||||||
FD_STATE_CREATE, /* Create and send fd */
|
FD_STATE_CREATE, /* Create and send fd */
|
||||||
@ -326,13 +324,7 @@ static int open_fd(int pid, struct fdinfo_entry *fe,
|
|||||||
(unsigned long)fe->addr, fe->type, fe->len, fi->users);
|
(unsigned long)fe->addr, fe->type, fe->len, fi->users);
|
||||||
|
|
||||||
list_for_each_entry(fle, &fi->list, list) {
|
list_for_each_entry(fle, &fi->list, list) {
|
||||||
struct msghdr hdr;
|
int len;
|
||||||
struct iovec data;
|
|
||||||
char cmsgbuf[CMSG_SPACE(sizeof(int))];
|
|
||||||
struct cmsghdr *cmsg;
|
|
||||||
int *cmsg_data;
|
|
||||||
|
|
||||||
char dummy = '*';
|
|
||||||
|
|
||||||
fi->users--;
|
fi->users--;
|
||||||
|
|
||||||
@ -342,35 +334,15 @@ static int open_fd(int pid, struct fdinfo_entry *fe,
|
|||||||
pr_info("Wait fdinfo pid=%d fd=%d\n", fle->pid, fle->fd);
|
pr_info("Wait fdinfo pid=%d fd=%d\n", fle->pid, fle->fd);
|
||||||
cr_wait_while(&fle->real_pid, 0);
|
cr_wait_while(&fle->real_pid, 0);
|
||||||
|
|
||||||
|
pr_info("Send fd %d to %s\n", (int)fe->addr, saddr.sun_path + 1);
|
||||||
|
|
||||||
saddr.sun_family = AF_UNIX;
|
saddr.sun_family = AF_UNIX;
|
||||||
snprintf(saddr.sun_path, UNIX_PATH_MAX,
|
snprintf(saddr.sun_path, UNIX_PATH_MAX,
|
||||||
"X/crtools-fd-%d-%d", fle->real_pid, fle->fd);
|
"X/crtools-fd-%d-%d", fle->real_pid, fle->fd);
|
||||||
|
len = SUN_LEN(&saddr);
|
||||||
pr_info("Send fd %ld to %s\n", fe->addr, saddr.sun_path + 1);
|
|
||||||
|
|
||||||
data.iov_base = &dummy;
|
|
||||||
data.iov_len = sizeof(dummy);
|
|
||||||
|
|
||||||
hdr.msg_name = (struct sockaddr *)&saddr;
|
|
||||||
hdr.msg_namelen = SUN_LEN(&saddr);
|
|
||||||
*saddr.sun_path = '\0';
|
*saddr.sun_path = '\0';
|
||||||
hdr.msg_iov = &data;
|
|
||||||
hdr.msg_iovlen = 1;
|
|
||||||
hdr.msg_flags = 0;
|
|
||||||
|
|
||||||
hdr.msg_control = &cmsgbuf;
|
if (send_fd(sock, &saddr, len, fe->addr) < 0) {
|
||||||
hdr.msg_controllen = CMSG_LEN(sizeof(int));
|
|
||||||
|
|
||||||
cmsg = CMSG_FIRSTHDR(&hdr);
|
|
||||||
cmsg->cmsg_len = hdr.msg_controllen;
|
|
||||||
cmsg->cmsg_level = SOL_SOCKET;
|
|
||||||
cmsg->cmsg_type = SCM_RIGHTS;
|
|
||||||
|
|
||||||
cmsg_data = (int *)CMSG_DATA(cmsg);
|
|
||||||
*cmsg_data = fe->addr;
|
|
||||||
|
|
||||||
tmp = sendmsg(sock, &hdr, 0);
|
|
||||||
if (tmp < 0) {
|
|
||||||
pr_perror("Can't send file descriptor");
|
pr_perror("Can't send file descriptor");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -382,42 +354,6 @@ out:
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int recv_fd(int sock)
|
|
||||||
{
|
|
||||||
struct msghdr msg;
|
|
||||||
struct iovec iov;
|
|
||||||
char buf[1];
|
|
||||||
char ccmsg[CMSG_SPACE(sizeof(int))];
|
|
||||||
struct cmsghdr *cmsg;
|
|
||||||
int *cmsg_data;
|
|
||||||
iov.iov_base = buf;
|
|
||||||
iov.iov_len = 1;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
msg.msg_name = 0;
|
|
||||||
msg.msg_namelen = 0;
|
|
||||||
msg.msg_iov = &iov;
|
|
||||||
msg.msg_iovlen = 1;
|
|
||||||
msg.msg_control = ccmsg;
|
|
||||||
msg.msg_controllen = sizeof(ccmsg);
|
|
||||||
|
|
||||||
ret = recvmsg(sock, &msg, 0);
|
|
||||||
if (ret == -1) {
|
|
||||||
pr_perror("recvmsg");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
cmsg = CMSG_FIRSTHDR(&msg);
|
|
||||||
if (!cmsg->cmsg_type == SCM_RIGHTS) {
|
|
||||||
pr_perror("got control message of unknown type %d",
|
|
||||||
cmsg->cmsg_type);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
cmsg_data = (int *)CMSG_DATA(cmsg);
|
|
||||||
return *cmsg_data;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int receive_fd(int pid, struct fdinfo_entry *fe, struct fdinfo_desc *fi)
|
static int receive_fd(int pid, struct fdinfo_entry *fe, struct fdinfo_desc *fi)
|
||||||
{
|
{
|
||||||
int tmp;
|
int tmp;
|
||||||
@ -440,7 +376,7 @@ static int receive_fd(int pid, struct fdinfo_entry *fe, struct fdinfo_desc *fi)
|
|||||||
|
|
||||||
tmp = recv_fd(fe->addr);
|
tmp = recv_fd(fe->addr);
|
||||||
if (tmp < 0) {
|
if (tmp < 0) {
|
||||||
pr_err("Can't get fd");
|
pr_err("Can't get fd %d\n", tmp);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
close(fe->addr);
|
close(fe->addr);
|
||||||
|
9
include/util-net.h
Normal file
9
include/util-net.h
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#ifndef UTIL_NET_H_
|
||||||
|
#define UTIL_NET_H_
|
||||||
|
|
||||||
|
#define UNIX_PATH_MAX (sizeof(struct sockaddr_un) - \
|
||||||
|
(size_t)((struct sockaddr_un *) 0)->sun_path)
|
||||||
|
|
||||||
|
extern int send_fd(int sock, struct sockaddr_un *saddr, int len, int fd);
|
||||||
|
extern int recv_fd(int sock);
|
||||||
|
#endif
|
68
util-net.c
Normal file
68
util-net.c
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/un.h>
|
||||||
|
|
||||||
|
#include "syscall.h"
|
||||||
|
|
||||||
|
int send_fd(int sock, struct sockaddr_un *saddr, int len, int fd)
|
||||||
|
{
|
||||||
|
struct msghdr hdr;
|
||||||
|
struct iovec data;
|
||||||
|
char cmsgbuf[CMSG_SPACE(sizeof(int))];
|
||||||
|
struct cmsghdr* cmsg;
|
||||||
|
int *cmsg_data;
|
||||||
|
char dummy = '*';
|
||||||
|
|
||||||
|
data.iov_base = &dummy;
|
||||||
|
data.iov_len = sizeof(dummy);
|
||||||
|
|
||||||
|
hdr.msg_name = (struct sockaddr *)saddr;
|
||||||
|
hdr.msg_namelen = len;
|
||||||
|
hdr.msg_iov = &data;
|
||||||
|
hdr.msg_iovlen = 1;
|
||||||
|
hdr.msg_flags = 0;
|
||||||
|
|
||||||
|
hdr.msg_control = &cmsgbuf;
|
||||||
|
hdr.msg_controllen = CMSG_LEN(sizeof(int));
|
||||||
|
|
||||||
|
cmsg = CMSG_FIRSTHDR(&hdr);
|
||||||
|
cmsg->cmsg_len = hdr.msg_controllen;
|
||||||
|
cmsg->cmsg_level = SOL_SOCKET;
|
||||||
|
cmsg->cmsg_type = SCM_RIGHTS;
|
||||||
|
|
||||||
|
cmsg_data = (int *)CMSG_DATA(cmsg);
|
||||||
|
*cmsg_data = fd;
|
||||||
|
|
||||||
|
return sys_sendmsg(sock, &hdr, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int recv_fd(int sock)
|
||||||
|
{
|
||||||
|
struct msghdr msg;
|
||||||
|
struct iovec iov;
|
||||||
|
char buf[1];
|
||||||
|
char ccmsg[CMSG_SPACE(sizeof(int))];
|
||||||
|
struct cmsghdr *cmsg;
|
||||||
|
int *cmsg_data;
|
||||||
|
iov.iov_base = buf;
|
||||||
|
iov.iov_len = 1;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
msg.msg_name = 0;
|
||||||
|
msg.msg_namelen = 0;
|
||||||
|
msg.msg_iov = &iov;
|
||||||
|
msg.msg_iovlen = 1;
|
||||||
|
msg.msg_control = ccmsg;
|
||||||
|
msg.msg_controllen = sizeof(ccmsg);
|
||||||
|
|
||||||
|
ret = sys_recvmsg(sock, &msg, 0);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
cmsg = CMSG_FIRSTHDR(&msg);
|
||||||
|
if (!cmsg->cmsg_type == SCM_RIGHTS)
|
||||||
|
return -2;
|
||||||
|
|
||||||
|
cmsg_data = (int *)CMSG_DATA(cmsg);
|
||||||
|
return *cmsg_data;
|
||||||
|
}
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user