Merge branch 'net-next'
This commit is contained in:
commit
cd63507430
|
|
@ -92,11 +92,12 @@ struct can_ctrlmode {
|
|||
};
|
||||
|
||||
#define CAN_CTRLMODE_LOOPBACK 0x01 /* Loopback mode */
|
||||
#define CAN_CTRLMODE_LISTENONLY 0x02 /* Listen-only mode */
|
||||
#define CAN_CTRLMODE_LISTENONLY 0x02 /* Listen-only mode */
|
||||
#define CAN_CTRLMODE_3_SAMPLES 0x04 /* Triple sampling mode */
|
||||
#define CAN_CTRLMODE_ONE_SHOT 0x08 /* One-Shot mode */
|
||||
#define CAN_CTRLMODE_BERR_REPORTING 0x10 /* Bus-error reporting */
|
||||
#define CAN_CTRLMODE_FD 0x20 /* CAN FD mode */
|
||||
#define CAN_CTRLMODE_PRESUME_ACK 0x40 /* Ignore missing CAN ACKs */
|
||||
|
||||
/*
|
||||
* CAN device statistics
|
||||
|
|
|
|||
|
|
@ -202,11 +202,17 @@ enum {
|
|||
IFLA_INET6_CACHEINFO, /* time values and max reasm size */
|
||||
IFLA_INET6_ICMP6STATS, /* statistics (icmpv6) */
|
||||
IFLA_INET6_TOKEN, /* device token */
|
||||
IFLA_INET6_ADDR_GEN_MODE, /* implicit address generator mode */
|
||||
__IFLA_INET6_MAX
|
||||
};
|
||||
|
||||
#define IFLA_INET6_MAX (__IFLA_INET6_MAX - 1)
|
||||
|
||||
enum in6_addr_gen_mode {
|
||||
IN6_ADDR_GEN_MODE_EUI64,
|
||||
IN6_ADDR_GEN_MODE_NONE,
|
||||
};
|
||||
|
||||
enum {
|
||||
BRIDGE_MODE_UNSPEC,
|
||||
BRIDGE_MODE_HAIRPIN,
|
||||
|
|
|
|||
|
|
@ -37,6 +37,12 @@
|
|||
#define INIT_NETDEV_GROUP 0
|
||||
|
||||
|
||||
/* interface name assignment types (sysfs name_assign_type attribute) */
|
||||
#define NET_NAME_UNKNOWN 0 /* unknown origin (not exposed to userspace) */
|
||||
#define NET_NAME_ENUM 1 /* enumerated by kernel */
|
||||
#define NET_NAME_PREDICTABLE 2 /* predictably named by the kernel */
|
||||
#define NET_NAME_USER 3 /* provided by user-space */
|
||||
#define NET_NAME_RENAMED 4 /* renamed by user-space */
|
||||
|
||||
/* Media selection options. */
|
||||
enum {
|
||||
|
|
|
|||
22
ip/iplink.c
22
ip/iplink.c
|
|
@ -81,6 +81,7 @@ void iplink_usage(void)
|
|||
fprintf(stderr, " [ state { auto | enable | disable} ] ]\n");
|
||||
fprintf(stderr, " [ master DEVICE ]\n");
|
||||
fprintf(stderr, " [ nomaster ]\n");
|
||||
fprintf(stderr, " [ addrgenmode { eui64 | none } ]\n");
|
||||
fprintf(stderr, " ip link show [ DEVICE | group GROUP ] [up]\n");
|
||||
|
||||
if (iplink_have_newlink()) {
|
||||
|
|
@ -161,6 +162,15 @@ static int get_link_mode(const char *mode)
|
|||
return -1;
|
||||
}
|
||||
|
||||
static int get_addr_gen_mode(const char *mode)
|
||||
{
|
||||
if (strcasecmp(mode, "eui64") == 0)
|
||||
return IN6_ADDR_GEN_MODE_EUI64;
|
||||
if (strcasecmp(mode, "none") == 0)
|
||||
return IN6_ADDR_GEN_MODE_NONE;
|
||||
return -1;
|
||||
}
|
||||
|
||||
#if IPLINK_IOCTL_COMPAT
|
||||
static int have_rtnl_newlink = -1;
|
||||
|
||||
|
|
@ -561,6 +571,18 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req,
|
|||
invarg("Invalid \"numrxqueues\" value\n", *argv);
|
||||
addattr_l(&req->n, sizeof(*req), IFLA_NUM_RX_QUEUES,
|
||||
&numrxqueues, 4);
|
||||
} else if (matches(*argv, "addrgenmode") == 0) {
|
||||
struct rtattr *afs, *afs6;
|
||||
int mode;
|
||||
NEXT_ARG();
|
||||
mode = get_addr_gen_mode(*argv);
|
||||
if (mode < 0)
|
||||
invarg("Invalid address generation mode\n", *argv);
|
||||
afs = addattr_nest(&req->n, sizeof(*req), IFLA_AF_SPEC);
|
||||
afs6 = addattr_nest(&req->n, sizeof(*req), AF_INET6);
|
||||
addattr8(&req->n, sizeof(*req), IFLA_INET6_ADDR_GEN_MODE, mode);
|
||||
addattr_nest_end(&req->n, afs6);
|
||||
addattr_nest_end(&req->n, afs);
|
||||
} else {
|
||||
if (strcmp(*argv, "dev") == 0) {
|
||||
NEXT_ARG();
|
||||
|
|
|
|||
Loading…
Reference in New Issue