2006-01-02 21:04:38 +03:00
/*
* net / tipc / netlink . c : TIPC configuration handling
2007-02-09 17:25:21 +03:00
*
2014-11-20 12:29:07 +03:00
* Copyright ( c ) 2005 - 2006 , 2014 , Ericsson AB
2008-05-22 01:52:30 +04:00
* Copyright ( c ) 2005 - 2007 , Wind River Systems
2006-01-02 21:04:38 +03:00
* All rights reserved .
*
2006-01-11 15:30:43 +03:00
* Redistribution and use in source and binary forms , with or without
2006-01-02 21:04:38 +03:00
* modification , are permitted provided that the following conditions are met :
*
2006-01-11 15:30:43 +03:00
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
* 3. Neither the names of the copyright holders nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission .
2006-01-02 21:04:38 +03:00
*
2006-01-11 15:30:43 +03:00
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS "
* AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR
* CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS
* INTERRUPTION ) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN
* CONTRACT , STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE )
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE
2006-01-02 21:04:38 +03:00
* POSSIBILITY OF SUCH DAMAGE .
*/
# include "core.h"
2014-11-20 12:29:10 +03:00
# include "socket.h"
2014-11-20 12:29:20 +03:00
# include "name_table.h"
2014-11-20 12:29:07 +03:00
# include "bearer.h"
2014-11-20 12:29:12 +03:00
# include "link.h"
2014-11-20 12:29:17 +03:00
# include "node.h"
2014-11-20 12:29:18 +03:00
# include "net.h"
2006-01-02 21:04:38 +03:00
# include <net/genetlink.h>
2014-11-20 12:29:07 +03:00
static const struct nla_policy tipc_nl_policy [ TIPC_NLA_MAX + 1 ] = {
[ TIPC_NLA_UNSPEC ] = { . type = NLA_UNSPEC , } ,
[ TIPC_NLA_BEARER ] = { . type = NLA_NESTED , } ,
2014-11-20 12:29:10 +03:00
[ TIPC_NLA_SOCK ] = { . type = NLA_NESTED , } ,
2014-11-20 12:29:12 +03:00
[ TIPC_NLA_PUBL ] = { . type = NLA_NESTED , } ,
[ TIPC_NLA_LINK ] = { . type = NLA_NESTED , } ,
2014-11-20 12:29:15 +03:00
[ TIPC_NLA_MEDIA ] = { . type = NLA_NESTED , } ,
2014-11-20 12:29:18 +03:00
[ TIPC_NLA_NODE ] = { . type = NLA_NESTED , } ,
2014-11-20 12:29:20 +03:00
[ TIPC_NLA_NET ] = { . type = NLA_NESTED , } ,
[ TIPC_NLA_NAME_TABLE ] = { . type = NLA_NESTED , }
2014-11-20 12:29:07 +03:00
} ;
2016-03-04 19:04:42 +03:00
const struct nla_policy
tipc_nl_name_table_policy [ TIPC_NLA_NAME_TABLE_MAX + 1 ] = {
[ TIPC_NLA_NAME_TABLE_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_NAME_TABLE_PUBL ] = { . type = NLA_NESTED }
} ;
const struct nla_policy tipc_nl_sock_policy [ TIPC_NLA_SOCK_MAX + 1 ] = {
[ TIPC_NLA_SOCK_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_SOCK_ADDR ] = { . type = NLA_U32 } ,
[ TIPC_NLA_SOCK_REF ] = { . type = NLA_U32 } ,
[ TIPC_NLA_SOCK_CON ] = { . type = NLA_NESTED } ,
[ TIPC_NLA_SOCK_HAS_PUBL ] = { . type = NLA_FLAG }
} ;
const struct nla_policy tipc_nl_net_policy [ TIPC_NLA_NET_MAX + 1 ] = {
[ TIPC_NLA_NET_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_NET_ID ] = { . type = NLA_U32 }
} ;
const struct nla_policy tipc_nl_link_policy [ TIPC_NLA_LINK_MAX + 1 ] = {
[ TIPC_NLA_LINK_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_LINK_NAME ] = { . type = NLA_STRING ,
. len = TIPC_MAX_LINK_NAME } ,
[ TIPC_NLA_LINK_MTU ] = { . type = NLA_U32 } ,
[ TIPC_NLA_LINK_BROADCAST ] = { . type = NLA_FLAG } ,
[ TIPC_NLA_LINK_UP ] = { . type = NLA_FLAG } ,
[ TIPC_NLA_LINK_ACTIVE ] = { . type = NLA_FLAG } ,
[ TIPC_NLA_LINK_PROP ] = { . type = NLA_NESTED } ,
[ TIPC_NLA_LINK_STATS ] = { . type = NLA_NESTED } ,
[ TIPC_NLA_LINK_RX ] = { . type = NLA_U32 } ,
[ TIPC_NLA_LINK_TX ] = { . type = NLA_U32 }
} ;
const struct nla_policy tipc_nl_node_policy [ TIPC_NLA_NODE_MAX + 1 ] = {
[ TIPC_NLA_NODE_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_NODE_ADDR ] = { . type = NLA_U32 } ,
[ TIPC_NLA_NODE_UP ] = { . type = NLA_FLAG }
} ;
/* Properties valid for media, bearer and link */
const struct nla_policy tipc_nl_prop_policy [ TIPC_NLA_PROP_MAX + 1 ] = {
[ TIPC_NLA_PROP_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_PROP_PRIO ] = { . type = NLA_U32 } ,
[ TIPC_NLA_PROP_TOL ] = { . type = NLA_U32 } ,
[ TIPC_NLA_PROP_WIN ] = { . type = NLA_U32 }
} ;
const struct nla_policy tipc_nl_bearer_policy [ TIPC_NLA_BEARER_MAX + 1 ] = {
[ TIPC_NLA_BEARER_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_BEARER_NAME ] = { . type = NLA_STRING ,
. len = TIPC_MAX_BEARER_NAME } ,
[ TIPC_NLA_BEARER_PROP ] = { . type = NLA_NESTED } ,
[ TIPC_NLA_BEARER_DOMAIN ] = { . type = NLA_U32 }
} ;
const struct nla_policy tipc_nl_media_policy [ TIPC_NLA_MEDIA_MAX + 1 ] = {
[ TIPC_NLA_MEDIA_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_MEDIA_NAME ] = { . type = NLA_STRING } ,
[ TIPC_NLA_MEDIA_PROP ] = { . type = NLA_NESTED }
} ;
const struct nla_policy tipc_nl_udp_policy [ TIPC_NLA_UDP_MAX + 1 ] = {
[ TIPC_NLA_UDP_UNSPEC ] = { . type = NLA_UNSPEC } ,
[ TIPC_NLA_UDP_LOCAL ] = { . type = NLA_BINARY ,
. len = sizeof ( struct sockaddr_storage ) } ,
[ TIPC_NLA_UDP_REMOTE ] = { . type = NLA_BINARY ,
. len = sizeof ( struct sockaddr_storage ) } ,
} ;
2014-11-20 12:29:07 +03:00
/* Users of the legacy API (tipc-config) can't handle that we add operations,
* so we have a separate genl handling for the new API .
*/
2015-02-09 11:50:03 +03:00
struct genl_family tipc_genl_family = {
2014-11-20 12:29:07 +03:00
. id = GENL_ID_GENERATE ,
. name = TIPC_GENL_V2_NAME ,
. version = TIPC_GENL_V2_VERSION ,
. hdrsize = 0 ,
. maxattr = TIPC_NLA_MAX ,
2015-01-09 10:27:13 +03:00
. netnsok = true ,
2014-11-20 12:29:07 +03:00
} ;
static const struct genl_ops tipc_genl_v2_ops [ ] = {
{
. cmd = TIPC_NL_BEARER_DISABLE ,
. doit = tipc_nl_bearer_disable ,
. policy = tipc_nl_policy ,
} ,
{
. cmd = TIPC_NL_BEARER_ENABLE ,
. doit = tipc_nl_bearer_enable ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:08 +03:00
} ,
{
. cmd = TIPC_NL_BEARER_GET ,
. doit = tipc_nl_bearer_get ,
. dumpit = tipc_nl_bearer_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:09 +03:00
} ,
{
. cmd = TIPC_NL_BEARER_SET ,
. doit = tipc_nl_bearer_set ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:10 +03:00
} ,
{
. cmd = TIPC_NL_SOCK_GET ,
. dumpit = tipc_nl_sk_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:11 +03:00
} ,
{
. cmd = TIPC_NL_PUBL_GET ,
. dumpit = tipc_nl_publ_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:12 +03:00
} ,
{
. cmd = TIPC_NL_LINK_GET ,
2015-11-19 22:30:45 +03:00
. doit = tipc_nl_node_get_link ,
2015-11-19 22:30:46 +03:00
. dumpit = tipc_nl_node_dump_link ,
2014-11-20 12:29:12 +03:00
. policy = tipc_nl_policy ,
2014-11-20 12:29:13 +03:00
} ,
{
. cmd = TIPC_NL_LINK_SET ,
2015-11-19 22:30:45 +03:00
. doit = tipc_nl_node_set_link ,
2014-11-20 12:29:13 +03:00
. policy = tipc_nl_policy ,
2014-11-20 12:29:14 +03:00
} ,
{
. cmd = TIPC_NL_LINK_RESET_STATS ,
2015-11-19 22:30:45 +03:00
. doit = tipc_nl_node_reset_link_stats ,
2014-11-20 12:29:14 +03:00
. policy = tipc_nl_policy ,
2014-11-20 12:29:15 +03:00
} ,
{
. cmd = TIPC_NL_MEDIA_GET ,
. doit = tipc_nl_media_get ,
. dumpit = tipc_nl_media_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:16 +03:00
} ,
{
. cmd = TIPC_NL_MEDIA_SET ,
. doit = tipc_nl_media_set ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:17 +03:00
} ,
{
. cmd = TIPC_NL_NODE_GET ,
. dumpit = tipc_nl_node_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:18 +03:00
} ,
{
. cmd = TIPC_NL_NET_GET ,
. dumpit = tipc_nl_net_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:19 +03:00
} ,
{
. cmd = TIPC_NL_NET_SET ,
. doit = tipc_nl_net_set ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:20 +03:00
} ,
{
. cmd = TIPC_NL_NAME_TABLE_GET ,
. dumpit = tipc_nl_name_table_dump ,
. policy = tipc_nl_policy ,
2014-11-20 12:29:07 +03:00
}
} ;
2014-11-20 12:29:11 +03:00
int tipc_nlmsg_parse ( const struct nlmsghdr * nlh , struct nlattr * * * attr )
{
2015-02-09 11:50:03 +03:00
u32 maxattr = tipc_genl_family . maxattr ;
2014-11-20 12:29:11 +03:00
2015-02-09 11:50:03 +03:00
* attr = tipc_genl_family . attrbuf ;
2014-11-20 12:29:11 +03:00
if ( ! * attr )
return - EOPNOTSUPP ;
return nlmsg_parse ( nlh , GENL_HDRLEN , * attr , maxattr , tipc_nl_policy ) ;
}
2006-01-18 02:38:21 +03:00
int tipc_netlink_start ( void )
2006-01-02 21:04:38 +03:00
{
2009-05-21 14:34:05 +04:00
int res ;
2006-01-10 21:54:24 +03:00
2015-02-09 11:50:03 +03:00
res = genl_register_family_with_ops ( & tipc_genl_family ,
2014-11-20 12:29:07 +03:00
tipc_genl_v2_ops ) ;
2009-05-21 14:34:05 +04:00
if ( res ) {
2012-06-29 08:16:37 +04:00
pr_err ( " Failed to register netlink interface \n " ) ;
2009-05-21 14:34:05 +04:00
return res ;
}
2007-02-09 17:25:21 +03:00
return 0 ;
2006-01-02 21:04:38 +03:00
}
2006-01-18 02:38:21 +03:00
void tipc_netlink_stop ( void )
2006-01-02 21:04:38 +03:00
{
2009-05-21 14:34:05 +04:00
genl_unregister_family ( & tipc_genl_family ) ;
2006-01-02 21:04:38 +03:00
}