diff options
author | Alok Barsode <alok.barsode@linux.intel.com> | 2012-02-03 20:26:02 +0200 |
---|---|---|
committer | Samuel Ortiz <sameo@linux.intel.com> | 2012-02-04 01:15:36 +0100 |
commit | d92c0506baf62cce92341b42e705b1c237959df1 (patch) | |
tree | 28c88fcb58fb6a7fcfa65ef7d37e350d40164d6b | |
parent | f97c14e2606c64df0ae23c81a8a4066d27367091 (diff) | |
download | connman-d92c0506baf62cce92341b42e705b1c237959df1.tar.gz connman-d92c0506baf62cce92341b42e705b1c237959df1.tar.bz2 connman-d92c0506baf62cce92341b42e705b1c237959df1.zip |
timeserver: Use service timeserver, if any, before system timeservers
-rw-r--r-- | include/service.h | 1 | ||||
-rw-r--r-- | src/service.c | 11 | ||||
-rw-r--r-- | src/timeserver.c | 11 |
3 files changed, 23 insertions, 0 deletions
diff --git a/include/service.h b/include/service.h index afa51a2c..d7aaca5c 100644 --- a/include/service.h +++ b/include/service.h @@ -107,6 +107,7 @@ char *connman_service_get_interface(struct connman_service *service); const char *connman_service_get_domainname(struct connman_service *service); char **connman_service_get_nameservers(struct connman_service *service); +char **connman_service_get_timeservers(struct connman_service *service); void connman_service_set_proxy_method(struct connman_service *service, enum connman_service_proxy_method method); enum connman_service_proxy_method connman_service_get_proxy_method(struct connman_service *service); char **connman_service_get_proxy_servers(struct connman_service *service); diff --git a/src/service.c b/src/service.c index 2fe93fce..a61824f1 100644 --- a/src/service.c +++ b/src/service.c @@ -2154,6 +2154,17 @@ char **connman_service_get_nameservers(struct connman_service *service) return NULL; } +char **connman_service_get_timeservers(struct connman_service *service) +{ + if (service == NULL) + return NULL; + + if (service->timeservers != NULL) + return service->timeservers; + + return NULL; +} + void connman_service_set_proxy_method(struct connman_service *service, enum connman_service_proxy_method method) { diff --git a/src/timeserver.c b/src/timeserver.c index a3614337..b00f1091 100644 --- a/src/timeserver.c +++ b/src/timeserver.c @@ -35,6 +35,7 @@ static GSList *driver_list = NULL; static GHashTable *server_hash = NULL; static char **system_timeservers = NULL; +static char **timeservers = NULL; static GResolv *resolv = NULL; static int resolv_id = 0; @@ -289,6 +290,14 @@ int __connman_timeserver_sync(struct connman_service *service) system_timeservers = load_timeservers(); + timeservers = connman_service_get_timeservers(service); + + if (timeservers != NULL && timeservers[0] != NULL) { + DBG("Using service tiemservers"); + __connman_ntp_start(timeservers[0]); + return 0; + } + if (system_timeservers == NULL || system_timeservers[count] == NULL) { DBG("No timeservers set."); return 0; @@ -315,6 +324,8 @@ void __connman_timeserver_stop() system_timeservers = NULL; } + timeservers = NULL; + count = 0; __connman_ntp_stop(); |