Thread (36 messages) 36 messages, 5 authors, 2014-06-27

[PATCH v7 4/9] seccomp: move no_new_privs into seccomp

From: luto@amacapital.net (Andy Lutomirski)
Date: 2014-06-24 19:21:23
Also in: linux-api, linux-arch, linux-mips, lkml

On Tue, Jun 24, 2014 at 12:18 PM, Oleg Nesterov [off-list ref] wrote:
On 06/23, Kees Cook wrote:
quoted
--- a/include/linux/seccomp.h
+++ b/include/linux/seccomp.h
@@ -3,6 +3,8 @@

 #include <uapi/linux/seccomp.h>

+#define SECCOMP_FLAG_NO_NEW_PRIVS    0       /* task may not gain privs */
+
 #ifdef CONFIG_SECCOMP

 #include <linux/thread_info.h>
@@ -16,6 +18,7 @@ struct seccomp_filter;
  *         system calls available to a process.
  * @filter: must always point to a valid seccomp-filter or NULL as it is
  *          accessed without locking during system call entry.
+ * @flags: flags under task->sighand->siglock lock
  *
  *          @filter must only be accessed from the context of current as there
  *          is no read locking.
@@ -23,6 +26,7 @@ struct seccomp_filter;
 struct seccomp {
      int mode;
      struct seccomp_filter *filter;
+     unsigned long flags;
 };

 extern int __secure_computing(int);
@@ -51,7 +55,9 @@ static inline int seccomp_mode(struct seccomp *s)

 #include <linux/errno.h>

-struct seccomp { };
+struct seccomp {
+     unsigned long flags;
+};
A bit messy ;)

I am wondering if we can simply do

        static inline bool current_no_new_privs(void)
        {
                if (current->no_new_privs)
                        return true;

        #ifdef CONFIG_SECCOMP
                if (test_thread_flag(TIF_SECCOMP))
                        return true;
        #endif
Nope -- privileged users can enable seccomp w/o nnp.

--Andy
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help