summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/compat/hpux/hppa/hpux_sig.c53
-rw-r--r--sys/compat/hpux/hppa/syscalls.master6
2 files changed, 56 insertions, 3 deletions
diff --git a/sys/compat/hpux/hppa/hpux_sig.c b/sys/compat/hpux/hppa/hpux_sig.c
index 012bbd1c160..06462c709c0 100644
--- a/sys/compat/hpux/hppa/hpux_sig.c
+++ b/sys/compat/hpux/hppa/hpux_sig.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hpux_sig.c,v 1.1 2004/07/09 21:48:21 mickey Exp $ */
+/* $OpenBSD: hpux_sig.c,v 1.2 2004/07/11 00:20:46 mickey Exp $ */
/*
* Copyright (c) 2004 Michael Shalayeff. All rights reserved.
@@ -53,6 +53,7 @@
#include <compat/hpux/hpux.h>
#include <compat/hpux/hpux_sig.h>
+#include <compat/hpux/hpux_util.h>
#include <compat/hpux/hppa/hpux_syscallargs.h>
/* indexed by HPUX signal number - 1 */
@@ -412,3 +413,53 @@ hpux_sigsetreturn(struct proc *p, void *v, register_t *retval)
printf("hpux_sigsetreturn(%x)\n", SCARG(uap, cookie));
return (0);
}
+
+int
+hpux_sys_sigaltstack(struct proc *p, void *v, register_t *retval)
+{
+ struct hpux_sys_sigaltstack_args /* {
+ syscallarg(struct hpux_sigaltstack *) nss;
+ syscallarg(struct hpux_sigaltstack *) oss;
+ } */ *uap = v;
+ struct hpux_sigaltstack {
+ void *ss_sp;
+ int ss_flags;
+#define HPUX_SS_DISABLE 0x0002
+ size_t ss_size;
+ } hsa;
+ struct sys_sigaltstack_args saa;
+ struct sigaltstack *psa, sa;
+ caddr_t sg;
+ int error;
+
+ if ((error = copyin(SCARG(uap, nss), &hsa, sizeof hsa)))
+ return (error);
+
+ sa.ss_sp = hsa.ss_sp;
+ sa.ss_size = hsa.ss_size;
+ sa.ss_flags = hsa.ss_flags & SS_ONSTACK;
+ if (hsa.ss_flags & HPUX_SS_DISABLE)
+ sa.ss_flags |= SS_DISABLE;
+
+ sg = stackgap_init(p->p_emul);
+ psa = stackgap_alloc(&sg, 2 * sizeof(struct sigaltstack));
+ SCARG(&saa, nss) = &psa[0];
+ SCARG(&saa, oss) = &psa[1];
+
+ if ((error = copyout(&sa, psa, sizeof sa)))
+ return (error);
+
+ if ((error = sys_sigaltstack(p, &saa, retval)))
+ return (error);
+
+ if ((error = copyin(SCARG(&saa, oss), &sa, sizeof sa)))
+ return (error);
+
+ hsa.ss_sp = sa.ss_sp;
+ hsa.ss_flags = sa.ss_flags & SS_ONSTACK;
+ if (sa.ss_flags & SS_DISABLE)
+ hsa.ss_flags |= HPUX_SS_DISABLE;
+ hsa.ss_size = sa.ss_size;
+
+ return (copyout(&hsa, SCARG(uap, oss), sizeof hsa));
+}
diff --git a/sys/compat/hpux/hppa/syscalls.master b/sys/compat/hpux/hppa/syscalls.master
index 2aaf9245949..df7feecf4c8 100644
--- a/sys/compat/hpux/hppa/syscalls.master
+++ b/sys/compat/hpux/hppa/syscalls.master
@@ -1,4 +1,4 @@
- $OpenBSD: syscalls.master,v 1.2 2004/07/10 22:37:33 mickey Exp $
+ $OpenBSD: syscalls.master,v 1.3 2004/07/11 00:20:46 mickey Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
@@ -514,7 +514,9 @@
378 UNIMPL pwrite64
379 UNIMPL pwritev64
380 UNIMPL setcontext
-381 UNIMPL sigaltstack
+381 STD { int hpux_sys_sigaltstack( \
+ const struct hpux_sigaltstack *nss, \
+ struct hpux_sigaltstack *oss); }
382 UNIMPL waitid
383 UNIMPL setpgrp
384 UNIMPL recvmsg2