/* wait arp reply, and check it */
tm.tv_usec = 0;
- prevTime = time(NULL);
+ prevTime = uptime();
while (timeout > 0) {
FD_ZERO(&fdset);
FD_SET(s, &fdset);
break;
}
}
- timeout -= time(NULL) - prevTime;
- prevTime = time(NULL);
+ timeout -= uptime() - prevTime;
+ prevTime = uptime();
}
close(s);
DEBUG(LOG_INFO, "%salid arp replies for this address", rv ? "No v" : "V");
static int daemonized;
+long uptime(void)
+{
+ struct sysinfo info;
+ sysinfo(&info);
+ return info.uptime;
+}
+
+
/*
* This function makes sure our first socket calls
* aren't going to fd 1 (printf badness...) and are
#include <syslog.h>
#endif
+long uptime(void);
void background(const char *pidfile);
void start_log_and_pid(const char *client_server, const char *pidfile);
void background(const char *pidfile);
for (;;) {
- tv.tv_sec = timeout - time(NULL);
+ tv.tv_sec = timeout - uptime();
tv.tv_usec = 0;
if (listen_mode != LISTEN_NONE && fd < 0) {
retval = select(max_fd + 1, &rfds, NULL, NULL, &tv);
} else retval = 0; /* If we already timed out, fall through */
- now = time(NULL);
+ now = uptime();
if (retval == 0) {
/* timeout dropped to zero */
switch (state) {