4  * This file defines the kernel API for the NetLabel system.  The NetLabel
 
   5  * system manages static and dynamic label mappings for network protocols such
 
   8  * Author: Paul Moore <paul.moore@hp.com>
 
  13  * (c) Copyright Hewlett-Packard Development Company, L.P., 2006
 
  15  * This program is free software;  you can redistribute it and/or modify
 
  16  * it under the terms of the GNU General Public License as published by
 
  17  * the Free Software Foundation; either version 2 of the License, or
 
  18  * (at your option) any later version.
 
  20  * This program is distributed in the hope that it will be useful,
 
  21  * but WITHOUT ANY WARRANTY;  without even the implied warranty of
 
  22  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
 
  23  * the GNU General Public License for more details.
 
  25  * You should have received a copy of the GNU General Public License
 
  26  * along with this program;  if not, write to the Free Software
 
  27  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 
  31 #include <linux/init.h>
 
  32 #include <linux/types.h>
 
  34 #include <net/netlabel.h>
 
  35 #include <net/cipso_ipv4.h>
 
  38 #include "netlabel_domainhash.h"
 
  39 #include "netlabel_unlabeled.h"
 
  40 #include "netlabel_user.h"
 
  47  * netlbl_socket_setattr - Label a socket using the correct protocol
 
  48  * @sock: the socket to label
 
  49  * @secattr: the security attributes
 
  52  * Attach the correct label to the given socket using the security attributes
 
  53  * specified in @secattr.  This function requires exclusive access to
 
  54  * @sock->sk, which means it either needs to be in the process of being
 
  55  * created or locked via lock_sock(sock->sk).  Returns zero on success,
 
  56  * negative values on failure.
 
  59 int netlbl_socket_setattr(const struct socket *sock,
 
  60                           const struct netlbl_lsm_secattr *secattr)
 
  62         int ret_val = -ENOENT;
 
  63         struct netlbl_dom_map *dom_entry;
 
  66         dom_entry = netlbl_domhsh_getentry(secattr->domain);
 
  67         if (dom_entry == NULL)
 
  68                 goto socket_setattr_return;
 
  69         switch (dom_entry->type) {
 
  70         case NETLBL_NLTYPE_CIPSOV4:
 
  71                 ret_val = cipso_v4_socket_setattr(sock,
 
  72                                                   dom_entry->type_def.cipsov4,
 
  75         case NETLBL_NLTYPE_UNLABELED:
 
  82 socket_setattr_return:
 
  88  * netlbl_sock_getattr - Determine the security attributes of a sock
 
  90  * @secattr: the security attributes
 
  93  * Examines the given sock to see any NetLabel style labeling has been
 
  94  * applied to the sock, if so it parses the socket label and returns the
 
  95  * security attributes in @secattr.  Returns zero on success, negative values
 
  99 int netlbl_sock_getattr(struct sock *sk, struct netlbl_lsm_secattr *secattr)
 
 103         ret_val = cipso_v4_sock_getattr(sk, secattr);
 
 107         return netlbl_unlabel_getattr(secattr);
 
 111  * netlbl_socket_getattr - Determine the security attributes of a socket
 
 113  * @secattr: the security attributes
 
 116  * Examines the given socket to see any NetLabel style labeling has been
 
 117  * applied to the socket, if so it parses the socket label and returns the
 
 118  * security attributes in @secattr.  Returns zero on success, negative values
 
 122 int netlbl_socket_getattr(const struct socket *sock,
 
 123                           struct netlbl_lsm_secattr *secattr)
 
 127         ret_val = cipso_v4_socket_getattr(sock, secattr);
 
 131         return netlbl_unlabel_getattr(secattr);
 
 135  * netlbl_skbuff_getattr - Determine the security attributes of a packet
 
 137  * @secattr: the security attributes
 
 140  * Examines the given packet to see if a recognized form of packet labeling
 
 141  * is present, if so it parses the packet label and returns the security
 
 142  * attributes in @secattr.  Returns zero on success, negative values on
 
 146 int netlbl_skbuff_getattr(const struct sk_buff *skb,
 
 147                           struct netlbl_lsm_secattr *secattr)
 
 151         ret_val = cipso_v4_skbuff_getattr(skb, secattr);
 
 155         return netlbl_unlabel_getattr(secattr);
 
 159  * netlbl_skbuff_err - Handle a LSM error on a sk_buff
 
 161  * @error: the error code
 
 164  * Deal with a LSM problem when handling the packet in @skb, typically this is
 
 165  * a permission denied problem (-EACCES).  The correct action is determined
 
 166  * according to the packet's labeling protocol.
 
 169 void netlbl_skbuff_err(struct sk_buff *skb, int error)
 
 171         if (CIPSO_V4_OPTEXIST(skb))
 
 172                 cipso_v4_error(skb, error, 0);
 
 176  * netlbl_cache_invalidate - Invalidate all of the NetLabel protocol caches
 
 179  * For all of the NetLabel protocols that support some form of label mapping
 
 180  * cache, invalidate the cache.  Returns zero on success, negative values on
 
 184 void netlbl_cache_invalidate(void)
 
 186         cipso_v4_cache_invalidate();
 
 190  * netlbl_cache_add - Add an entry to a NetLabel protocol cache
 
 192  * @secattr: the packet's security attributes
 
 195  * Add the LSM security attributes for the given packet to the underlying
 
 196  * NetLabel protocol's label mapping cache.  Returns zero on success, negative
 
 200 int netlbl_cache_add(const struct sk_buff *skb,
 
 201                      const struct netlbl_lsm_secattr *secattr)
 
 203         if (secattr->cache == NULL)
 
 206         if (CIPSO_V4_OPTEXIST(skb))
 
 207                 return cipso_v4_cache_add(skb, secattr);
 
 217  * netlbl_init - Initialize NetLabel
 
 220  * Perform the required NetLabel initialization before first use.
 
 223 static int __init netlbl_init(void)
 
 227         printk(KERN_INFO "NetLabel: Initializing\n");
 
 228         printk(KERN_INFO "NetLabel:  domain hash size = %u\n",
 
 229                (1 << NETLBL_DOMHSH_BITSIZE));
 
 230         printk(KERN_INFO "NetLabel:  protocols ="
 
 235         ret_val = netlbl_domhsh_init(NETLBL_DOMHSH_BITSIZE);
 
 239         ret_val = netlbl_netlink_init();
 
 243         ret_val = netlbl_unlabel_defconf();
 
 246         printk(KERN_INFO "NetLabel:  unlabeled traffic allowed by default\n");
 
 251         panic("NetLabel: failed to initialize properly (%d)\n", ret_val);
 
 254 subsys_initcall(netlbl_init);