|
|
- From 3537c0e956f9f67085fa9e76f303689df8753d2e Mon Sep 17 00:00:00 2001
- From: Brent Cook <busterb@gmail.com>
- Date: Tue, 30 Dec 2014 09:02:50 -0600
- Subject: [PATCH 04/13] conditionally fill in sin_len/sin6_len if they exist
-
- ---
- src/usr.sbin/ntpd/config.c | 8 ++++++++
- 1 file changed, 8 insertions(+)
-
- diff --git a/src/usr.sbin/ntpd/config.c b/src/usr.sbin/ntpd/config.c
- index 8c1baa2..2e39604 100644
- --- a/src/usr.sbin/ntpd/config.c
- +++ b/src/usr.sbin/ntpd/config.c
- @@ -72,7 +72,9 @@ host_v4(const char *s)
- if ((h = calloc(1, sizeof(struct ntp_addr))) == NULL)
- fatal(NULL);
- sa_in = (struct sockaddr_in *)&h->ss;
- +#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
- sa_in->sin_len = sizeof(struct sockaddr_in);
- +#endif
- sa_in->sin_family = AF_INET;
- sa_in->sin_addr.s_addr = ina.s_addr;
-
- @@ -94,7 +96,9 @@ host_v6(const char *s)
- if ((h = calloc(1, sizeof(struct ntp_addr))) == NULL)
- fatal(NULL);
- sa_in6 = (struct sockaddr_in6 *)&h->ss;
- +#ifdef SIN6_LEN
- sa_in6->sin6_len = sizeof(struct sockaddr_in6);
- +#endif
- sa_in6->sin6_family = AF_INET6;
- memcpy(&sa_in6->sin6_addr,
- &((struct sockaddr_in6 *)res->ai_addr)->sin6_addr,
- @@ -156,12 +160,16 @@ host_dns(const char *s, struct ntp_addr **hn)
- h->ss.ss_family = res->ai_family;
- if (res->ai_family == AF_INET) {
- sa_in = (struct sockaddr_in *)&h->ss;
- +#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
- sa_in->sin_len = sizeof(struct sockaddr_in);
- +#endif
- sa_in->sin_addr.s_addr = ((struct sockaddr_in *)
- res->ai_addr)->sin_addr.s_addr;
- } else {
- sa_in6 = (struct sockaddr_in6 *)&h->ss;
- +#ifdef SIN6_LEN
- sa_in6->sin6_len = sizeof(struct sockaddr_in6);
- +#endif
- memcpy(&sa_in6->sin6_addr, &((struct sockaddr_in6 *)
- res->ai_addr)->sin6_addr, sizeof(struct in6_addr));
- }
- --
- 2.4.5
-
|