2006-08-03 16:48:37 -07:00
/*
* NetLabel NETLINK Interface
*
* This file defines the NETLINK interface for the NetLabel system . The
* NetLabel system manages static and dynamic label mappings for network
* protocols such as CIPSO and RIPSO .
*
* Author : Paul Moore < paul . moore @ hp . com >
*
*/
/*
* ( c ) Copyright Hewlett - Packard Development Company , L . P . , 2006
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See
* the GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*
*/
# include <linux/init.h>
# include <linux/types.h>
# include <linux/list.h>
# include <linux/socket.h>
2006-09-28 14:51:47 -07:00
# include <linux/audit.h>
# include <linux/tty.h>
# include <linux/security.h>
2006-08-03 16:48:37 -07:00
# include <net/sock.h>
# include <net/netlink.h>
# include <net/genetlink.h>
# include <net/netlabel.h>
# include <asm/bug.h>
# include "netlabel_mgmt.h"
# include "netlabel_unlabeled.h"
# include "netlabel_cipso_v4.h"
# include "netlabel_user.h"
/*
* NetLabel NETLINK Setup Functions
*/
/**
* netlbl_netlink_init - Initialize the NETLINK communication channel
*
* Description :
* Call out to the NetLabel components so they can register their families and
* commands with the Generic NETLINK mechanism . Returns zero on success and
* non - zero on failure .
*
*/
2008-02-17 22:33:57 -08:00
int __init netlbl_netlink_init ( void )
2006-08-03 16:48:37 -07:00
{
int ret_val ;
ret_val = netlbl_mgmt_genl_init ( ) ;
if ( ret_val ! = 0 )
return ret_val ;
ret_val = netlbl_cipsov4_genl_init ( ) ;
if ( ret_val ! = 0 )
return ret_val ;
ret_val = netlbl_unlabel_genl_init ( ) ;
if ( ret_val ! = 0 )
return ret_val ;
return 0 ;
}
2006-09-28 14:51:47 -07:00
/*
* NetLabel Audit Functions
*/
/**
* netlbl_audit_start_common - Start an audit message
* @ type : audit message type
2006-09-29 17:05:05 -07:00
* @ audit_info : NetLabel audit information
2006-09-28 14:51:47 -07:00
*
* Description :
* Start an audit message using the type specified in @ type and fill the audit
* message with some fields common to all NetLabel audit messages . Returns
* a pointer to the audit buffer on success , NULL on failure .
*
*/
2006-09-29 17:05:05 -07:00
struct audit_buffer * netlbl_audit_start_common ( int type ,
struct netlbl_audit * audit_info )
2006-09-28 14:51:47 -07:00
{
struct audit_buffer * audit_buf ;
char * secctx ;
u32 secctx_len ;
2006-11-17 17:38:55 -05:00
if ( audit_enabled = = 0 )
return NULL ;
2008-02-12 22:35:37 -08:00
audit_buf = audit_log_start ( current - > audit_context , GFP_ATOMIC , type ) ;
2006-09-28 14:51:47 -07:00
if ( audit_buf = = NULL )
return NULL ;
2006-09-29 17:05:05 -07:00
audit_log_format ( audit_buf , " netlabel: auid=%u " , audit_info - > loginuid ) ;
2006-09-28 14:51:47 -07:00
2006-09-29 17:05:05 -07:00
if ( audit_info - > secid ! = 0 & &
security_secid_to_secctx ( audit_info - > secid ,
& secctx ,
2007-08-01 11:12:59 -04:00
& secctx_len ) = = 0 ) {
2006-09-28 14:51:47 -07:00
audit_log_format ( audit_buf , " subj=%s " , secctx ) ;
2007-08-01 11:12:59 -04:00
security_release_secctx ( secctx , secctx_len ) ;
}
2006-09-28 14:51:47 -07:00
return audit_buf ;
}