diff options
Diffstat (limited to 'fs/exec.c')
-rw-r--r-- | fs/exec.c | 7 |
1 files changed, 4 insertions, 3 deletions
@@ -1371,7 +1371,7 @@ int search_binary_handler(struct linux_binprm *bprm,struct pt_regs *regs) | |||
1371 | unsigned int depth = bprm->recursion_depth; | 1371 | unsigned int depth = bprm->recursion_depth; |
1372 | int try,retval; | 1372 | int try,retval; |
1373 | struct linux_binfmt *fmt; | 1373 | struct linux_binfmt *fmt; |
1374 | pid_t old_pid; | 1374 | pid_t old_pid, old_vpid; |
1375 | 1375 | ||
1376 | retval = security_bprm_check(bprm); | 1376 | retval = security_bprm_check(bprm); |
1377 | if (retval) | 1377 | if (retval) |
@@ -1382,8 +1382,9 @@ int search_binary_handler(struct linux_binprm *bprm,struct pt_regs *regs) | |||
1382 | return retval; | 1382 | return retval; |
1383 | 1383 | ||
1384 | /* Need to fetch pid before load_binary changes it */ | 1384 | /* Need to fetch pid before load_binary changes it */ |
1385 | old_pid = current->pid; | ||
1385 | rcu_read_lock(); | 1386 | rcu_read_lock(); |
1386 | old_pid = task_pid_nr_ns(current, task_active_pid_ns(current->parent)); | 1387 | old_vpid = task_pid_nr_ns(current, task_active_pid_ns(current->parent)); |
1387 | rcu_read_unlock(); | 1388 | rcu_read_unlock(); |
1388 | 1389 | ||
1389 | retval = -ENOENT; | 1390 | retval = -ENOENT; |
@@ -1406,7 +1407,7 @@ int search_binary_handler(struct linux_binprm *bprm,struct pt_regs *regs) | |||
1406 | if (retval >= 0) { | 1407 | if (retval >= 0) { |
1407 | if (depth == 0) { | 1408 | if (depth == 0) { |
1408 | trace_sched_process_exec(current, old_pid, bprm); | 1409 | trace_sched_process_exec(current, old_pid, bprm); |
1409 | ptrace_event(PTRACE_EVENT_EXEC, old_pid); | 1410 | ptrace_event(PTRACE_EVENT_EXEC, old_vpid); |
1410 | } | 1411 | } |
1411 | put_binfmt(fmt); | 1412 | put_binfmt(fmt); |
1412 | allow_write_access(bprm->file); | 1413 | allow_write_access(bprm->file); |