Make ping6(1) return code consistent with the man page.

When every sendto() call originated by ping6(1) fails, current code always
 returns 2 ("transmission was successful but no responses were received")
 which is incorrect. Return EX_OSERR instead as in many cases it indicates
 some kernel-level problems.

MFC after:	3 weeks
This commit is contained in:
Alexander V. Chernikov 2020-02-15 15:39:53 +00:00
parent 074ad60a4c
commit af14123601

View File

@ -238,6 +238,7 @@ static long npackets; /* max packets to transmit */
static long nreceived; /* # of packets we got back */
static long nrepeats; /* number of duplicates */
static long ntransmitted; /* sequence # for outbound packets = #sent */
static long ntransmitfailures; /* number of transmit failures */
static int interval = 1000; /* interval between packets in ms */
static int waittime = MAXWAIT; /* timeout for each packet */
static long nrcvtimeout = 0; /* # of packets we got back after waittime */
@ -1256,7 +1257,12 @@ main(int argc, char *argv[])
if(packet != NULL)
free(packet);
exit(nreceived == 0 ? 2 : 0);
if (nreceived > 0)
exit(0);
else if (ntransmitted > ntransmitfailures)
exit(2);
else
exit(EX_OSERR);
}
static void
@ -1423,8 +1429,10 @@ pinger(void)
i = sendmsg(ssend, &smsghdr, 0);
if (i < 0 || i != cc) {
if (i < 0)
if (i < 0) {
ntransmitfailures++;
warn("sendmsg");
}
(void)printf("ping6: wrote %s %d chars, ret=%d\n",
hostname, cc, i);
}