summaryrefslogtreecommitdiff
path: root/src/sys/include
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2025-09-27 13:16:10 -0400
committerIan Moffett <ian@osmora.org>2025-09-27 13:16:10 -0400
commit6bcb672277090e0da850f514a8c557d6bd395537 (patch)
tree1cbff76f29c6d26406472cb7f300ed2ca05acb44 /src/sys/include
parent41f5792098c8f2764441eca195a24918b4ae390f (diff)
kern: Add initial signals work
Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'src/sys/include')
-rw-r--r--src/sys/include/os/signal.h55
-rw-r--r--src/sys/include/sys/proc.h4
-rw-r--r--src/sys/include/sys/signal.h54
-rw-r--r--src/sys/include/sys/syscall.h9
4 files changed, 118 insertions, 4 deletions
diff --git a/src/sys/include/os/signal.h b/src/sys/include/os/signal.h
new file mode 100644
index 0000000..b77a51f
--- /dev/null
+++ b/src/sys/include/os/signal.h
@@ -0,0 +1,55 @@
+/*
+ * Copyright (c) 2025 Ian Marco Moffett and L5 engineers
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the project nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _OS_SIGNAL_H_
+#define _OS_SIGNAL_H_
+
+#include <sys/types.h>
+#include <sys/proc.h>
+#include <sys/signal.h>
+
+typedef struct sigaction sigtab_t[32];
+
+/*
+ * Initialize the signals framework
+ */
+int signal_init(struct proc *procp);
+
+/* Default handlers */
+void sigfpe_default(int signo);
+void sigkill_default(int signo);
+void sigsegv_default(int signo);
+void sigterm_default(int signo);
+
+/*
+ * POSIX sigaction system call
+ */
+scret_t sys_sigaction(struct syscall_args *scargs);
+
+#endif /* !_OS_SIGNAL_H_ */
diff --git a/src/sys/include/sys/proc.h b/src/sys/include/sys/proc.h
index c5b0fda..c268693 100644
--- a/src/sys/include/sys/proc.h
+++ b/src/sys/include/sys/proc.h
@@ -36,6 +36,7 @@
#include <sys/param.h>
#include <sys/queue.h>
#include <os/mac.h>
+#include <os/signal.h>
#include <os/spinlock.h>
#include <os/filedesc.h>
#include <vm/vm.h>
@@ -57,6 +58,8 @@
* @pcb: Process control block
* @scdom: Syscall domain
* @level: Access level
+ * @maplist_lock: Protects the maplist
+ * @sigtab: Signal table
* @maplist: List of mapped regions
* @link: TAILQ link
*/
@@ -68,6 +71,7 @@ struct proc {
struct filedesc *fdtab[FD_MAX];
mac_level_t level;
struct spinlock maplist_lock;
+ sigtab_t sigtab;
TAILQ_HEAD(, vm_range) maplist;
TAILQ_ENTRY(proc) link;
};
diff --git a/src/sys/include/sys/signal.h b/src/sys/include/sys/signal.h
new file mode 100644
index 0000000..85d0dbb
--- /dev/null
+++ b/src/sys/include/sys/signal.h
@@ -0,0 +1,54 @@
+/*
+ * Copyright (c) 2025 Ian Marco Moffett and L5 engineers
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the project nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _SIGNAL_H_
+#define _SIGNAL_H_
+
+#include <sys/types.h>
+
+#define SIGFPE 8 /* Floating point exception */
+#define SIGKILL 9 /* Kill */
+#define SIGSEGV 11 /* Segmentation violation */
+#define SIGTERM 15 /* Terminate gracefully */
+
+typedef __uint32_t sigset_t;
+
+/*
+ * POSIX sigaction
+ *
+ * Represents the action associated with
+ * a specific signal
+ */
+struct sigaction {
+ void(*sa_handler)(int);
+ sigset_t sa_mask;
+ int sa_flags;
+};
+
+#endif /* _SIGNAL_H_ */
diff --git a/src/sys/include/sys/syscall.h b/src/sys/include/sys/syscall.h
index 3f8ab10..5ec48c3 100644
--- a/src/sys/include/sys/syscall.h
+++ b/src/sys/include/sys/syscall.h
@@ -42,10 +42,11 @@
* Defines marked as (mandatory) must be implemented
* between latches.
*/
-#define SYS_none 0x00
-#define SYS_exit 0x01
-#define SYS_write 0x02
-#define SYS_cross 0x03 /* cross a border (mandatory) */
+#define SYS_none 0x00
+#define SYS_exit 0x01
+#define SYS_write 0x02
+#define SYS_cross 0x03 /* cross a border (mandatory) */
+#define SYS_sigaction 0x04
typedef __ssize_t scret_t;
typedef __ssize_t scarg_t;