xref: /aosp_15_r20/external/libnl/lib/route/link/team.c (revision 4dc78e53d49367fa8e61b07018507c90983a077d)
1*4dc78e53SAndroid Build Coastguard Worker /* SPDX-License-Identifier: LGPL-2.1-only */
2*4dc78e53SAndroid Build Coastguard Worker /*
3*4dc78e53SAndroid Build Coastguard Worker  * Copyright (c) 2015 Jonas Johansson <[email protected]>
4*4dc78e53SAndroid Build Coastguard Worker  */
5*4dc78e53SAndroid Build Coastguard Worker 
6*4dc78e53SAndroid Build Coastguard Worker /**
7*4dc78e53SAndroid Build Coastguard Worker  * @ingroup link
8*4dc78e53SAndroid Build Coastguard Worker  * @defgroup team Team
9*4dc78e53SAndroid Build Coastguard Worker  *
10*4dc78e53SAndroid Build Coastguard Worker  * @details
11*4dc78e53SAndroid Build Coastguard Worker  * \b Link Type Name: "team"
12*4dc78e53SAndroid Build Coastguard Worker  *
13*4dc78e53SAndroid Build Coastguard Worker  * @route_doc{link_team, Team Documentation}
14*4dc78e53SAndroid Build Coastguard Worker  * @{
15*4dc78e53SAndroid Build Coastguard Worker  */
16*4dc78e53SAndroid Build Coastguard Worker 
17*4dc78e53SAndroid Build Coastguard Worker #include "nl-default.h"
18*4dc78e53SAndroid Build Coastguard Worker 
19*4dc78e53SAndroid Build Coastguard Worker #include <netlink/netlink.h>
20*4dc78e53SAndroid Build Coastguard Worker #include <netlink/route/link/team.h>
21*4dc78e53SAndroid Build Coastguard Worker 
22*4dc78e53SAndroid Build Coastguard Worker #include "link-api.h"
23*4dc78e53SAndroid Build Coastguard Worker 
24*4dc78e53SAndroid Build Coastguard Worker /**
25*4dc78e53SAndroid Build Coastguard Worker  * Allocate link object of type team
26*4dc78e53SAndroid Build Coastguard Worker  *
27*4dc78e53SAndroid Build Coastguard Worker  * @return Allocated link object or NULL.
28*4dc78e53SAndroid Build Coastguard Worker  */
rtnl_link_team_alloc(void)29*4dc78e53SAndroid Build Coastguard Worker struct rtnl_link *rtnl_link_team_alloc(void)
30*4dc78e53SAndroid Build Coastguard Worker {
31*4dc78e53SAndroid Build Coastguard Worker 	struct rtnl_link *link;
32*4dc78e53SAndroid Build Coastguard Worker 
33*4dc78e53SAndroid Build Coastguard Worker 	if (!(link = rtnl_link_alloc()))
34*4dc78e53SAndroid Build Coastguard Worker 		return NULL;
35*4dc78e53SAndroid Build Coastguard Worker 
36*4dc78e53SAndroid Build Coastguard Worker 	if (rtnl_link_set_type(link, "team") < 0) {
37*4dc78e53SAndroid Build Coastguard Worker 		rtnl_link_put(link);
38*4dc78e53SAndroid Build Coastguard Worker 		return NULL;
39*4dc78e53SAndroid Build Coastguard Worker 	}
40*4dc78e53SAndroid Build Coastguard Worker 
41*4dc78e53SAndroid Build Coastguard Worker 	return link;
42*4dc78e53SAndroid Build Coastguard Worker }
43*4dc78e53SAndroid Build Coastguard Worker 
44*4dc78e53SAndroid Build Coastguard Worker /**
45*4dc78e53SAndroid Build Coastguard Worker  * Create a new kernel team device
46*4dc78e53SAndroid Build Coastguard Worker  * @arg sock		netlink socket
47*4dc78e53SAndroid Build Coastguard Worker  * @arg name		name of team device or NULL
48*4dc78e53SAndroid Build Coastguard Worker  * @arg opts		team options (currently unused)
49*4dc78e53SAndroid Build Coastguard Worker  *
50*4dc78e53SAndroid Build Coastguard Worker  * Creates a new team device in the kernel. If no name is
51*4dc78e53SAndroid Build Coastguard Worker  * provided, the kernel will automatically pick a name of the
52*4dc78e53SAndroid Build Coastguard Worker  * form "type%d" (e.g. team0, vlan1, etc.)
53*4dc78e53SAndroid Build Coastguard Worker  *
54*4dc78e53SAndroid Build Coastguard Worker  * The \a opts argument is currently unused. In the future, it
55*4dc78e53SAndroid Build Coastguard Worker  * may be used to carry additional team options to be set
56*4dc78e53SAndroid Build Coastguard Worker  * when creating the team device.
57*4dc78e53SAndroid Build Coastguard Worker  *
58*4dc78e53SAndroid Build Coastguard Worker  * @note When letting the kernel assign a name, it will become
59*4dc78e53SAndroid Build Coastguard Worker  *       difficult to retrieve the interface afterwards because
60*4dc78e53SAndroid Build Coastguard Worker  *       you have to guess the name the kernel has chosen. It is
61*4dc78e53SAndroid Build Coastguard Worker  *       therefore not recommended to not provide a device name.
62*4dc78e53SAndroid Build Coastguard Worker  *
63*4dc78e53SAndroid Build Coastguard Worker  * @see rtnl_link_team_enslave()
64*4dc78e53SAndroid Build Coastguard Worker  * @see rtnl_link_team_release()
65*4dc78e53SAndroid Build Coastguard Worker  *
66*4dc78e53SAndroid Build Coastguard Worker  * @return 0 on success or a negative error code
67*4dc78e53SAndroid Build Coastguard Worker  */
rtnl_link_team_add(struct nl_sock * sock,const char * name,struct rtnl_link * opts)68*4dc78e53SAndroid Build Coastguard Worker int rtnl_link_team_add(struct nl_sock *sock, const char *name,
69*4dc78e53SAndroid Build Coastguard Worker 		       struct rtnl_link *opts)
70*4dc78e53SAndroid Build Coastguard Worker {
71*4dc78e53SAndroid Build Coastguard Worker 	struct rtnl_link *link;
72*4dc78e53SAndroid Build Coastguard Worker 	int err;
73*4dc78e53SAndroid Build Coastguard Worker 
74*4dc78e53SAndroid Build Coastguard Worker 	if (!(link = rtnl_link_team_alloc()))
75*4dc78e53SAndroid Build Coastguard Worker 		return -NLE_NOMEM;
76*4dc78e53SAndroid Build Coastguard Worker 
77*4dc78e53SAndroid Build Coastguard Worker 	if (!name && opts)
78*4dc78e53SAndroid Build Coastguard Worker 		name = rtnl_link_get_name(opts);
79*4dc78e53SAndroid Build Coastguard Worker 
80*4dc78e53SAndroid Build Coastguard Worker 	if (name)
81*4dc78e53SAndroid Build Coastguard Worker 		rtnl_link_set_name(link, name);
82*4dc78e53SAndroid Build Coastguard Worker 
83*4dc78e53SAndroid Build Coastguard Worker 	err = rtnl_link_add(sock, link, NLM_F_CREATE);
84*4dc78e53SAndroid Build Coastguard Worker 
85*4dc78e53SAndroid Build Coastguard Worker 	rtnl_link_put(link);
86*4dc78e53SAndroid Build Coastguard Worker 
87*4dc78e53SAndroid Build Coastguard Worker 	return err;
88*4dc78e53SAndroid Build Coastguard Worker }
89*4dc78e53SAndroid Build Coastguard Worker 
90*4dc78e53SAndroid Build Coastguard Worker static struct rtnl_link_info_ops team_info_ops = {
91*4dc78e53SAndroid Build Coastguard Worker 	.io_name		= "team",
92*4dc78e53SAndroid Build Coastguard Worker };
93*4dc78e53SAndroid Build Coastguard Worker 
team_init(void)94*4dc78e53SAndroid Build Coastguard Worker static void _nl_init team_init(void)
95*4dc78e53SAndroid Build Coastguard Worker {
96*4dc78e53SAndroid Build Coastguard Worker 	rtnl_link_register_info(&team_info_ops);
97*4dc78e53SAndroid Build Coastguard Worker }
98*4dc78e53SAndroid Build Coastguard Worker 
team_exit(void)99*4dc78e53SAndroid Build Coastguard Worker static void _nl_exit team_exit(void)
100*4dc78e53SAndroid Build Coastguard Worker {
101*4dc78e53SAndroid Build Coastguard Worker 	rtnl_link_unregister_info(&team_info_ops);
102*4dc78e53SAndroid Build Coastguard Worker }
103*4dc78e53SAndroid Build Coastguard Worker 
104*4dc78e53SAndroid Build Coastguard Worker /** @} */
105