On Thu, May 29, 2014 at 9:25 AM, Steve Grubb <sgrubb(a)redhat.com> wrote:
On Thursday, May 29, 2014 09:04:10 AM Andy Lutomirski wrote:
> On Thu, May 29, 2014 at 6:05 AM, Steve Grubb <sgrubb(a)redhat.com> wrote:
> > On Wednesday, May 28, 2014 07:40:57 PM Andy Lutomirski wrote:
> >> >> - It assumes that syscall numbers are between 0 and 2048.
> >> >>
> >> > There could well be a bug here. Not questioning that. Although that
> >> > would be patch 1/2
> >>
> >> Even with patch 1, it still doesn't handle large syscall numbers -- it
> >> just assumes they're not audited.
> >
> > All syscalls must be auditable. Meaning that if an arch goes above 2048,
> > then we'll need to do some math to get it to fall back within the range.
>
> Off the top of my head, x32, some ARM variants, and some MIPS variants
> have syscalls above 2048.
That could be fixed by putting a subtraction in place to get the bit mask to
map correctly. User space audit rules would need to fix that also.
> auditsc has been disabled on the offending
> ARM variant (because I noticed that the same issue affects seccomp,
> and no one particularly wants to fix it), but I suspect that auditsc
> is enabled but completely broken on whichever MIPS ABI has the issue.
> I haven't checked.
>
> TBH, I think that it's silly to let the auditsc design be heavily
> constrained by ia64 considerations -- I still think that the syscall
> entry hooks could be removed completely with some effort on most
> architectures and that performance would improve considerably. For
> users who don't have syscall filter rules, performance might even
> improve on ia64 -- I don't care how expensive syscall_get_args is, the
> actual printk/auditd thing will dominate in cases where anything is
> written.
The last time I heard of benchmarking being done, audit's performance hit was
negligible. That was about 4 years ago and there has been a whole lot of code
churn since then. But it should in general be the cost of an 'if' statement
unless auditing is enabled. If it is enabled, then you necessarily get the
full treatment in case you trigger an event.
The actual rule matching is reasonably inexpensive, but the killer is
the fact that every system call is forced into the slow path. Without
audit, this cost is paid by seccomp users and tasks that are being
ptraced. With audit, every single syscall for every single task pays
the full cost of a slow path system call.
This is extra sad because, AFAICS, most of the syscall entry audit
code shouldn't be necessary even for audit users.
> For users who aren't bound by Common Criteria or related
things, I
> suspect that syscall auditing (as opposed to, say, LSM-based auditing)
> will provide dubious value at best.
No, it works pretty good. You can see who is accessing what files pretty
clearly.
Right, but I don't think it's the *syscall* part that's really
necessary here. The fact that someone opened /etc/passwd is
interesting. The fact that someone sys_opened (const char *)0x123456
is not.
> Keep in mind that many syscalls take pointer arguments, and the auditsc code
> can't really do anything sensible with them.
All security relevant information is collected in auxiliary records if they
are not directly readable as a syscall argument. This is a basic requirement.
We are not required to capture all possible arguments. If you know of any
security relevant parameters not captured, please let us know.
a5 and a6. The cmsg data in sendmsg (which is very security-relevant
-- think of SCM_RIGHTS and SCM_CREDENTIALS). The destination for
sendto. The whole payload of netlink messages. I don't know how many
of these are actually captures.
Plus, except for things like setuid and sigreturn, capturing
parameters on entry shouldn't be needed anyway. Capturing at log time
should be fine.
If this magic capturing only happened for users who need it for
compliance reasons, that would be one thing. But it happens for every
single system call on Fedora.
--Andy