Author: dchagin
Date: Tue Apr 30 17:18:05 2019
New Revision: 346965
URL: https://svnweb.freebsd.org/changeset/base/346965

Log:
  Follow the FreeBSD and implement PDEATH_SIG prctl ops in the Linuxulator.
  It was first introduced in r163734 and missied by me in r283383.
  
  MFC after:    1 week

Modified:
  head/sys/compat/linux/linux_emul.c
  head/sys/compat/linux/linux_emul.h
  head/sys/compat/linux/linux_misc.c

Modified: head/sys/compat/linux/linux_emul.c
==============================================================================
--- head/sys/compat/linux/linux_emul.c  Tue Apr 30 16:52:50 2019        
(r346964)
+++ head/sys/compat/linux/linux_emul.c  Tue Apr 30 17:18:05 2019        
(r346965)
@@ -127,7 +127,6 @@ linux_proc_init(struct thread *td, struct thread *newt
 
                em->em_tid = p->p_pid;
                em->flags = 0;
-               em->pdeath_signal = 0;
                em->robust_futexes = NULL;
                em->child_clear_tid = NULL;
                em->child_set_tid = NULL;

Modified: head/sys/compat/linux/linux_emul.h
==============================================================================
--- head/sys/compat/linux/linux_emul.h  Tue Apr 30 16:52:50 2019        
(r346964)
+++ head/sys/compat/linux/linux_emul.h  Tue Apr 30 17:18:05 2019        
(r346965)
@@ -40,7 +40,6 @@ struct linux_emuldata {
        int    *child_set_tid;  /* in clone(): Child's TID to set on clone */
        int    *child_clear_tid;/* in clone(): Child's TID to clear on exit */
 
-       int     pdeath_signal;          /* parent death signal */
        int     flags;                  /* thread emuldata flags */
        int     em_tid;                 /* thread id */
 

Modified: head/sys/compat/linux/linux_misc.c
==============================================================================
--- head/sys/compat/linux/linux_misc.c  Tue Apr 30 16:52:50 2019        
(r346964)
+++ head/sys/compat/linux/linux_misc.c  Tue Apr 30 17:18:05 2019        
(r346965)
@@ -51,6 +51,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/namei.h>
 #include <sys/priv.h>
 #include <sys/proc.h>
+#include <sys/procctl.h>
 #include <sys/reboot.h>
 #include <sys/racct.h>
 #include <sys/random.h>
@@ -1993,7 +1994,6 @@ linux_prctl(struct thread *td, struct linux_prctl_args
        int error = 0, max_size;
        struct proc *p = td->td_proc;
        char comm[LINUX_MAX_COMM_LEN];
-       struct linux_emuldata *em;
        int pdeath_signal;
 
 #ifdef DEBUG
@@ -2007,17 +2007,18 @@ linux_prctl(struct thread *td, struct linux_prctl_args
        case LINUX_PR_SET_PDEATHSIG:
                if (!LINUX_SIG_VALID(args->arg2))
                        return (EINVAL);
-               em = em_find(td);
-               KASSERT(em != NULL, ("prctl: emuldata not found.\n"));
-               em->pdeath_signal = args->arg2;
-               break;
+               pdeath_signal = linux_to_bsd_signal(args->arg2);
+               return (kern_procctl(td, P_PID, 0, PROC_PDEATHSIG_CTL,
+                   &pdeath_signal));
        case LINUX_PR_GET_PDEATHSIG:
-               em = em_find(td);
-               KASSERT(em != NULL, ("prctl: emuldata not found.\n"));
-               pdeath_signal = em->pdeath_signal;
-               error = copyout(&pdeath_signal,
+               error = kern_procctl(td, P_PID, 0, PROC_PDEATHSIG_STATUS,
+                   &pdeath_signal);
+               if (error != 0)
+                       return (error);
+               pdeath_signal = bsd_to_linux_signal(pdeath_signal);
+               return (copyout(&pdeath_signal,
                    (void *)(register_t)args->arg2,
-                   sizeof(pdeath_signal));
+                   sizeof(pdeath_signal)));
                break;
        case LINUX_PR_GET_KEEPCAPS:
                /*
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to