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