diff options
author | csjp <csjp@FreeBSD.org> | 2006-09-12 04:25:13 +0000 |
---|---|---|
committer | csjp <csjp@FreeBSD.org> | 2006-09-12 04:25:13 +0000 |
commit | 63e89c05d2dd3463fdb87ade28334a74d7c6e6f0 (patch) | |
tree | bfad0bcbfb5566e8fc5f5992840f671a03dba9ea /sys/security/mac_biba/mac_biba.c | |
parent | c74e70f7a8f39a60078eafdfacb3a154e190b0f8 (diff) | |
download | FreeBSD-src-63e89c05d2dd3463fdb87ade28334a74d7c6e6f0.zip FreeBSD-src-63e89c05d2dd3463fdb87ade28334a74d7c6e6f0.tar.gz |
Introduce a new entry point, mac_create_mbuf_from_firewall. This entry point
exists to allow the mandatory access control policy to properly initialize
mbufs generated by the firewall. An example where this might happen is keep
alive packets, or ICMP error packets in response to other packets.
This takes care of kernel panics associated with un-initialize mbuf labels
when the firewall generates packets.
[1] I modified this patch from it's original version, the initial patch
introduced a number of entry points which were programmatically
equivalent. So I introduced only one. Instead, we should leverage
mac_create_mbuf_netlayer() which is used for similar situations,
an example being icmp_error()
This will minimize the impact associated with the MFC
Submitted by: mlaier [1]
MFC after: 1 week
This is a RELENG_6 candidate
Diffstat (limited to 'sys/security/mac_biba/mac_biba.c')
-rw-r--r-- | sys/security/mac_biba/mac_biba.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/sys/security/mac_biba/mac_biba.c b/sys/security/mac_biba/mac_biba.c index aecf72b..3f244ae 100644 --- a/sys/security/mac_biba/mac_biba.c +++ b/sys/security/mac_biba/mac_biba.c @@ -1381,6 +1381,17 @@ mac_biba_inpcb_sosetlabel(struct socket *so, struct label *solabel, mac_biba_copy(source, dest); } +static void +mac_biba_create_mbuf_from_firewall(struct mbuf *m, struct label *label) +{ + struct mac_biba *dest; + + dest = SLOT(label); + + /* XXX: where is the label for the firewall really comming from? */ + mac_biba_set_effective(dest, MAC_BIBA_TYPE_EQUAL, 0, NULL); +} + /* * Labeling event operations: processes. */ @@ -3210,6 +3221,7 @@ static struct mac_policy_ops mac_biba_ops = .mpo_check_vnode_stat = mac_biba_check_vnode_stat, .mpo_check_vnode_write = mac_biba_check_vnode_write, .mpo_associate_nfsd_label = mac_biba_associate_nfsd_label, + .mpo_create_mbuf_from_firewall = mac_biba_create_mbuf_from_firewall, }; MAC_POLICY_SET(&mac_biba_ops, mac_biba, "TrustedBSD MAC/Biba", |