Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
P
PPSi
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
50
Issues
50
List
Board
Labels
Milestones
Merge Requests
1
Merge Requests
1
Wiki
Wiki
image/svg+xml
Discourse
Discourse
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Projects
PPSi
Commits
c1ec94a7
Commit
c1ec94a7
authored
Mar 07, 2013
by
Alessandro Rubini
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bare-socket.c: factorize error reporting
Signed-off-by:
Alessandro Rubini
<
rubini@gnudd.com
>
parent
faa6248d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
24 deletions
+18
-24
bare-socket.c
lib-bare/bare-socket.c
+18
-24
No files found.
lib-bare/bare-socket.c
View file @
c1ec94a7
...
...
@@ -50,34 +50,26 @@ static int bare_open_ch(struct pp_instance *ppi, char *ifname)
struct
bare_ifreq
ifr
;
struct
bare_sockaddr_ll
addr_ll
;
struct
bare_packet_mreq
pmr
;
char
*
context
;
if
(
OPTS
(
ppi
)
->
ethernet_mode
)
{
/* open socket */
context
=
"socket()"
;
sock
=
sys_socket
(
PF_PACKET
,
SOCK_RAW
,
ETH_P_1588
);
if
(
sock
<
0
)
{
pp_diag_error
(
ppi
,
bare_errno
);
pp_diag_error_str2
(
ppi
,
"socket()"
,
""
);
sys_close
(
sock
);
return
-
1
;
}
if
(
sock
<
0
)
goto
err_out
;
/* hw interface information */
memset
(
&
ifr
,
0
,
sizeof
(
ifr
));
strcpy
(
ifr
.
ifr_ifrn
.
ifrn_name
,
ifname
);
if
(
sys_ioctl
(
sock
,
SIOCGIFINDEX
,
&
ifr
)
<
0
)
{
pp_diag_error
(
ppi
,
bare_errno
);
pp_diag_error_str2
(
ppi
,
"ioctl(GIFINDEX)"
,
""
);
sys_close
(
sock
);
return
-
1
;
}
context
=
"ioctl(SIOCGIFINDEX)"
;
if
(
sys_ioctl
(
sock
,
SIOCGIFINDEX
,
&
ifr
)
<
0
)
goto
err_out
;
iindex
=
ifr
.
ifr_ifru
.
index
;
if
(
sys_ioctl
(
sock
,
SIOCGIFHWADDR
,
&
ifr
)
<
0
)
{
pp_diag_error
(
ppi
,
bare_errno
);
pp_diag_error_str2
(
ppi
,
"ioctl(GIFHWADDR)"
,
""
);
sys_close
(
sock
);
return
-
1
;
}
context
=
"ioctl(SIOCGIFHWADDR)"
;
if
(
sys_ioctl
(
sock
,
SIOCGIFHWADDR
,
&
ifr
)
<
0
)
goto
err_out
;
memcpy
(
NP
(
ppi
)
->
ch
[
PP_NP_GEN
].
addr
,
ifr
.
ifr_ifru
.
ifru_hwaddr
.
sa_data
,
6
);
...
...
@@ -89,13 +81,10 @@ static int bare_open_ch(struct pp_instance *ppi, char *ifname)
addr_ll
.
sll_family
=
PF_PACKET
;
addr_ll
.
sll_protocol
=
htons
(
ETH_P_1588
);
addr_ll
.
sll_ifindex
=
iindex
;
context
=
"bind()"
;
if
(
sys_bind
(
sock
,
(
struct
bare_sockaddr
*
)
&
addr_ll
,
sizeof
(
addr_ll
))
<
0
)
{
pp_diag_error
(
ppi
,
bare_errno
);
pp_diag_error_str2
(
ppi
,
"bind"
,
""
);
sys_close
(
sock
);
return
-
1
;
}
sizeof
(
addr_ll
))
<
0
)
goto
err_out
;
/* accept the multicast address for raw-ethernet ptp */
memset
(
&
pmr
,
0
,
sizeof
(
pmr
));
...
...
@@ -115,6 +104,11 @@ static int bare_open_ch(struct pp_instance *ppi, char *ifname)
return
0
;
}
err_out:
pp_printf
(
"%s: %s: fatal error, errno = %i
\n
"
,
__func__
,
context
,
bare_errno
);
if
(
sock
>=
0
)
sys_close
(
sock
);
return
-
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