veth device link management
Signed-off-by: Vitaliy Gusev <vgusev@openvz.org> Signed-off-by: Stephen Hemminger <shemminger@linux-foundation.org>
This commit is contained in:
parent
909dfe2c7e
commit
f9329ccaf9
|
|
@ -10,78 +10,52 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "ip_common.h"
|
#include "ip_common.h"
|
||||||
#include "veth.h"
|
#include "veth.h"
|
||||||
|
|
||||||
#define ETH_ALEN 6
|
#define IFNAMSIZ 16
|
||||||
|
|
||||||
static void usage(void)
|
static void usage(void)
|
||||||
{
|
{
|
||||||
printf("Usage: ip link add ... type veth "
|
printf("Usage: ip link <options> type veth "
|
||||||
"[peer <peer-name>] [mac <mac>] [peer_mac <mac>]\n");
|
"[peer <options>]\nTo get <options> type "
|
||||||
|
"'ip link add help'\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static int veth_parse_opt(struct link_util *lu, int argc, char **argv,
|
static int veth_parse_opt(struct link_util *lu, int argc, char **argv,
|
||||||
struct nlmsghdr *hdr)
|
struct nlmsghdr *hdr)
|
||||||
{
|
{
|
||||||
__u8 mac[ETH_ALEN];
|
char *name, *type, *link, *dev;
|
||||||
|
int err, len;
|
||||||
for (; argc != 0; argv++, argc--) {
|
struct rtattr * data;
|
||||||
if (strcmp(*argv, "peer") == 0) {
|
|
||||||
argv++;
|
|
||||||
argc--;
|
|
||||||
if (argc == 0) {
|
|
||||||
usage();
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
addattr_l(hdr, 1024, VETH_INFO_PEER,
|
|
||||||
*argv, strlen(*argv));
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strcmp(*argv, "mac") == 0) {
|
|
||||||
argv++;
|
|
||||||
argc--;
|
|
||||||
if (argc == 0) {
|
|
||||||
usage();
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hexstring_a2n(*argv, mac, sizeof(mac)) == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
addattr_l(hdr, 1024, VETH_INFO_MAC,
|
|
||||||
mac, ETH_ALEN);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strcmp(*argv, "peer_mac") == 0) {
|
|
||||||
argv++;
|
|
||||||
argc--;
|
|
||||||
if (argc == 0) {
|
|
||||||
usage();
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hexstring_a2n(*argv, mac, sizeof(mac)) == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
addattr_l(hdr, 1024, VETH_INFO_PEER_MAC,
|
|
||||||
mac, ETH_ALEN);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (strcmp(argv[0], "peer") != 0) {
|
||||||
usage();
|
usage();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
data = NLMSG_TAIL(hdr);
|
||||||
|
addattr_l(hdr, 1024, VETH_INFO_PEER, NULL, 0);
|
||||||
|
|
||||||
|
hdr->nlmsg_len += sizeof(struct ifinfomsg);
|
||||||
|
|
||||||
|
err = iplink_parse(argc - 1, argv + 1, (struct iplink_req *)hdr,
|
||||||
|
&name, &type, &link, &dev);
|
||||||
|
if (err < 0)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
if (name) {
|
||||||
|
len = strlen(name) + 1;
|
||||||
|
if (len > IFNAMSIZ)
|
||||||
|
invarg("\"name\" too long\n", *argv);
|
||||||
|
addattr_l(hdr, 1024, IFLA_IFNAME, name, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
data->rta_len = (void *)NLMSG_TAIL(hdr) - (void *)data;
|
||||||
|
return argc - 1 - err;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct link_util veth_link_util = {
|
struct link_util veth_link_util = {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue