Re: [RFC PATCH v8 09/18] SELinux: Only store the network interface's ifindex

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, 2007-12-14 at 16:50 -0500, Paul Moore wrote:
> Instead of storing the packet's network interface name store the ifindex.  This
> allows us to defer the need to lookup the net_device structure until the audit
> record is generated meaning that in the majority of cases we never need to
> bother with this at all.
>
> ---
> 
>  security/selinux/avc.c         |   15 ++++++++++++---
>  security/selinux/hooks.c       |    4 ++--
>  security/selinux/include/avc.h |    7 +++++--
>  3 files changed, 19 insertions(+), 7 deletions(-)
> 
> diff --git a/security/selinux/avc.c b/security/selinux/avc.c
> index 81b3dff..8ecfab9 100644
> --- a/security/selinux/avc.c
> +++ b/security/selinux/avc.c
> @@ -661,9 +661,18 @@ void avc_audit(u32 ssid, u32 tsid,
>  						    "daddr", "dest");
>  				break;
>  			}
> -			if (a->u.net.netif)
> -				audit_log_format(ab, " netif=%s",
> -					a->u.net.netif);
> +			if (a->u.net.netif >= 0) {
> +				struct net_device *dev;
> +
> +				/* NOTE: we always use init's namespace */
> +				dev = dev_get_by_index(&init_net,
> +						       a->u.net.netif);
> +				if (dev) {
> +					audit_log_format(ab, " netif=%s",
> +							 dev->name);
> +					dev_put(dev);
> +				}
> +			}
>  			break;
>  		}
>  	}
> diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c
> index 2ca8dfb..e429a8c 100644
> --- a/security/selinux/hooks.c
> +++ b/security/selinux/hooks.c
> @@ -3691,7 +3691,7 @@ static int selinux_socket_sock_rcv_skb(struct sock *sk, struct sk_buff *skb)
>  		family = PF_INET;
>  
>  	AVC_AUDIT_DATA_INIT(&ad, NET);
> -	ad.u.net.netif = skb->dev ? skb->dev->name : "[unknown]";
> +	ad.u.net.netif = skb->iif;
>  	ad.u.net.family = family;
>  
>  	err = selinux_parse_skb(skb, &ad, &addrp, &len, 1, NULL);
> @@ -4023,7 +4023,7 @@ static unsigned int selinux_ip_postroute_last(unsigned int hooknum,
>  	sksec = sk->sk_security;
>  
>  	AVC_AUDIT_DATA_INIT(&ad, NET);
> -	ad.u.net.netif = dev->name;
> +	ad.u.net.netif = dev->ifindex;
>  	ad.u.net.family = family;
>  
>  	err = selinux_parse_skb(skb, &ad, &addrp, &len, 0, &proto);
> diff --git a/security/selinux/include/avc.h b/security/selinux/include/avc.h
> index 553607a..5185152 100644
> --- a/security/selinux/include/avc.h
> +++ b/security/selinux/include/avc.h
> @@ -51,7 +51,7 @@ struct avc_audit_data {
>  			struct inode *inode;
>  		} fs;
>  		struct {
> -			char *netif;
> +			int netif;
>  			struct sock *sk;
>  			u16 family;
>  			__be16 dport;
> @@ -77,7 +77,10 @@ struct avc_audit_data {
>  
>  /* Initialize an AVC audit data structure. */
>  #define AVC_AUDIT_DATA_INIT(_d,_t) \
> -        { memset((_d), 0, sizeof(struct avc_audit_data)); (_d)->type = AVC_AUDIT_DATA_##_t; }
> +        { memset((_d), 0, sizeof(struct avc_audit_data)); \
> +	  (_d)->type = AVC_AUDIT_DATA_##_t; \
> +	  if ((_d)->type == AVC_AUDIT_DATA_NET) \
> +		  (_d)->u.net.netif = -1; }

As a minor nit, at the same time you do this, turn this into a static
inline function please.

>  
>  /*
>   * AVC statistics
> 
> 
> --
> This message was distributed to subscribers of the selinux mailing list.
> If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
> the words "unsubscribe selinux" without quotes as the message.
-- 
Stephen Smalley
National Security Agency


--
This message was distributed to subscribers of the selinux mailing list.
If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
the words "unsubscribe selinux" without quotes as the message.

[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux