[CRIU] [PATCH 6/6] sockets: Add checkpoint restore for file owners

Cyrill Gorcunov gorcunov at openvz.org
Mon Apr 9 16:03:06 EDT 2012


Signed-off-by: Cyrill Gorcunov <gorcunov at openvz.org>
---
 cr-show.c         |    2 +-
 include/crtools.h |    1 +
 include/image.h   |    2 ++
 sockets.c         |   31 ++++++++++++++++++++++---------
 4 files changed, 26 insertions(+), 10 deletions(-)

diff --git a/cr-show.c b/cr-show.c
index 72ff1e0..4b5c4c2 100644
--- a/cr-show.c
+++ b/cr-show.c
@@ -96,7 +96,7 @@ out:
 	pr_img_tail(CR_FD_FDINFO);
 }
 
-static void show_fown(fown_t *fown)
+void show_fown(fown_t *fown)
 {
 	if (fown->pid)
 		pr_msg("\tfown: uid: %x euid: %x signum: %x pid_type: %x pid: %x\n",
diff --git a/include/crtools.h b/include/crtools.h
index 55681c8..5b25009 100644
--- a/include/crtools.h
+++ b/include/crtools.h
@@ -90,6 +90,7 @@ void show_pstree(int fd_pstree, struct cr_options *o);
 void show_sigacts(int fd_sigacts, struct cr_options *o);
 void show_itimers(int fd, struct cr_options *o);
 void show_creds(int fd, struct cr_options *o);
+void show_fown(fown_t *fown);
 
 extern struct cr_fd_desc_tmpl fdset_template[CR_FD_MAX];
 
diff --git a/include/image.h b/include/image.h
index b03695b..8ed37a0 100644
--- a/include/image.h
+++ b/include/image.h
@@ -111,6 +111,7 @@ struct unix_sk_entry {
 	u8	pad;
 	u32	backlog;
 	u32	peer;
+	fown_t	fown;
 	u8	name[0];
 } __packed;
 
@@ -123,6 +124,7 @@ struct inet_sk_entry {
 	u16	src_port;
 	u16	dst_port;
 	u32	backlog;
+	fown_t	fown;
 	u32	src_addr[4];
 	u32	dst_addr[4];
 } __packed;
diff --git a/sockets.c b/sockets.c
index 65d45ff..71d2315 100644
--- a/sockets.c
+++ b/sockets.c
@@ -294,7 +294,7 @@ static int can_dump_inet_sk(const struct inet_sk_desc *sk)
 	return 1;
 }
 
-static int dump_one_inet(struct socket_desc *_sk, int fd,
+static int dump_one_inet(struct socket_desc *_sk, struct fd_parms *p,
 			 const struct cr_fdset *cr_fdset)
 {
 	struct inet_sk_desc *sk = (struct inet_sk_desc *)_sk;
@@ -304,7 +304,7 @@ static int dump_one_inet(struct socket_desc *_sk, int fd,
 	if (!can_dump_inet_sk(sk))
 		goto err;
 
-	fe.addr = fd;
+	fe.addr = p->fd_name;
 	fe.type = FDINFO_INETSK;
 	fe.id = sk->sd.ino;
 
@@ -324,13 +324,14 @@ static int dump_one_inet(struct socket_desc *_sk, int fd,
 	ie.src_port	= sk->src_port;
 	ie.dst_port	= sk->dst_port;
 	ie.backlog	= sk->wqlen;
+	ie.fown		= p->fown;
 	memcpy(ie.src_addr, sk->src_addr, sizeof(u32) * 4);
 	memcpy(ie.dst_addr, sk->dst_addr, sizeof(u32) * 4);
 
 	if (write_img(fdset_fd(glob_fdset, CR_FD_INETSK), &ie))
 		goto err;
 
-	pr_info("Dumping inet socket at %d\n", fd);
+	pr_info("Dumping inet socket at %d\n", (int)p->fd_name);
 	show_one_inet("Dumping", sk);
 	show_one_inet_img("Dumped", &ie);
 	sk->sd.already_dumped = 1;
@@ -365,8 +366,8 @@ static int can_dump_unix_sk(const struct unix_sk_desc *sk)
 	return 1;
 }
 
-static int dump_one_unix(const struct socket_desc *_sk, int fd, int lfd,
-			 const struct cr_fdset *cr_fdset)
+static int dump_one_unix(const struct socket_desc *_sk, struct fd_parms *p,
+			 int lfd, const struct cr_fdset *cr_fdset)
 {
 	struct unix_sk_desc *sk = (struct unix_sk_desc *)_sk;
 	struct fdinfo_entry fe;
@@ -375,7 +376,7 @@ static int dump_one_unix(const struct socket_desc *_sk, int fd, int lfd,
 	if (!can_dump_unix_sk(sk))
 		goto err;
 
-	fe.addr = fd;
+	fe.addr = p->fd_name;
 	fe.type = FDINFO_UNIXSK;
 	fe.id = sk->sd.ino;
 
@@ -391,6 +392,7 @@ static int dump_one_unix(const struct socket_desc *_sk, int fd, int lfd,
 	ue.namelen	= sk->namelen;
 	ue.backlog	= sk->wqlen;
 	ue.peer		= sk->peer_ino;
+	ue.fown		= p->fown;
 
 	if (ue.peer) {
 		struct unix_sk_desc *peer;
@@ -452,7 +454,7 @@ static int dump_one_unix(const struct socket_desc *_sk, int fd, int lfd,
 		if (dump_socket_queue(lfd, ue.id))
 			goto err;
 
-	pr_info("Dumping unix socket at %d\n", fd);
+	pr_info("Dumping unix socket at %d\n", (int)p->fd_name);
 	show_one_unix("Dumping", sk);
 	show_one_unix_img("Dumped", &ue);
 
@@ -475,9 +477,9 @@ int dump_socket(struct fd_parms *p, int lfd, const struct cr_fdset *cr_fdset)
 
 	switch (sk->family) {
 	case AF_UNIX:
-		return dump_one_unix(sk, p->fd_name, lfd, cr_fdset);
+		return dump_one_unix(sk, p, lfd, cr_fdset);
 	case AF_INET:
-		return dump_one_inet(sk, p->fd_name, cr_fdset);
+		return dump_one_inet(sk, p, cr_fdset);
 	default:
 		pr_err("BUG! Unknown socket collected\n");
 		break;
@@ -953,6 +955,9 @@ static int open_inet_sk(struct file_desc *d)
 		return -1;
 	}
 
+	if (restore_fown(getpid(), sk, &ii->ie.fown))
+		goto err;
+
 	/*
 	 * Listen sockets are easiest ones -- simply
 	 * bind() and listen(), and that's all.
@@ -1080,6 +1085,7 @@ void show_inetsk(int fd, struct cr_options *o)
 		pr_msg("id %x family %s type %s proto %s state %s %s:%d <-> %s:%d\n",
 			ie.id, skfamily2s(ie.family), sktype2s(ie.type), skproto2s(ie.proto),
 			skstate2s(ie.state), src_addr, ie.src_port, dst_addr, ie.dst_port);
+		show_fown(&ie.fown);
 	}
 
 out:
@@ -1116,6 +1122,7 @@ void show_unixsk(int fd, struct cr_options *o)
 			pr_msg(" --> %s\n", buf);
 		} else
 			pr_msg("\n");
+		show_fown(&ue.fown);
 	}
 out:
 	pr_img_tail(CR_FD_UNIXSK);
@@ -1262,6 +1269,9 @@ static int open_unixsk_pair_master(struct unix_sk_info *ui)
 		return -1;
 	}
 
+	if (restore_fown(getpid(), sk[0], &ui->ue.fown))
+		return -1;
+
 	if (restore_socket_queue(sk[0], peer->ue.id))
 		return -1;
 	if (restore_socket_queue(sk[1], ui->ue.id))
@@ -1324,6 +1334,9 @@ static int open_unixsk_standalone(struct unix_sk_info *ui)
 		return -1;
 	}
 
+	if (restore_fown(getpid(), sk, &ui->ue.fown))
+		return -1;
+
 	if (bind_unix_sk(sk, ui))
 		return -1;
 
-- 
1.7.7.6



More information about the CRIU mailing list