X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Ftimedate%2Ftimedated.c;h=f5d2201cea6fb31687fa26da222f3ebd178e0d95;hp=48c6a132e7919bef7d96d527bd819124abd8043a;hb=9f6eb1cd58f2ddf2eb6ba0e4de056e13d938af75;hpb=03cc26dda4cb59207fea3dd4fd1fa4608746739c diff --git a/src/timedate/timedated.c b/src/timedate/timedated.c index 48c6a132e..f5d2201ce 100644 --- a/src/timedate/timedated.c +++ b/src/timedate/timedated.c @@ -45,8 +45,8 @@ typedef struct Context { char *zone; bool local_rtc; - int can_ntp; - int use_ntp; + unsigned can_ntp; + unsigned use_ntp; Hashmap *polkit_registry; } Context; @@ -63,7 +63,7 @@ static void context_reset(Context *c) { static void context_free(Context *c, sd_bus *bus) { assert(c); - free(c->zone); + context_reset(c); bus_verify_polkit_async_registry_free(bus, c->polkit_registry); } @@ -467,12 +467,14 @@ static int property_get_rtc_time( zero(tm); r = hwclock_get_time(&tm); - if (r < 0) { + if (r == -EBUSY) { + log_warning("/dev/rtc is busy, is somebody keeping it open continously? That's not a good idea... Returning a bogus RTC timestamp."); + t = 0; + } else if (r < 0) { sd_bus_error_set_errnof(error, -r, "Failed to read RTC: %s", strerror(-r)); return r; - } - - t = (usec_t) mktime(&tm) * USEC_PER_SEC; + } else + t = (usec_t) timegm(&tm) * USEC_PER_SEC; r = sd_bus_message_append(reply, "t", t); if (r < 0) @@ -521,10 +523,14 @@ static int method_set_timezone(sd_bus *bus, sd_bus_message *m, void *userdata) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; Context *c = userdata; const char *z; - bool interactive; + unsigned interactive; char *t; int r; + assert(bus); + assert(m); + assert(c); + r = sd_bus_message_read(m, "sb", &z, &interactive); if (r < 0) return sd_bus_reply_method_errno(bus, m, r, NULL); @@ -581,7 +587,7 @@ static int method_set_timezone(sd_bus *bus, sd_bus_message *m, void *userdata) { static int method_set_local_rtc(sd_bus *bus, sd_bus_message *m, void *userdata) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; - bool lrtc, fix_system, interactive; + unsigned lrtc, fix_system, interactive; Context *c = userdata; struct timespec ts; int r; @@ -665,7 +671,7 @@ static int method_set_local_rtc(sd_bus *bus, sd_bus_message *m, void *userdata) static int method_set_time(sd_bus *bus, sd_bus_message *m, void *userdata) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; - bool relative, interactive; + unsigned relative, interactive; Context *c = userdata; int64_t utc; struct timespec ts; @@ -731,7 +737,7 @@ static int method_set_time(sd_bus *bus, sd_bus_message *m, void *userdata) { static int method_set_ntp(sd_bus *bus, sd_bus_message *m, void *userdata) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; - bool ntp, interactive; + unsigned ntp, interactive; Context *c = userdata; int r; @@ -837,7 +843,6 @@ int main(int argc, char *argv[]) { int r; log_set_target(LOG_TARGET_AUTO); - log_set_max_level(LOG_DEBUG); log_parse_environment(); log_open(); @@ -877,7 +882,6 @@ int main(int argc, char *argv[]) { goto finish; } - sd_bus_flush(bus); r = 0; finish: