1. 28 3月, 2016 1 次提交
  2. 12 5月, 2015 3 次提交
  3. 12 4月, 2015 1 次提交
  4. 18 3月, 2013 2 次提交
  5. 12 10月, 2012 1 次提交
  6. 21 9月, 2012 1 次提交
  7. 10 4月, 2012 1 次提交
  8. 07 1月, 2012 1 次提交
  9. 04 1月, 2012 3 次提交
  10. 14 9月, 2011 1 次提交
  11. 14 7月, 2011 1 次提交
  12. 11 7月, 2011 1 次提交
  13. 30 6月, 2011 1 次提交
  14. 29 6月, 2011 1 次提交
    • T
      TOMOYO: Cleanup part 1. · 7c75964f
      Tetsuo Handa 提交于
      In order to synchronize with TOMOYO 1.8's syntax,
      
      (1) Remove special handling for allow_read/write permission.
      (2) Replace deny_rewrite/allow_rewrite permission with allow_append permission.
      (3) Remove file_pattern keyword.
      (4) Remove allow_read permission from exception policy.
      (5) Allow creating domains in enforcing mode without calling supervisor.
      (6) Add permission check for opening directory for reading.
      (7) Add permission check for stat() operation.
      (8) Make "cat < /sys/kernel/security/tomoyo/self_domain" behave as if
          "cat /sys/kernel/security/tomoyo/self_domain".
      Signed-off-by: NTetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
      Signed-off-by: NJames Morris <jmorris@namei.org>
      7c75964f
  15. 02 8月, 2010 6 次提交
  16. 16 2月, 2010 2 次提交
  17. 15 2月, 2010 2 次提交
  18. 14 1月, 2010 1 次提交
    • A
      Fix ACC_MODE() for real · 6d125529
      Al Viro 提交于
      commit 5300990c had stepped on a rather
      nasty mess: definitions of ACC_MODE used to be different.  Fixed the
      resulting breakage, converting them to variant that takes O_... value;
      all callers have that and it actually simplifies life (see tomoyo part
      of changes).
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      6d125529
  19. 15 12月, 2009 1 次提交
  20. 08 12月, 2009 1 次提交
  21. 21 11月, 2009 1 次提交
  22. 12 11月, 2009 1 次提交
  23. 02 9月, 2009 1 次提交
    • D
      KEYS: Add a keyctl to install a process's session keyring on its parent [try #6] · ee18d64c
      David Howells 提交于
      Add a keyctl to install a process's session keyring onto its parent.  This
      replaces the parent's session keyring.  Because the COW credential code does
      not permit one process to change another process's credentials directly, the
      change is deferred until userspace next starts executing again.  Normally this
      will be after a wait*() syscall.
      
      To support this, three new security hooks have been provided:
      cred_alloc_blank() to allocate unset security creds, cred_transfer() to fill in
      the blank security creds and key_session_to_parent() - which asks the LSM if
      the process may replace its parent's session keyring.
      
      The replacement may only happen if the process has the same ownership details
      as its parent, and the process has LINK permission on the session keyring, and
      the session keyring is owned by the process, and the LSM permits it.
      
      Note that this requires alteration to each architecture's notify_resume path.
      This has been done for all arches barring blackfin, m68k* and xtensa, all of
      which need assembly alteration to support TIF_NOTIFY_RESUME.  This allows the
      replacement to be performed at the point the parent process resumes userspace
      execution.
      
      This allows the userspace AFS pioctl emulation to fully emulate newpag() and
      the VIOCSETTOK and VIOCSETTOK2 pioctls, all of which require the ability to
      alter the parent process's PAG membership.  However, since kAFS doesn't use
      PAGs per se, but rather dumps the keys into the session keyring, the session
      keyring of the parent must be replaced if, for example, VIOCSETTOK is passed
      the newpag flag.
      
      This can be tested with the following program:
      
      	#include <stdio.h>
      	#include <stdlib.h>
      	#include <keyutils.h>
      
      	#define KEYCTL_SESSION_TO_PARENT	18
      
      	#define OSERROR(X, S) do { if ((long)(X) == -1) { perror(S); exit(1); } } while(0)
      
      	int main(int argc, char **argv)
      	{
      		key_serial_t keyring, key;
      		long ret;
      
      		keyring = keyctl_join_session_keyring(argv[1]);
      		OSERROR(keyring, "keyctl_join_session_keyring");
      
      		key = add_key("user", "a", "b", 1, keyring);
      		OSERROR(key, "add_key");
      
      		ret = keyctl(KEYCTL_SESSION_TO_PARENT);
      		OSERROR(ret, "KEYCTL_SESSION_TO_PARENT");
      
      		return 0;
      	}
      
      Compiled and linked with -lkeyutils, you should see something like:
      
      	[dhowells@andromeda ~]$ keyctl show
      	Session Keyring
      	       -3 --alswrv   4043  4043  keyring: _ses
      	355907932 --alswrv   4043    -1   \_ keyring: _uid.4043
      	[dhowells@andromeda ~]$ /tmp/newpag
      	[dhowells@andromeda ~]$ keyctl show
      	Session Keyring
      	       -3 --alswrv   4043  4043  keyring: _ses
      	1055658746 --alswrv   4043  4043   \_ user: a
      	[dhowells@andromeda ~]$ /tmp/newpag hello
      	[dhowells@andromeda ~]$ keyctl show
      	Session Keyring
      	       -3 --alswrv   4043  4043  keyring: hello
      	340417692 --alswrv   4043  4043   \_ user: a
      
      Where the test program creates a new session keyring, sticks a user key named
      'a' into it and then installs it on its parent.
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      Signed-off-by: NJames Morris <jmorris@namei.org>
      ee18d64c
  24. 19 6月, 2009 1 次提交
  25. 09 6月, 2009 1 次提交
  26. 27 5月, 2009 1 次提交
  27. 14 4月, 2009 1 次提交
  28. 23 2月, 2009 1 次提交