public inbox for linux-audit@redhat.com
 help / color / mirror / Atom feed
From: Jiri Pirko <jpirko@redhat.com>
To: Eric Paris <eparis@redhat.com>
Cc: linux-kernel@vger.kernel.org, linux-audit@redhat.com,
	viro@zeniv.linux.org.uk,
	Andrew Morton <akpm@linux-foundation.org>
Subject: Re: audit: EXECVE record - removed bogus newline
Date: Fri, 9 Jan 2009 13:21:30 +0100	[thread overview]
Message-ID: <20090109132130.0bc87c02@psychotron.englab.brq.redhat.com> (raw)
In-Reply-To: <1231428798.31089.80.camel@localhost.localdomain>

On Thu, 08 Jan 2009 10:33:18 -0500
Eric Paris <eparis@redhat.com> wrote:

> On Thu, 2009-01-08 at 15:38 +0100, Jiri Pirko wrote:
> > EXECVE records contain a newline after every argument. auditd converts
> > "\n" to " " so you cannot see newlines even in raw logs, but they're
> > there nevertheless. If you're not using auditd, you need to work round
> > them. These '\n' chars are can be easily replaced by spaces when
> > creating record in kernel. Note there is no need for trailing '\n' in
> > an audit record. 
> 
> While I completely agree the \n was my mistake and should be
> dropped/fixed can you fix one more thing and look at another?  First
> arg_num_len is being miscalculated since I included the \n in that
> calculation (might be the only place....)
I think that calculation is correct only the comment needs to be changed like this:
-       /* how many digits are in arg_num? 3 is the length of a=\n */
+       /* how many digits are in arg_num? 3 is the length of " a=" */

the count is still 3 - with '\n' or with ' '.


> and I remember not wanting to
> follow convention and put the space at the beginning of the aX= for some
> reason.  If you add thousands of arguments so this is larger than
> MAX_EXECVE_AUDIT_LEN do you end up with an extra space somewhere in the
> second EXECVE record? 
Is this a problem? We can do some workaround but is it necessary?
> Or maybe it was a single argument that was larger
> than the max
This would do the same thing (leading space in record).
> , can't remember which, but I do remember having a random
> extra space (maybe we'd rather have that for consistency?)
Yes that's right - the space might be good if userspace client just
concatenates two records, the space should be good to be there. But I'm
unable to judge this. What do others think?

Jirka
> 
> -Eric
> 
> > 
> > record before this patch:
> > "type=EXECVE msg=audit(1231421801.566:31): argc=4 a0=\"./test\"\na1=\"a\"\na2=\"b\"\na3=\"c\"\n"
> > 
> > record after this patch:
> > "type=EXECVE msg=audit(1231421801.566:31): argc=4 a0=\"./test\" a1=\"a\" a2=\"b\" a3=\"c\""
> > 
> > 
> > Signed-off-by: Jiri Pirko <jpirko@redhat.com>
> > ---
> >  kernel/auditsc.c |    7 +++----
> >  1 files changed, 3 insertions(+), 4 deletions(-)
> > 
> > diff --git a/kernel/auditsc.c b/kernel/auditsc.c
> > index 8cbddff..c7012e0 100644
> > --- a/kernel/auditsc.c
> > +++ b/kernel/auditsc.c
> > @@ -1109,7 +1109,7 @@ static int audit_log_single_execve_arg(struct audit_context *context,
> >  		 * so we can be sure nothing was lost.
> >  		 */
> >  		if ((i == 0) && (too_long))
> > -			audit_log_format(*ab, "a%d_len=%zu ", arg_num,
> > +			audit_log_format(*ab, " a%d_len=%zu", arg_num,
> >  					 has_cntl ? 2*len : len);
> >  
> >  		/*
> > @@ -1129,7 +1129,7 @@ static int audit_log_single_execve_arg(struct audit_context *context,
> >  		buf[to_send] = '\0';
> >  
> >  		/* actually log it */
> > -		audit_log_format(*ab, "a%d", arg_num);
> > +		audit_log_format(*ab, " a%d", arg_num);
> >  		if (too_long)
> >  			audit_log_format(*ab, "[%d]", i);
> >  		audit_log_format(*ab, "=");
> > @@ -1137,7 +1137,6 @@ static int audit_log_single_execve_arg(struct audit_context *context,
> >  			audit_log_n_hex(*ab, buf, to_send);
> >  		else
> >  			audit_log_format(*ab, "\"%s\"", buf);
> > -		audit_log_format(*ab, "\n");
> >  
> >  		p += to_send;
> >  		len_left -= to_send;
> > @@ -1165,7 +1164,7 @@ static void audit_log_execve_info(struct audit_context *context,
> >  
> >  	p = (const char __user *)axi->mm->arg_start;
> >  
> > -	audit_log_format(*ab, "argc=%d ", axi->argc);
> > +	audit_log_format(*ab, "argc=%d", axi->argc);
> >  
> >  	/*
> >  	 * we need some kernel buffer to hold the userspace args.  Just
> 
> 

  reply	other threads:[~2009-01-09 12:21 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-01-08 14:38 audit: EXECVE record - removed bogus newline Jiri Pirko
2009-01-08 15:33 ` Eric Paris
2009-01-09 12:21   ` Jiri Pirko [this message]
2009-01-09 15:21     ` Eric Paris
2009-01-09 15:44       ` Jiri Pirko

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20090109132130.0bc87c02@psychotron.englab.brq.redhat.com \
    --to=jpirko@redhat.com \
    --cc=akpm@linux-foundation.org \
    --cc=eparis@redhat.com \
    --cc=linux-audit@redhat.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=viro@zeniv.linux.org.uk \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox