1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-11 09:18:07 +03:00

timesync: always initialize structs when declaring them as far as possible with contsant values

This commit is contained in:
Lennart Poettering 2014-05-05 21:47:09 +02:00
parent 43ba1b3e64
commit 5f8cfaee52

View File

@ -37,6 +37,7 @@
#include "util.h" #include "util.h"
#include "sparse-endian.h" #include "sparse-endian.h"
#include "log.h" #include "log.h"
#include "socket-util.h"
#include "sd-event.h" #include "sd-event.h"
#include "sd-daemon.h" #include "sd-daemon.h"
@ -111,7 +112,7 @@ struct Manager {
/* peer */ /* peer */
sd_event_source *event_receive; sd_event_source *event_receive;
char *server; char *server;
struct sockaddr_in server_addr; union sockaddr_union server_addr;
int server_socket; int server_socket;
uint64_t packet_count; uint64_t packet_count;
@ -168,19 +169,24 @@ static double square(double d) {
} }
static int sntp_send_request(Manager *m) { static int sntp_send_request(Manager *m) {
struct ntp_msg ntpmsg = {}; struct ntp_msg ntpmsg = {
struct sockaddr_in addr = {}; /*
* "The client initializes the NTP message header, sends the request
* to the server, and strips the time of day from the Transmit
* Timestamp field of the reply. For this purpose, all the NTP
* header fields are set to 0, except the Mode, VN, and optional
* Transmit Timestamp fields."
*/
.field = NTP_FIELD(0, 4, NTP_MODE_CLIENT),
};
union sockaddr_union addr = {
.in.sin_family = AF_INET,
.in.sin_port = htobe16(123),
};
ssize_t len; ssize_t len;
int r; int r;
/*
* "The client initializes the NTP message header, sends the request
* to the server, and strips the time of day from the Transmit
* Timestamp field of the reply. For this purpose, all the NTP
* header fields are set to 0, except the Mode, VN, and optional
* Transmit Timestamp fields."
*/
ntpmsg.field = NTP_FIELD(0, 4, NTP_MODE_CLIENT);
/* /*
* Set transmit timestamp, remember it; the server will send that back * Set transmit timestamp, remember it; the server will send that back
@ -195,10 +201,8 @@ static int sntp_send_request(Manager *m) {
ntpmsg.trans_time.sec = htobe32(m->trans_time.tv_sec + OFFSET_1900_1970); ntpmsg.trans_time.sec = htobe32(m->trans_time.tv_sec + OFFSET_1900_1970);
ntpmsg.trans_time.frac = htobe32(m->trans_time.tv_nsec); ntpmsg.trans_time.frac = htobe32(m->trans_time.tv_nsec);
addr.sin_family = AF_INET; addr.in.sin_addr.s_addr = inet_addr(m->server);
addr.sin_port = htobe16(123); len = sendto(m->server_socket, &ntpmsg, sizeof(ntpmsg), MSG_DONTWAIT, &addr.sa, sizeof(addr.in));
addr.sin_addr.s_addr = inet_addr(m->server);
len = sendto(m->server_socket, &ntpmsg, sizeof(ntpmsg), MSG_DONTWAIT, &addr, sizeof(addr));
if (len == sizeof(ntpmsg)) { if (len == sizeof(ntpmsg)) {
m->pending = true; m->pending = true;
log_debug("Sent NTP request to: %s", m->server); log_debug("Sent NTP request to: %s", m->server);
@ -283,7 +287,11 @@ static int sntp_clock_watch(sd_event_source *source, int fd, uint32_t revents, v
/* wake up when the system time changes underneath us */ /* wake up when the system time changes underneath us */
static int sntp_clock_watch_setup(Manager *m) { static int sntp_clock_watch_setup(Manager *m) {
struct itimerspec its = { .it_value.tv_sec = TIME_T_MAX };
struct itimerspec its = {
.it_value.tv_sec = TIME_T_MAX
};
_cleanup_close_ int fd = -1; _cleanup_close_ int fd = -1;
sd_event_source *source; sd_event_source *source;
int r; int r;
@ -472,7 +480,7 @@ static int sntp_receive_response(sd_event_source *source, int fd, uint32_t reven
struct cmsghdr cmsghdr; struct cmsghdr cmsghdr;
uint8_t buf[CMSG_SPACE(sizeof(struct timeval))]; uint8_t buf[CMSG_SPACE(sizeof(struct timeval))];
} control; } control;
struct sockaddr_in server_addr; union sockaddr_union server_addr;
struct msghdr msghdr = { struct msghdr msghdr = {
.msg_iov = &iov, .msg_iov = &iov,
.msg_iovlen = 1, .msg_iovlen = 1,
@ -509,7 +517,7 @@ static int sntp_receive_response(sd_event_source *source, int fd, uint32_t reven
return -EINVAL; return -EINVAL;
} }
if (m->server_addr.sin_addr.s_addr != server_addr.sin_addr.s_addr) { if (m->server_addr.in.sin_addr.s_addr != server_addr.in.sin_addr.s_addr) {
log_debug("Response from unknown server. Disconnecting."); log_debug("Response from unknown server. Disconnecting.");
return -EINVAL; return -EINVAL;
} }
@ -657,8 +665,8 @@ static int sntp_server_connect(Manager *m, const char *server) {
s = NULL; s = NULL;
zero(m->server_addr); zero(m->server_addr);
m->server_addr.sin_family = AF_INET; m->server_addr.in.sin_family = AF_INET;
m->server_addr.sin_addr.s_addr = inet_addr(server); m->server_addr.in.sin_addr.s_addr = inet_addr(server);
m->poll_interval_usec = NTP_POLL_INTERVAL_MIN_SEC * USEC_PER_SEC; m->poll_interval_usec = NTP_POLL_INTERVAL_MIN_SEC * USEC_PER_SEC;
@ -687,8 +695,12 @@ static void sntp_server_disconnect(Manager *m) {
} }
static int sntp_listen_setup(Manager *m) { static int sntp_listen_setup(Manager *m) {
union sockaddr_union addr = {
.in.sin_family = AF_INET,
};
_cleanup_close_ int fd = -1; _cleanup_close_ int fd = -1;
struct sockaddr_in addr;
const int on = 1; const int on = 1;
const int tos = IPTOS_LOWDELAY; const int tos = IPTOS_LOWDELAY;
int r; int r;
@ -697,9 +709,7 @@ static int sntp_listen_setup(Manager *m) {
if (fd < 0) if (fd < 0)
return -errno; return -errno;
zero(addr); r = bind(fd, &addr.sa, sizeof(addr.in));
addr.sin_family = AF_INET;
r = bind(fd, (struct sockaddr *)&addr, sizeof(addr));
if (r < 0) if (r < 0)
return -errno; return -errno;