X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fmdnsd.git;a=blobdiff_plain;f=util.c;h=63f1612fdb2c935887de2d0bdd2953ae5d630a40;hp=87db94c6ee67652fb56babb5aa358c3644b9f68d;hb=c0c78c92d57c53276bb7f08468bcc716ba272497;hpb=cef25024bc6d3948d1e4a164d82a63fa21414912 diff --git a/util.c b/util.c index 87db94c..63f1612 100644 --- a/util.c +++ b/util.c @@ -16,8 +16,6 @@ #include #include #include -#include -#include #include #include @@ -29,6 +27,7 @@ #include #include +#include #include "dns.h" #include "util.h" @@ -36,19 +35,8 @@ uint8_t mdns_buf[MDNS_BUF_LEN]; int debug = 0; -static void -signal_shutdown(int signal) -{ - uloop_end(); -} - -void -signal_setup(void) -{ - signal(SIGPIPE, SIG_IGN); - signal(SIGTERM, signal_shutdown); - signal(SIGKILL, signal_shutdown); -} +char mdns_hostname[HOSTNAME_LEN]; +char mdns_hostname_local[HOSTNAME_LEN + 6]; uint32_t rand_time_delta(uint32_t t) @@ -73,24 +61,23 @@ rand_time_delta(uint32_t t) return val; } -char* -get_hostname(void) +void get_hostname(void) { - static struct utsname utsname; + struct utsname utsname; + + mdns_hostname[0] = 0; + mdns_hostname_local[0] = 0; if (uname(&utsname) < 0) - return NULL; + return; - return utsname.nodename; + snprintf(mdns_hostname, sizeof(mdns_hostname), "%s", utsname.nodename); + snprintf(mdns_hostname_local, sizeof(mdns_hostname_local), "%s.local", utsname.nodename); } -void* -memdup(const void *d, int l) +time_t monotonic_time(void) { - void *r = malloc(l); - if (!r) - return NULL; - memcpy(r, d, l); - return r; + struct timespec ts; + clock_gettime(CLOCK_MONOTONIC, &ts); + return ts.tv_sec; } -