SELinux: Enable dynamic enable/disable of the network access checks
authorPaul Moore <paul.moore@hp.com>
Tue, 29 Jan 2008 13:43:36 +0000 (08:43 -0500)
committerJames Morris <jmorris@namei.org>
Tue, 29 Jan 2008 21:17:26 +0000 (08:17 +1100)
commitd621d35e576aa20a0ddae8022c3810f38357c8ff
tree318e8aa890dbe715b901b11b019ebac3badb693d
parent220deb966ea51e0dedb6a187c0763120809f3e64
SELinux: Enable dynamic enable/disable of the network access checks

This patch introduces a mechanism for checking when labeled IPsec or SECMARK
are in use by keeping introducing a configuration reference counter for each
subsystem.  In the case of labeled IPsec, whenever a labeled SA or SPD entry
is created the labeled IPsec/XFRM reference count is increased and when the
entry is removed it is decreased.  In the case of SECMARK, when a SECMARK
target is created the reference count is increased and later decreased when the
target is removed.  These reference counters allow SELinux to quickly determine
if either of these subsystems are enabled.

NetLabel already has a similar mechanism which provides the netlbl_enabled()
function.

This patch also renames the selinux_relabel_packet_permission() function to
selinux_secmark_relabel_packet_permission() as the original name and
description were misleading in that they referenced a single packet label which
is not the case.

Signed-off-by: Paul Moore <paul.moore@hp.com>
Signed-off-by: James Morris <jmorris@namei.org>
include/linux/selinux.h
net/netfilter/xt_SECMARK.c
security/selinux/exports.c
security/selinux/hooks.c
security/selinux/include/xfrm.h
security/selinux/xfrm.c