[NetLabel]: protect the CIPSOv4 socket option from setsockopt()
authorPaul Moore <paul.moore@hp.com>
Mon, 30 Oct 2006 23:22:15 +0000 (15:22 -0800)
committerDavid S. Miller <davem@sunset.davemloft.net>
Mon, 30 Oct 2006 23:24:49 +0000 (15:24 -0800)
commitf8687afefcc821fc47c75775eec87731fe3de360
tree9835a3c95fb94597ede42cfdf732b97cc495c9bf
parent920b868ae1dfdac77c5e8c97e7067b23680f043e
[NetLabel]: protect the CIPSOv4 socket option from setsockopt()

This patch makes two changes to protect applications from either removing or
tampering with the CIPSOv4 IP option on a socket.  The first is the requirement
that applications have the CAP_NET_RAW capability to set an IPOPT_CIPSO option
on a socket; this prevents untrusted applications from setting their own
CIPSOv4 security attributes on the packets they send.  The second change is to
SELinux and it prevents applications from setting any IPv4 options when there
is an IPOPT_CIPSO option already present on the socket; this prevents
applications from removing CIPSOv4 security attributes from the packets they
send.

Signed-off-by: Paul Moore <paul.moore@hp.com>
Signed-off-by: James Morris <jmorris@namei.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/cipso_ipv4.c
net/ipv4/ip_options.c
security/selinux/hooks.c
security/selinux/include/selinux_netlabel.h
security/selinux/ss/services.c