diff options
author | shin <shin@FreeBSD.org> | 1999-12-28 05:37:39 +0000 |
---|---|---|
committer | shin <shin@FreeBSD.org> | 1999-12-28 05:37:39 +0000 |
commit | 21448b46272429cd4260638c31ec239118e6fb02 (patch) | |
tree | 3761183d74afd9038bbe0f1e1a64339ed76d2fcc /sbin | |
parent | 8b8214b6d3bce6e64a982ab67d5d17dfa3f85b0b (diff) | |
download | FreeBSD-src-21448b46272429cd4260638c31ec239118e6fb02.zip FreeBSD-src-21448b46272429cd4260638c31ec239118e6fb02.tar.gz |
Small bug fix and improvements
(1)added error check of if_nameindex() return value at getaddrinfo().
(2)print out more detailed information when getaddrinfo() error value
is EAI_SYSTEM.(in this case system error num is kept in errno)
(1) is Discovered by: jinmei@kame.net in KAME environment.
Diffstat (limited to 'sbin')
-rw-r--r-- | sbin/ping6/ping6.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/sbin/ping6/ping6.c b/sbin/ping6/ping6.c index d118655..34de2bd 100644 --- a/sbin/ping6/ping6.c +++ b/sbin/ping6/ping6.c @@ -434,6 +434,8 @@ main(argc, argv) ret_ga = getaddrinfo(target, NULL, &hints, &res); if (ret_ga) { fprintf(stderr, "ping6: %s\n", gai_strerror(ret_ga)); + if (ret_ga == EAI_SYSTEM) + errx(1, "%s", strerror(errno)); exit(1); } if (res->ai_canonname) @@ -586,8 +588,12 @@ main(argc, argv) for (hops = 0; hops < argc - 1; hops++) { struct addrinfo *iaip; - if ((error = getaddrinfo(argv[hops], NULL, &hints, &iaip))) - errx(1, gai_strerror(error)); + if ((error = getaddrinfo(argv[hops], NULL, &hints, &iaip))) { + fprintf(stderr, "ping6: %s\n", gai_strerror(error)); + if (error == EAI_SYSTEM) + errx(1, strerror(errno)); + exit(1); + } if (SIN6(res->ai_addr)->sin6_family != AF_INET6) errx(1, "bad addr family of an intermediate addr"); |