All of lore.kernel.org
 help / color / mirror / Atom feed
* [kernel-hardening] printk()s of user-supplied strings
@ 2011-06-12  2:31 Solar Designer
  2011-06-12 12:46 ` Vasiliy Kulikov
  2011-06-12 13:15 ` Vasiliy Kulikov
  0 siblings, 2 replies; 3+ messages in thread
From: Solar Designer @ 2011-06-12  2:31 UTC (permalink / raw)
  To: kernel-hardening; +Cc: Willy Tarreau

Vasiliy,

You could want to review this thread:

http://lists.openwall.net/linux-kernel/2006/08/22/29

(click "thread-next" for further messages).

I don't know (or don't recall) what the outcome of it was, if any.

Alexander

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [kernel-hardening] printk()s of user-supplied strings
  2011-06-12  2:31 [kernel-hardening] printk()s of user-supplied strings Solar Designer
@ 2011-06-12 12:46 ` Vasiliy Kulikov
  2011-06-12 13:15 ` Vasiliy Kulikov
  1 sibling, 0 replies; 3+ messages in thread
From: Vasiliy Kulikov @ 2011-06-12 12:46 UTC (permalink / raw)
  To: kernel-hardening; +Cc: Willy Tarreau

Solar,

On Sun, Jun 12, 2011 at 06:31 +0400, Solar Designer wrote:
> You could want to review this thread:
> 
> http://lists.openwall.net/linux-kernel/2006/08/22/29
> 
> (click "thread-next" for further messages).
> 
> I don't know (or don't recall) what the outcome of it was, if any.

I don't see any log spoofing protection in the current code.


As a primary threat is \n and \n<X> spoofing, I think the more simple
and bloodless solution would be escaping \n by some string like ">>".  So,
the initial

printk(PR_ERR, "Suspicious string: %s\n",
 "something\n<1>[  2533.035243] TCP: possible syn-flood from google.com")

- would result in -

[  2533.111111] Suspicious string: something
>> <1>[  2533.035243] TCP: possible syn-flood from google.com

Also all non-printable characters should be escaped on their own (1-31,
possibly, 127-255).  \xYYY or similar?

This parsing should be done in "%s" substitution only and in printk()
substitutions only (there are many other users of vscnprintf() and
similar).


An escaping has one drawback - escaped \n looses information about the
log severity.  So, this prefixed ">> .." string will be printed as it
would has emergency log severities.  It is better than simple log
spoofing, though.

Fully filter "\n" is not a solution as, IIRC, there are legitimate users
of such a multiline feature in the kernel.

Thanks,

-- 
Vasiliy

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [kernel-hardening] printk()s of user-supplied strings
  2011-06-12  2:31 [kernel-hardening] printk()s of user-supplied strings Solar Designer
  2011-06-12 12:46 ` Vasiliy Kulikov
@ 2011-06-12 13:15 ` Vasiliy Kulikov
  1 sibling, 0 replies; 3+ messages in thread
From: Vasiliy Kulikov @ 2011-06-12 13:15 UTC (permalink / raw)
  To: kernel-hardening; +Cc: Willy Tarreau

Solar,

On Sun, Jun 12, 2011 at 06:31 +0400, Solar Designer wrote:
> You could want to review this thread:
> 
> http://lists.openwall.net/linux-kernel/2006/08/22/29
> 
> (click "thread-next" for further messages).
> 
> I don't know (or don't recall) what the outcome of it was, if any.

I don't see any log spoofing protection in the current code.


As a primary threat is \n and \n<X> spoofing, I think the more simple
and bloodless solution would be escaping \n by some string like ">>".  So,
the initial

printk(PR_ERR, "Suspicious string: %s\n",
 "something\n<1>[  2533.035243] TCP: possible syn-flood from google.com")

- would result in -

[  2533.111111] Suspicious string: something
>> <1>[  2533.035243] TCP: possible syn-flood from google.com

Also all non-printable characters should be escaped on their own (1-31,
possibly, 127-255).  \xYYY or similar?

This parsing should be done in "%s" substitution only and in printk()
substitutions only (there are many other users of vscnprintf() and
similar).


An escaping has one drawback - escaped \n looses information about the
log severity.  So, this prefixed ">> .." string will be printed as it
would has emergency log severities.  It is better than simple log
spoofing, though.

Fully filter "\n" is not a solution as, IIRC, there are legitimate users
of such a multiline feature in the kernel.

Thanks,

-- 
Vasiliy

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2011-06-12 13:15 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-06-12  2:31 [kernel-hardening] printk()s of user-supplied strings Solar Designer
2011-06-12 12:46 ` Vasiliy Kulikov
2011-06-12 13:15 ` Vasiliy Kulikov

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.