Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
C
criu
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zhul
criu
Commits
8df4d676
Commit
8df4d676
authored
Dec 26, 2013
by
Pavel Emelyanov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
net: Factor out empty-kind devices checking
Signed-off-by:
Pavel Emelyanov
<
xemul@parallels.com
>
parent
d5790de6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
31 deletions
+18
-31
net.c
net.c
+18
-31
No files found.
net.c
View file @
8df4d676
...
@@ -100,15 +100,9 @@ static char *link_kind(struct ifinfomsg *ifi, struct rtattr **tb)
...
@@ -100,15 +100,9 @@ static char *link_kind(struct ifinfomsg *ifi, struct rtattr **tb)
return
RTA_DATA
(
linkinfo
[
IFLA_INFO_KIND
]);
return
RTA_DATA
(
linkinfo
[
IFLA_INFO_KIND
]);
}
}
static
int
dump_one_ethernet
(
struct
ifinfomsg
*
ifi
,
static
int
dump_one_ethernet
(
struct
ifinfomsg
*
ifi
,
char
*
kind
,
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
{
{
char
*
kind
;
kind
=
link_kind
(
ifi
,
tb
);
if
(
!
kind
)
goto
unk
;
if
(
!
strcmp
(
kind
,
"veth"
))
if
(
!
strcmp
(
kind
,
"veth"
))
/*
/*
* This is not correct. The peer of the veth device may
* This is not correct. The peer of the veth device may
...
@@ -121,37 +115,24 @@ static int dump_one_ethernet(struct ifinfomsg *ifi,
...
@@ -121,37 +115,24 @@ static int dump_one_ethernet(struct ifinfomsg *ifi,
return
dump_one_netdev
(
ND_TYPE__VETH
,
ifi
,
tb
,
fds
,
NULL
);
return
dump_one_netdev
(
ND_TYPE__VETH
,
ifi
,
tb
,
fds
,
NULL
);
if
(
!
strcmp
(
kind
,
"tun"
))
if
(
!
strcmp
(
kind
,
"tun"
))
return
dump_one_netdev
(
ND_TYPE__TUN
,
ifi
,
tb
,
fds
,
dump_tun_link
);
return
dump_one_netdev
(
ND_TYPE__TUN
,
ifi
,
tb
,
fds
,
dump_tun_link
);
unk:
pr_err
(
"Unknown eth kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
pr_err
(
"Unknown eth kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
return
-
1
;
return
-
1
;
}
}
static
int
dump_one_gendev
(
struct
ifinfomsg
*
ifi
,
static
int
dump_one_gendev
(
struct
ifinfomsg
*
ifi
,
char
*
kind
,
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
{
{
char
*
kind
;
kind
=
link_kind
(
ifi
,
tb
);
if
(
!
kind
)
goto
unk
;
if
(
!
strcmp
(
kind
,
"tun"
))
if
(
!
strcmp
(
kind
,
"tun"
))
return
dump_one_netdev
(
ND_TYPE__TUN
,
ifi
,
tb
,
fds
,
dump_tun_link
);
return
dump_one_netdev
(
ND_TYPE__TUN
,
ifi
,
tb
,
fds
,
dump_tun_link
);
unk:
pr_err
(
"Unknown ARPHRD_NONE kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
pr_err
(
"Unknown ARPHRD_NONE kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
return
-
1
;
return
-
1
;
}
}
static
int
dump_one_voiddev
(
struct
ifinfomsg
*
ifi
,
static
int
dump_one_voiddev
(
struct
ifinfomsg
*
ifi
,
char
*
kind
,
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
struct
rtattr
**
tb
,
struct
cr_fdset
*
fds
)
{
{
char
*
kind
;
kind
=
link_kind
(
ifi
,
tb
);
if
(
!
kind
)
goto
unk
;
if
(
!
strcmp
(
kind
,
"venet"
))
if
(
!
strcmp
(
kind
,
"venet"
))
/*
/*
* If we meet a link we know about, such as
* If we meet a link we know about, such as
...
@@ -160,7 +141,6 @@ static int dump_one_voiddev(struct ifinfomsg *ifi,
...
@@ -160,7 +141,6 @@ static int dump_one_voiddev(struct ifinfomsg *ifi,
*/
*/
return
dump_one_netdev
(
ND_TYPE__EXTLINK
,
ifi
,
tb
,
fds
,
NULL
);
return
dump_one_netdev
(
ND_TYPE__EXTLINK
,
ifi
,
tb
,
fds
,
NULL
);
unk:
pr_err
(
"Unknown VOID kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
pr_err
(
"Unknown VOID kind %s link %d
\n
"
,
kind
,
ifi
->
ifi_index
);
return
-
1
;
return
-
1
;
}
}
...
@@ -171,6 +151,7 @@ static int dump_one_link(struct nlmsghdr *hdr, void *arg)
...
@@ -171,6 +151,7 @@ static int dump_one_link(struct nlmsghdr *hdr, void *arg)
struct
ifinfomsg
*
ifi
;
struct
ifinfomsg
*
ifi
;
int
ret
=
0
,
len
=
hdr
->
nlmsg_len
-
NLMSG_LENGTH
(
sizeof
(
*
ifi
));
int
ret
=
0
,
len
=
hdr
->
nlmsg_len
-
NLMSG_LENGTH
(
sizeof
(
*
ifi
));
struct
rtattr
*
tb
[
IFLA_MAX
+
1
];
struct
rtattr
*
tb
[
IFLA_MAX
+
1
];
char
*
kind
;
ifi
=
NLMSG_DATA
(
hdr
);
ifi
=
NLMSG_DATA
(
hdr
);
...
@@ -180,21 +161,27 @@ static int dump_one_link(struct nlmsghdr *hdr, void *arg)
...
@@ -180,21 +161,27 @@ static int dump_one_link(struct nlmsghdr *hdr, void *arg)
}
}
parse_rtattr
(
tb
,
IFLA_MAX
,
IFLA_RTA
(
ifi
),
len
);
parse_rtattr
(
tb
,
IFLA_MAX
,
IFLA_RTA
(
ifi
),
len
);
pr_info
(
"
\t
LD: Got link %d, type %d
\n
"
,
ifi
->
ifi_index
,
ifi
->
ifi_type
);
pr_info
(
"
\t
LD: Got link %d, type %d
\n
"
,
ifi
->
ifi_index
,
ifi
->
ifi_type
);
if
(
ifi
->
ifi_type
==
ARPHRD_LOOPBACK
)
return
dump_one_netdev
(
ND_TYPE__LOOPBACK
,
ifi
,
tb
,
fds
,
NULL
);
kind
=
link_kind
(
ifi
,
tb
);
if
(
!
kind
)
{
pr_err
(
"Empty kind dev type %d link %d
\n
"
,
ifi
->
ifi_type
,
ifi
->
ifi_index
);
return
-
1
;
}
switch
(
ifi
->
ifi_type
)
{
switch
(
ifi
->
ifi_type
)
{
case
ARPHRD_LOOPBACK
:
ret
=
dump_one_netdev
(
ND_TYPE__LOOPBACK
,
ifi
,
tb
,
fds
,
NULL
);
break
;
case
ARPHRD_ETHER
:
case
ARPHRD_ETHER
:
ret
=
dump_one_ethernet
(
ifi
,
tb
,
fds
);
ret
=
dump_one_ethernet
(
ifi
,
kind
,
tb
,
fds
);
break
;
break
;
case
ARPHRD_NONE
:
case
ARPHRD_NONE
:
ret
=
dump_one_gendev
(
ifi
,
tb
,
fds
);
ret
=
dump_one_gendev
(
ifi
,
kind
,
tb
,
fds
);
break
;
break
;
case
ARPHRD_VOID
:
case
ARPHRD_VOID
:
ret
=
dump_one_voiddev
(
ifi
,
tb
,
fds
);
ret
=
dump_one_voiddev
(
ifi
,
kind
,
tb
,
fds
);
break
;
break
;
default:
default:
pr_err
(
"Unsupported link type %d, kind %s
\n
"
,
pr_err
(
"Unsupported link type %d, kind %s
\n
"
,
...
...
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