|
@@ -212,10 +212,13 @@ static struct ip6_tnl *vti6_tnl_create(struct net *net, struct __ip6_tnl_parm *p
|
|
char name[IFNAMSIZ];
|
|
char name[IFNAMSIZ];
|
|
int err;
|
|
int err;
|
|
|
|
|
|
- if (p->name[0])
|
|
|
|
|
|
+ if (p->name[0]) {
|
|
|
|
+ if (!dev_valid_name(p->name))
|
|
|
|
+ goto failed;
|
|
strlcpy(name, p->name, IFNAMSIZ);
|
|
strlcpy(name, p->name, IFNAMSIZ);
|
|
- else
|
|
|
|
|
|
+ } else {
|
|
sprintf(name, "ip6_vti%%d");
|
|
sprintf(name, "ip6_vti%%d");
|
|
|
|
+ }
|
|
|
|
|
|
dev = alloc_netdev(sizeof(*t), name, NET_NAME_UNKNOWN, vti6_dev_setup);
|
|
dev = alloc_netdev(sizeof(*t), name, NET_NAME_UNKNOWN, vti6_dev_setup);
|
|
if (!dev)
|
|
if (!dev)
|