• Kees Cook's avatar
    exec: Check __FMODE_EXEC instead of in_execve for LSMs · 4759ff71
    Kees Cook authored
    After commit 978ffcbf ("execve: open the executable file before
    doing anything else"), current->in_execve was no longer in sync with the
    open(). This broke AppArmor and TOMOYO which depend on this flag to
    distinguish "open" operations from being "exec" operations.
    
    Instead of moving around in_execve, switch to using __FMODE_EXEC, which
    is where the "is this an exec?" intent is stored. Note that TOMOYO still
    uses in_execve around cred handling.
    Reported-by: default avatarKevin Locke <kevin@kevinlocke.name>
    Closes: https://lore.kernel.org/all/ZbE4qn9_h14OqADK@kevinlocke.nameSuggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
    Fixes: 978ffcbf ("execve: open the executable file before doing anything else")
    Cc: Josh Triplett <josh@joshtriplett.org>
    Cc: John Johansen <john.johansen@canonical.com>
    Cc: Paul Moore <paul@paul-moore.com>
    Cc: James Morris <jmorris@namei.org>
    Cc: Serge E. Hallyn <serge@hallyn.com>
    Cc: Kentaro Takeda <takedakn@nttdata.co.jp>
    Cc: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
    Cc: Alexander Viro <viro@zeniv.linux.org.uk>
    Cc: Christian Brauner <brauner@kernel.org>
    Cc: Jan Kara <jack@suse.cz>
    Cc: Eric Biederman <ebiederm@xmission.com>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
    Cc:  <linux-fsdevel@vger.kernel.org>
    Cc:  <linux-mm@kvack.org>
    Cc:  <apparmor@lists.ubuntu.com>
    Cc:  <linux-security-module@vger.kernel.org>
    Signed-off-by: default avatarKees Cook <keescook@chromium.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
    4759ff71
tomoyo.c 16.2 KB