Commit 45233b5e authored by Andrey Vagin's avatar Andrey Vagin Committed by Pavel Emelyanov

restore: add a function for constructing sigframe

Signed-off-by: 's avatarAndrey Vagin <avagin@openvz.org>
Signed-off-by: 's avatarPavel Emelyanov <xemul@parallels.com>
parent 478bd99b
......@@ -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
obj-y += arch/$(ARCH)/vdso.o
ifneq ($(MAKECMDGOALS),clean)
......
#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;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment