]> git.baikalelectronics.ru Git - kernel.git/commit
net-timestamp: no-payload only sysctl
authorWillem de Bruijn <willemb@google.com>
Fri, 30 Jan 2015 18:29:32 +0000 (13:29 -0500)
committerDavid S. Miller <davem@davemloft.net>
Tue, 3 Feb 2015 02:46:51 +0000 (18:46 -0800)
commit5b2c0c8cf9ac9000ae20b06f38b5ff6c4e77a486
treee9e4e746bcb24db72ae5a947c7001bab21211a8e
parentce3cb88e37f4839c70f7b5a2dbde3e6690501073
net-timestamp: no-payload only sysctl

Tx timestamps are looped onto the error queue on top of an skb. This
mechanism leaks packet headers to processes unless the no-payload
options SOF_TIMESTAMPING_OPT_TSONLY is set.

Add a sysctl that optionally drops looped timestamp with data. This
only affects processes without CAP_NET_RAW.

The policy is checked when timestamps are generated in the stack.
It is possible for timestamps with data to be reported after the
sysctl is set, if these were queued internally earlier.

No vulnerability is immediately known that exploits knowledge
gleaned from packet headers, but it may still be preferable to allow
administrators to lock down this path at the cost of possible
breakage of legacy applications.

Signed-off-by: Willem de Bruijn <willemb@google.com>
----

Changes
  (v1 -> v2)
  - test socket CAP_NET_RAW instead of capable(CAP_NET_RAW)
  (rfc -> v1)
  - document the sysctl in Documentation/sysctl/net.txt
  - fix access control race: read .._OPT_TSONLY only once,
        use same value for permission check and skb generation.
Signed-off-by: David S. Miller <davem@davemloft.net>
Documentation/sysctl/net.txt
include/net/sock.h
net/core/skbuff.c
net/core/sock.c
net/core/sysctl_net_core.c