diff options
Diffstat (limited to 'fs/exec.c')
-rw-r--r-- | fs/exec.c | 19 |
1 files changed, 14 insertions, 5 deletions
@@ -33,6 +33,7 @@ | |||
33 | #include <linux/string.h> | 33 | #include <linux/string.h> |
34 | #include <linux/init.h> | 34 | #include <linux/init.h> |
35 | #include <linux/pagemap.h> | 35 | #include <linux/pagemap.h> |
36 | #include <linux/perf_counter.h> | ||
36 | #include <linux/highmem.h> | 37 | #include <linux/highmem.h> |
37 | #include <linux/spinlock.h> | 38 | #include <linux/spinlock.h> |
38 | #include <linux/key.h> | 39 | #include <linux/key.h> |
@@ -922,6 +923,7 @@ void set_task_comm(struct task_struct *tsk, char *buf) | |||
922 | task_lock(tsk); | 923 | task_lock(tsk); |
923 | strlcpy(tsk->comm, buf, sizeof(tsk->comm)); | 924 | strlcpy(tsk->comm, buf, sizeof(tsk->comm)); |
924 | task_unlock(tsk); | 925 | task_unlock(tsk); |
926 | perf_counter_comm(tsk); | ||
925 | } | 927 | } |
926 | 928 | ||
927 | int flush_old_exec(struct linux_binprm * bprm) | 929 | int flush_old_exec(struct linux_binprm * bprm) |
@@ -990,6 +992,13 @@ int flush_old_exec(struct linux_binprm * bprm) | |||
990 | 992 | ||
991 | current->personality &= ~bprm->per_clear; | 993 | current->personality &= ~bprm->per_clear; |
992 | 994 | ||
995 | /* | ||
996 | * Flush performance counters when crossing a | ||
997 | * security domain: | ||
998 | */ | ||
999 | if (!get_dumpable(current->mm)) | ||
1000 | perf_counter_exit_task(current); | ||
1001 | |||
993 | /* An exec changes our domain. We are no longer part of the thread | 1002 | /* An exec changes our domain. We are no longer part of the thread |
994 | group */ | 1003 | group */ |
995 | 1004 | ||
@@ -1016,7 +1025,7 @@ void install_exec_creds(struct linux_binprm *bprm) | |||
1016 | commit_creds(bprm->cred); | 1025 | commit_creds(bprm->cred); |
1017 | bprm->cred = NULL; | 1026 | bprm->cred = NULL; |
1018 | 1027 | ||
1019 | /* cred_exec_mutex must be held at least to this point to prevent | 1028 | /* cred_guard_mutex must be held at least to this point to prevent |
1020 | * ptrace_attach() from altering our determination of the task's | 1029 | * ptrace_attach() from altering our determination of the task's |
1021 | * credentials; any time after this it may be unlocked */ | 1030 | * credentials; any time after this it may be unlocked */ |
1022 | 1031 | ||
@@ -1026,7 +1035,7 @@ EXPORT_SYMBOL(install_exec_creds); | |||
1026 | 1035 | ||
1027 | /* | 1036 | /* |
1028 | * determine how safe it is to execute the proposed program | 1037 | * determine how safe it is to execute the proposed program |
1029 | * - the caller must hold current->cred_exec_mutex to protect against | 1038 | * - the caller must hold current->cred_guard_mutex to protect against |
1030 | * PTRACE_ATTACH | 1039 | * PTRACE_ATTACH |
1031 | */ | 1040 | */ |
1032 | int check_unsafe_exec(struct linux_binprm *bprm) | 1041 | int check_unsafe_exec(struct linux_binprm *bprm) |
@@ -1268,7 +1277,7 @@ int do_execve(char * filename, | |||
1268 | if (!bprm) | 1277 | if (!bprm) |
1269 | goto out_files; | 1278 | goto out_files; |
1270 | 1279 | ||
1271 | retval = mutex_lock_interruptible(¤t->cred_exec_mutex); | 1280 | retval = mutex_lock_interruptible(¤t->cred_guard_mutex); |
1272 | if (retval < 0) | 1281 | if (retval < 0) |
1273 | goto out_free; | 1282 | goto out_free; |
1274 | current->in_execve = 1; | 1283 | current->in_execve = 1; |
@@ -1331,7 +1340,7 @@ int do_execve(char * filename, | |||
1331 | /* execve succeeded */ | 1340 | /* execve succeeded */ |
1332 | current->fs->in_exec = 0; | 1341 | current->fs->in_exec = 0; |
1333 | current->in_execve = 0; | 1342 | current->in_execve = 0; |
1334 | mutex_unlock(¤t->cred_exec_mutex); | 1343 | mutex_unlock(¤t->cred_guard_mutex); |
1335 | acct_update_integrals(current); | 1344 | acct_update_integrals(current); |
1336 | free_bprm(bprm); | 1345 | free_bprm(bprm); |
1337 | if (displaced) | 1346 | if (displaced) |
@@ -1354,7 +1363,7 @@ out_unmark: | |||
1354 | 1363 | ||
1355 | out_unlock: | 1364 | out_unlock: |
1356 | current->in_execve = 0; | 1365 | current->in_execve = 0; |
1357 | mutex_unlock(¤t->cred_exec_mutex); | 1366 | mutex_unlock(¤t->cred_guard_mutex); |
1358 | 1367 | ||
1359 | out_free: | 1368 | out_free: |
1360 | free_bprm(bprm); | 1369 | free_bprm(bprm); |