summaryrefslogtreecommitdiffstats
path: root/sbin
diff options
context:
space:
mode:
authortruckman <truckman@FreeBSD.org>2016-05-12 05:43:54 +0000
committertruckman <truckman@FreeBSD.org>2016-05-12 05:43:54 +0000
commit157633b36942a2dce30e07cd952bfbe200393444 (patch)
treed274127edd78d096c19af96aba4052cb50f2ccf0 /sbin
parent3571021d227752c84e8467a6742a88dd30204fd0 (diff)
downloadFreeBSD-src-157633b36942a2dce30e07cd952bfbe200393444.zip
FreeBSD-src-157633b36942a2dce30e07cd952bfbe200393444.tar.gz
Check for socket creation success before calling bind().
Reported by: Coverity CID: 1194209
Diffstat (limited to 'sbin')
-rw-r--r--sbin/ping/ping.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/sbin/ping/ping.c b/sbin/ping/ping.c
index e7df6ca..db78ef6 100644
--- a/sbin/ping/ping.c
+++ b/sbin/ping/ping.c
@@ -285,6 +285,16 @@ main(int argc, char *const *argv)
err(EX_NOPERM, "setuid() failed");
uid = getuid();
+ if (ssend < 0) {
+ errno = ssend_errno;
+ err(EX_OSERR, "ssend socket");
+ }
+
+ if (srecv < 0) {
+ errno = srecv_errno;
+ err(EX_OSERR, "srecv socket");
+ }
+
alarmtimeout = df = preload = tos = 0;
outpack = outpackhdr + sizeof(struct ip);
@@ -625,16 +635,6 @@ main(int argc, char *const *argv)
}
#endif
- if (ssend < 0) {
- errno = ssend_errno;
- err(EX_OSERR, "ssend socket");
- }
-
- if (srecv < 0) {
- errno = srecv_errno;
- err(EX_OSERR, "srecv socket");
- }
-
if (connect(ssend, (struct sockaddr *)&whereto, sizeof(whereto)) != 0)
err(1, "connect");
OpenPOWER on IntegriCloud