[CRIU] [PATCH 15/24] restore: add a function for constructing sigframe

Andrey Vagin avagin at openvz.org
Wed May 22 16:08:16 EDT 2013


Signed-off-by: Andrey Vagin <avagin at openvz.org>
---
 Makefile.crtools |  1 +
 sigframe.c       | 33 +++++++++++++++++++++++++++++++++
 2 files changed, 34 insertions(+)
 create mode 100644 sigframe.c

diff --git a/Makefile.crtools b/Makefile.crtools
index 9e648b5..9565232 100644
--- a/Makefile.crtools
+++ b/Makefile.crtools
@@ -47,6 +47,7 @@ obj-y	+= page-xfer.o
 obj-y	+= page-read.o
 obj-y	+= kerndat.o
 obj-y	+= stats.o
+obj-y	+= sigframe.o
 
 ifneq ($(MAKECMDGOALS),clean)
 incdeps := y
diff --git a/sigframe.c b/sigframe.c
new file mode 100644
index 0000000..b511bf1
--- /dev/null
+++ b/sigframe.c
@@ -0,0 +1,33 @@
+#include <unistd.h>
+
+#include "restorer.h"
+#include "asm/restore.h"
+#include "asm/restorer.h"
+
+#include "protobuf/core.pb-c.h"
+
+static inline int construct_sigframe(struct rt_sigframe *sigframe,
+				     struct rt_sigframe *rsigframe,
+				     CoreEntry *core)
+{
+	k_rtsigset_t *blk_sigset = &RT_SIGFRAME_UC(sigframe).uc_sigmask;
+
+	if (core->tc)
+		memcpy(blk_sigset, &core->tc->blk_sigset, sizeof(k_rtsigset_t));
+	else if (core->thread_core->has_blk_sigset) {
+		memcpy(blk_sigset,
+			&core->thread_core->blk_sigset, sizeof(k_rtsigset_t));
+	} else
+		memset(blk_sigset, 0, sizeof(k_rtsigset_t));
+
+	if (sigreturn_prep_fpu_frame(&sigframe->fpu_state, core))
+		return -1;
+
+	if (restore_fpu(sigframe, &rsigframe->fpu_state))
+		return -1;
+
+	if (restore_gpregs(sigframe, CORE_THREAD_ARCH_INFO(core)->gpregs))
+		return -1;
+
+	return 0;
+}
-- 
1.8.2



More information about the CRIU mailing list