diff --git a/Kernel/Process.cpp b/Kernel/Process.cpp index 4a130e34204..c80b36cd392 100644 --- a/Kernel/Process.cpp +++ b/Kernel/Process.cpp @@ -1601,10 +1601,8 @@ int Process::sys$sigaction(int signum, const sigaction* act, sigaction* old_act) if (!validate_write_typed(old_act)) return -EFAULT; old_act->sa_flags = action.flags; - old_act->sa_restorer = (decltype(old_act->sa_restorer))action.restorer.get(); old_act->sa_sigaction = (decltype(old_act->sa_sigaction))action.handler_or_sigaction.get(); } - action.restorer = LinearAddress((dword)act->sa_restorer); action.flags = act->sa_flags; action.handler_or_sigaction = LinearAddress((dword)act->sa_sigaction); return 0; diff --git a/Kernel/Thread.h b/Kernel/Thread.h index f974c916192..641f1443d57 100644 --- a/Kernel/Thread.h +++ b/Kernel/Thread.h @@ -21,7 +21,6 @@ struct SignalActionData { LinearAddress handler_or_sigaction; dword mask { 0 }; int flags { 0 }; - LinearAddress restorer; }; class Thread : public InlineLinkedListNode { diff --git a/Kernel/UnixTypes.h b/Kernel/UnixTypes.h index a941f6c3406..4261f8ad611 100644 --- a/Kernel/UnixTypes.h +++ b/Kernel/UnixTypes.h @@ -246,7 +246,6 @@ struct sigaction { }; sigset_t sa_mask; int sa_flags; - void (*sa_restorer)(void); }; #define SA_NOCLDSTOP 1 diff --git a/LibC/signal.cpp b/LibC/signal.cpp index ec2d8c2767f..859d0d054be 100644 --- a/LibC/signal.cpp +++ b/LibC/signal.cpp @@ -33,7 +33,6 @@ sighandler_t signal(int signum, sighandler_t handler) new_act.sa_handler = handler; new_act.sa_flags = 0; new_act.sa_mask = 0; - new_act.sa_restorer = nullptr; int rc = sigaction(signum, &new_act, &old_act); if (rc < 0) return SIG_ERR; diff --git a/LibC/signal.h b/LibC/signal.h index e854b7ed0bf..2bd8a888df1 100644 --- a/LibC/signal.h +++ b/LibC/signal.h @@ -19,7 +19,6 @@ struct sigaction { }; sigset_t sa_mask; int sa_flags; - void (*sa_restorer)(void); }; int kill(pid_t, int sig); diff --git a/Userland/sh.cpp b/Userland/sh.cpp index e4f926cb00f..f210f64013e 100644 --- a/Userland/sh.cpp +++ b/Userland/sh.cpp @@ -232,7 +232,6 @@ int main(int argc, char** argv) sa.sa_handler = handle_sigint; sa.sa_flags = 0; sa.sa_mask = 0; - sa.sa_restorer = nullptr; int rc = sigaction(SIGINT, &sa, nullptr); assert(rc == 0); }