diff options
| author | David Quigley <dpquigl@tycho.nsa.gov> | 2006-06-23 05:04:01 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-23 10:42:54 -0400 |
| commit | 35601547baf92d984b6e59cf3583649da04baea5 (patch) | |
| tree | a392501e6e004ed33789dbf3f7a9fe43295439e1 /include/linux/security.h | |
| parent | 22fb52dd736a62e24c44c50739007496265dc38c (diff) | |
[PATCH] SELinux: add task_movememory hook
This patch adds new security hook, task_movememory, to be called when memory
owened by a task is to be moved (e.g. when migrating pages to a this hook is
identical to the setscheduler implementation, but a separate hook introduced
to allow this check to be specialized in the future if necessary.
Since the last posting, the hook has been renamed following feedback from
Christoph Lameter.
Signed-off-by: David Quigley <dpquigl@tycho.nsa.gov>
Acked-by: Stephen Smalley <sds@tycho.nsa.gov>
Signed-off-by: James Morris <jmorris@namei.org>
Cc: Christoph Lameter <clameter@sgi.com>
Cc: Andi Kleen <ak@muc.de>
Acked-by: Chris Wright <chrisw@sous-sol.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include/linux/security.h')
| -rw-r--r-- | include/linux/security.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/include/linux/security.h b/include/linux/security.h index 65b32a0c620..d2c17bd91a2 100644 --- a/include/linux/security.h +++ b/include/linux/security.h | |||
| @@ -601,6 +601,10 @@ struct swap_info_struct; | |||
| 601 | * @p. | 601 | * @p. |
| 602 | * @p contains the task_struct for process. | 602 | * @p contains the task_struct for process. |
| 603 | * Return 0 if permission is granted. | 603 | * Return 0 if permission is granted. |
| 604 | * @task_movememory | ||
| 605 | * Check permission before moving memory owned by process @p. | ||
| 606 | * @p contains the task_struct for process. | ||
| 607 | * Return 0 if permission is granted. | ||
| 604 | * @task_kill: | 608 | * @task_kill: |
| 605 | * Check permission before sending signal @sig to @p. @info can be NULL, | 609 | * Check permission before sending signal @sig to @p. @info can be NULL, |
| 606 | * the constant 1, or a pointer to a siginfo structure. If @info is 1 or | 610 | * the constant 1, or a pointer to a siginfo structure. If @info is 1 or |
| @@ -1220,6 +1224,7 @@ struct security_operations { | |||
| 1220 | int (*task_setscheduler) (struct task_struct * p, int policy, | 1224 | int (*task_setscheduler) (struct task_struct * p, int policy, |
| 1221 | struct sched_param * lp); | 1225 | struct sched_param * lp); |
| 1222 | int (*task_getscheduler) (struct task_struct * p); | 1226 | int (*task_getscheduler) (struct task_struct * p); |
| 1227 | int (*task_movememory) (struct task_struct * p); | ||
| 1223 | int (*task_kill) (struct task_struct * p, | 1228 | int (*task_kill) (struct task_struct * p, |
| 1224 | struct siginfo * info, int sig); | 1229 | struct siginfo * info, int sig); |
| 1225 | int (*task_wait) (struct task_struct * p); | 1230 | int (*task_wait) (struct task_struct * p); |
| @@ -1865,6 +1870,11 @@ static inline int security_task_getscheduler (struct task_struct *p) | |||
| 1865 | return security_ops->task_getscheduler (p); | 1870 | return security_ops->task_getscheduler (p); |
| 1866 | } | 1871 | } |
| 1867 | 1872 | ||
| 1873 | static inline int security_task_movememory (struct task_struct *p) | ||
| 1874 | { | ||
| 1875 | return security_ops->task_movememory (p); | ||
| 1876 | } | ||
| 1877 | |||
| 1868 | static inline int security_task_kill (struct task_struct *p, | 1878 | static inline int security_task_kill (struct task_struct *p, |
| 1869 | struct siginfo *info, int sig) | 1879 | struct siginfo *info, int sig) |
| 1870 | { | 1880 | { |
| @@ -2512,6 +2522,11 @@ static inline int security_task_getscheduler (struct task_struct *p) | |||
| 2512 | return 0; | 2522 | return 0; |
| 2513 | } | 2523 | } |
| 2514 | 2524 | ||
| 2525 | static inline int security_task_movememory (struct task_struct *p) | ||
| 2526 | { | ||
| 2527 | return 0; | ||
| 2528 | } | ||
| 2529 | |||
| 2515 | static inline int security_task_kill (struct task_struct *p, | 2530 | static inline int security_task_kill (struct task_struct *p, |
| 2516 | struct siginfo *info, int sig) | 2531 | struct siginfo *info, int sig) |
| 2517 | { | 2532 | { |
