xref: /openbmc/linux/include/net/rtnetlink.h (revision efb48ccfcda4dbb9fce39c5c8df19644a08121c0)
1e2849863SThomas Graf #ifndef __NET_RTNETLINK_H
2e2849863SThomas Graf #define __NET_RTNETLINK_H
3e2849863SThomas Graf 
4e2849863SThomas Graf #include <linux/rtnetlink.h>
5e2849863SThomas Graf #include <net/netlink.h>
6e2849863SThomas Graf 
7661d2967SThomas Graf typedef int (*rtnl_doit_func)(struct sk_buff *, struct nlmsghdr *);
8e2849863SThomas Graf typedef int (*rtnl_dumpit_func)(struct sk_buff *, struct netlink_callback *);
9115c9b81SGreg Rose typedef u16 (*rtnl_calcit_func)(struct sk_buff *, struct nlmsghdr *);
10e2849863SThomas Graf 
11*efb48ccfSJoe Perches int __rtnl_register(int protocol, int msgtype,
12*efb48ccfSJoe Perches 		    rtnl_doit_func, rtnl_dumpit_func, rtnl_calcit_func);
13*efb48ccfSJoe Perches void rtnl_register(int protocol, int msgtype,
14*efb48ccfSJoe Perches 		   rtnl_doit_func, rtnl_dumpit_func, rtnl_calcit_func);
15*efb48ccfSJoe Perches int rtnl_unregister(int protocol, int msgtype);
16*efb48ccfSJoe Perches void rtnl_unregister_all(int protocol);
17e2849863SThomas Graf 
183a6c2b41SPatrick McHardy static inline int rtnl_msg_family(const struct nlmsghdr *nlh)
19c454673dSThomas Graf {
20c454673dSThomas Graf 	if (nlmsg_len(nlh) >= sizeof(struct rtgenmsg))
21c454673dSThomas Graf 		return ((struct rtgenmsg *) nlmsg_data(nlh))->rtgen_family;
22c454673dSThomas Graf 	else
23c454673dSThomas Graf 		return AF_UNSPEC;
24c454673dSThomas Graf }
25c454673dSThomas Graf 
2638f7b870SPatrick McHardy /**
2738f7b870SPatrick McHardy  *	struct rtnl_link_ops - rtnetlink link operations
2838f7b870SPatrick McHardy  *
2938f7b870SPatrick McHardy  *	@list: Used internally
3038f7b870SPatrick McHardy  *	@kind: Identifier
3138f7b870SPatrick McHardy  *	@maxtype: Highest device specific netlink attribute number
3238f7b870SPatrick McHardy  *	@policy: Netlink policy for device specific attribute validation
3338f7b870SPatrick McHardy  *	@validate: Optional validation function for netlink/changelink parameters
3438f7b870SPatrick McHardy  *	@priv_size: sizeof net_device private space
3538f7b870SPatrick McHardy  *	@setup: net_device setup function
3638f7b870SPatrick McHardy  *	@newlink: Function for configuring and registering a new device
3738f7b870SPatrick McHardy  *	@changelink: Function for changing parameters of an existing device
3838f7b870SPatrick McHardy  *	@dellink: Function to remove a device
3938f7b870SPatrick McHardy  *	@get_size: Function to calculate required room for dumping device
4038f7b870SPatrick McHardy  *		   specific netlink attributes
4138f7b870SPatrick McHardy  *	@fill_info: Function to dump device specific netlink attributes
429b17876fSstephen hemminger  *	@get_xstats_size: Function to calculate required room for dumping device
4338f7b870SPatrick McHardy  *			  specific statistics
4438f7b870SPatrick McHardy  *	@fill_xstats: Function to dump device specific statistics
45d40156aaSJiri Pirko  *	@get_num_tx_queues: Function to determine number of transmit queues
46d40156aaSJiri Pirko  *			    to create when creating a new device.
47d40156aaSJiri Pirko  *	@get_num_rx_queues: Function to determine number of receive queues
48d40156aaSJiri Pirko  *			    to create when creating a new device.
4938f7b870SPatrick McHardy  */
5038f7b870SPatrick McHardy struct rtnl_link_ops {
5138f7b870SPatrick McHardy 	struct list_head	list;
5238f7b870SPatrick McHardy 
5338f7b870SPatrick McHardy 	const char		*kind;
5438f7b870SPatrick McHardy 
5538f7b870SPatrick McHardy 	size_t			priv_size;
5638f7b870SPatrick McHardy 	void			(*setup)(struct net_device *dev);
5738f7b870SPatrick McHardy 
5838f7b870SPatrick McHardy 	int			maxtype;
5938f7b870SPatrick McHardy 	const struct nla_policy	*policy;
6038f7b870SPatrick McHardy 	int			(*validate)(struct nlattr *tb[],
6138f7b870SPatrick McHardy 					    struct nlattr *data[]);
6238f7b870SPatrick McHardy 
6381adee47SEric W. Biederman 	int			(*newlink)(struct net *src_net,
6481adee47SEric W. Biederman 					   struct net_device *dev,
6538f7b870SPatrick McHardy 					   struct nlattr *tb[],
6638f7b870SPatrick McHardy 					   struct nlattr *data[]);
6738f7b870SPatrick McHardy 	int			(*changelink)(struct net_device *dev,
6838f7b870SPatrick McHardy 					      struct nlattr *tb[],
6938f7b870SPatrick McHardy 					      struct nlattr *data[]);
7023289a37SEric Dumazet 	void			(*dellink)(struct net_device *dev,
7123289a37SEric Dumazet 					   struct list_head *head);
7238f7b870SPatrick McHardy 
7338f7b870SPatrick McHardy 	size_t			(*get_size)(const struct net_device *dev);
7438f7b870SPatrick McHardy 	int			(*fill_info)(struct sk_buff *skb,
7538f7b870SPatrick McHardy 					     const struct net_device *dev);
7638f7b870SPatrick McHardy 
7738f7b870SPatrick McHardy 	size_t			(*get_xstats_size)(const struct net_device *dev);
7838f7b870SPatrick McHardy 	int			(*fill_xstats)(struct sk_buff *skb,
7938f7b870SPatrick McHardy 					       const struct net_device *dev);
80d40156aaSJiri Pirko 	unsigned int		(*get_num_tx_queues)(void);
81d40156aaSJiri Pirko 	unsigned int		(*get_num_rx_queues)(void);
8238f7b870SPatrick McHardy };
8338f7b870SPatrick McHardy 
84*efb48ccfSJoe Perches int __rtnl_link_register(struct rtnl_link_ops *ops);
85*efb48ccfSJoe Perches void __rtnl_link_unregister(struct rtnl_link_ops *ops);
8638f7b870SPatrick McHardy 
87*efb48ccfSJoe Perches int rtnl_link_register(struct rtnl_link_ops *ops);
88*efb48ccfSJoe Perches void rtnl_link_unregister(struct rtnl_link_ops *ops);
8938f7b870SPatrick McHardy 
90f8ff182cSThomas Graf /**
91f8ff182cSThomas Graf  * 	struct rtnl_af_ops - rtnetlink address family operations
92f8ff182cSThomas Graf  *
93f8ff182cSThomas Graf  *	@list: Used internally
94f8ff182cSThomas Graf  * 	@family: Address family
95f8ff182cSThomas Graf  * 	@fill_link_af: Function to fill IFLA_AF_SPEC with address family
96f8ff182cSThomas Graf  * 		       specific netlink attributes.
97f8ff182cSThomas Graf  * 	@get_link_af_size: Function to calculate size of address family specific
989b17876fSstephen hemminger  * 			   netlink attributes.
99cf7afbfeSThomas Graf  *	@validate_link_af: Validate a IFLA_AF_SPEC attribute, must check attr
100cf7afbfeSThomas Graf  *			   for invalid configuration settings.
101cf7afbfeSThomas Graf  * 	@set_link_af: Function to parse a IFLA_AF_SPEC attribute and modify
102f8ff182cSThomas Graf  *		      net_device accordingly.
103f8ff182cSThomas Graf  */
104f8ff182cSThomas Graf struct rtnl_af_ops {
105f8ff182cSThomas Graf 	struct list_head	list;
106f8ff182cSThomas Graf 	int			family;
107f8ff182cSThomas Graf 
108f8ff182cSThomas Graf 	int			(*fill_link_af)(struct sk_buff *skb,
109f8ff182cSThomas Graf 						const struct net_device *dev);
110f8ff182cSThomas Graf 	size_t			(*get_link_af_size)(const struct net_device *dev);
111f8ff182cSThomas Graf 
112cf7afbfeSThomas Graf 	int			(*validate_link_af)(const struct net_device *dev,
113cf7afbfeSThomas Graf 						    const struct nlattr *attr);
114cf7afbfeSThomas Graf 	int			(*set_link_af)(struct net_device *dev,
115f8ff182cSThomas Graf 					       const struct nlattr *attr);
116f8ff182cSThomas Graf };
117f8ff182cSThomas Graf 
118*efb48ccfSJoe Perches int __rtnl_af_register(struct rtnl_af_ops *ops);
119*efb48ccfSJoe Perches void __rtnl_af_unregister(struct rtnl_af_ops *ops);
120f8ff182cSThomas Graf 
121*efb48ccfSJoe Perches int rtnl_af_register(struct rtnl_af_ops *ops);
122*efb48ccfSJoe Perches void rtnl_af_unregister(struct rtnl_af_ops *ops);
123f8ff182cSThomas Graf 
124*efb48ccfSJoe Perches struct net *rtnl_link_get_net(struct net *src_net, struct nlattr *tb[]);
125*efb48ccfSJoe Perches struct net_device *rtnl_create_link(struct net *net, char *ifname,
126*efb48ccfSJoe Perches 				    const struct rtnl_link_ops *ops,
127*efb48ccfSJoe Perches 				    struct nlattr *tb[]);
128*efb48ccfSJoe Perches int rtnl_configure_link(struct net_device *dev, const struct ifinfomsg *ifm);
129f8ff182cSThomas Graf 
130e7199288SPavel Emelianov extern const struct nla_policy ifla_policy[IFLA_MAX+1];
131e7199288SPavel Emelianov 
13238f7b870SPatrick McHardy #define MODULE_ALIAS_RTNL_LINK(kind) MODULE_ALIAS("rtnl-link-" kind)
13338f7b870SPatrick McHardy 
134e2849863SThomas Graf #endif
135