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:
parent
43ba1b3e64
commit
5f8cfaee52
@ -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;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user