Thread (53 messages) 53 messages, 9 authors, 2012-02-29

Re: [PATCH v11 10/12] ptrace,seccomp: Add PTRACE_SECCOMP support

From: Oleg Nesterov <oleg@redhat.com>
Date: 2012-02-29 16:23:27
Also in: lkml, netdev

On 02/28, Will Drewry wrote:
On Tue, Feb 28, 2012 at 11:04 AM, Will Drewry [off-list ref] wrote:
quoted
On Tue, Feb 28, 2012 at 10:43 AM, Oleg Nesterov [off-list ref] wrote:
quoted
Great. In this case this patch becomes really trivial. Just 2 defines
in ptrace.h and the unconditional ptrace_event() under SECCOMP_RET_TRACE.
hrm the only snag is that I can't then rely on TIF_SYSCALL_TRACE to
ensure seccomp is in the slow-path.  Right now, on x86, seccomp is
slow-path, but it doesn't have to be to have the syscall and args.
However, for ptrace to behavior properly, I believed it did need to be
in the slow path.  If SECCOMP_RET_TRACE doesn't rely on
PTRACE_SYSCALL, then it introduces a need for seccomp to always be in
the slow path or to flag (somehow) when it needs slow path.
My understanding of this magic is very limited, and I'm afraid
I misunderstood... So please correct me.

But what is the problem? system_call checks _TIF_WORK_SYSCALL_ENTRY
which includes _TIF_SECCOMP | _TIF_SYSCALL_TRACE, and jumps to
tracesys which does SAVE_REST.

Anyway. secure_computing() is called by syscall_trace_enter() which
also calls tracehook_report_syscall_entry(). If SECCOMP_RET_TRACE
can't do ptrace_event() then why tracehook_report_syscall_entry() is
fine?

Oleg.
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help