Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
a937e1e4
Commit
a937e1e4
authored
Jan 13, 2004
by
Stephen Hemminger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[NET]: Add SIOCSIGNAME wildcarding and name validation, with help from Jean Tourrilhes.
parent
424e8db5
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
57 additions
and
14 deletions
+57
-14
net/core/dev.c
net/core/dev.c
+57
-14
No files found.
net/core/dev.c
View file @
a937e1e4
...
@@ -620,6 +620,21 @@ struct net_device *__dev_get_by_flags(unsigned short if_flags, unsigned short ma
...
@@ -620,6 +620,21 @@ struct net_device *__dev_get_by_flags(unsigned short if_flags, unsigned short ma
return
NULL
;
return
NULL
;
}
}
/**
* dev_valid_name - check if name is okay for network device
* @name: name string
*
* Network device names need to be valid file names to
* to allow sysfs to work
*/
int
dev_valid_name
(
const
char
*
name
)
{
return
!
(
*
name
==
'\0'
||
!
strcmp
(
name
,
"."
)
||
!
strcmp
(
name
,
".."
)
||
strchr
(
name
,
'/'
));
}
/**
/**
* dev_alloc_name - allocate a name for a device
* dev_alloc_name - allocate a name for a device
* @dev: device
* @dev: device
...
@@ -660,6 +675,41 @@ int dev_alloc_name(struct net_device *dev, const char *name)
...
@@ -660,6 +675,41 @@ int dev_alloc_name(struct net_device *dev, const char *name)
return
-
ENFILE
;
/* Over 100 of the things .. bail out! */
return
-
ENFILE
;
/* Over 100 of the things .. bail out! */
}
}
/**
* dev_change_name - change name of a device
* @dev: device
* @name: name (or format string) must be at least IFNAMSIZ
*
* Change name of a device, can pass format strings "eth%d".
* for wildcarding.
*/
int
dev_change_name
(
struct
net_device
*
dev
,
char
*
newname
)
{
ASSERT_RTNL
();
if
(
dev
->
flags
&
IFF_UP
)
return
-
EBUSY
;
if
(
!
dev_valid_name
(
newname
))
return
-
EINVAL
;
if
(
strchr
(
newname
,
'%'
))
{
int
err
=
dev_alloc_name
(
dev
,
newname
);
if
(
err
)
return
err
;
strcpy
(
newname
,
dev
->
name
);
}
else
if
(
__dev_get_by_name
(
newname
))
return
-
EEXIST
;
else
strlcpy
(
dev
->
name
,
newname
,
IFNAMSIZ
);
class_device_rename
(
&
dev
->
class_dev
,
dev
->
name
);
notifier_call_chain
(
&
netdev_chain
,
NETDEV_CHANGENAME
,
dev
);
return
0
;
}
/**
/**
* dev_alloc - allocate a network device and name
* dev_alloc - allocate a network device and name
* @name: name format string
* @name: name format string
...
@@ -2341,20 +2391,8 @@ static int dev_ifsioc(struct ifreq *ifr, unsigned int cmd)
...
@@ -2341,20 +2391,8 @@ static int dev_ifsioc(struct ifreq *ifr, unsigned int cmd)
return
0
;
return
0
;
case
SIOCSIFNAME
:
case
SIOCSIFNAME
:
if
(
dev
->
flags
&
IFF_UP
)
return
-
EBUSY
;
ifr
->
ifr_newname
[
IFNAMSIZ
-
1
]
=
'\0'
;
ifr
->
ifr_newname
[
IFNAMSIZ
-
1
]
=
'\0'
;
if
(
__dev_get_by_name
(
ifr
->
ifr_newname
))
return
dev_change_name
(
dev
,
ifr
->
ifr_newname
);
return
-
EEXIST
;
err
=
class_device_rename
(
&
dev
->
class_dev
,
ifr
->
ifr_newname
);
if
(
!
err
)
{
strlcpy
(
dev
->
name
,
ifr
->
ifr_newname
,
IFNAMSIZ
);
notifier_call_chain
(
&
netdev_chain
,
NETDEV_CHANGENAME
,
dev
);
}
return
err
;
/*
/*
* Unknown or private ioctl
* Unknown or private ioctl
...
@@ -2487,6 +2525,7 @@ int dev_ioctl(unsigned int cmd, void *arg)
...
@@ -2487,6 +2525,7 @@ int dev_ioctl(unsigned int cmd, void *arg)
*/
*/
case
SIOCGMIIPHY
:
case
SIOCGMIIPHY
:
case
SIOCGMIIREG
:
case
SIOCGMIIREG
:
case
SIOCSIFNAME
:
if
(
!
capable
(
CAP_NET_ADMIN
))
if
(
!
capable
(
CAP_NET_ADMIN
))
return
-
EPERM
;
return
-
EPERM
;
dev_load
(
ifr
.
ifr_name
);
dev_load
(
ifr
.
ifr_name
);
...
@@ -2518,7 +2557,6 @@ int dev_ioctl(unsigned int cmd, void *arg)
...
@@ -2518,7 +2557,6 @@ int dev_ioctl(unsigned int cmd, void *arg)
case
SIOCDELMULTI
:
case
SIOCDELMULTI
:
case
SIOCSIFHWBROADCAST
:
case
SIOCSIFHWBROADCAST
:
case
SIOCSIFTXQLEN
:
case
SIOCSIFTXQLEN
:
case
SIOCSIFNAME
:
case
SIOCSMIIREG
:
case
SIOCSMIIREG
:
case
SIOCBONDENSLAVE
:
case
SIOCBONDENSLAVE
:
case
SIOCBONDRELEASE
:
case
SIOCBONDRELEASE
:
...
@@ -2668,6 +2706,11 @@ int register_netdevice(struct net_device *dev)
...
@@ -2668,6 +2706,11 @@ int register_netdevice(struct net_device *dev)
goto
out_err
;
goto
out_err
;
}
}
}
}
if
(
!
dev_valid_name
(
dev
->
name
))
{
ret
=
-
EINVAL
;
goto
out_err
;
}
dev
->
ifindex
=
dev_new_index
();
dev
->
ifindex
=
dev_new_index
();
if
(
dev
->
iflink
==
-
1
)
if
(
dev
->
iflink
==
-
1
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment