X-Git-Url: http://git.archive.openwrt.org/?a=blobdiff_plain;f=ubus.c;h=202646a7422cdd07ae04b95929999b8b1584f034;hb=bdac146facb72ce3f88f682d598d3124ec73fe78;hp=e87543aeef73a09ff2403a4c8952ae40d9b06e83;hpb=8158e9052afbf2ee47de645167b90b6e7fc7d86d;p=project%2Fprocd.git diff --git a/ubus.c b/ubus.c index e87543a..202646a 100644 --- a/ubus.c +++ b/ubus.c @@ -23,6 +23,7 @@ char *ubus_socket = NULL; static struct ubus_context *ctx; static struct uloop_process ubus_proc; static bool ubus_connected = false; +static int reconnect = 1; static void procd_ubus_connection_lost(struct ubus_context *old_ctx); @@ -76,14 +77,16 @@ static void procd_ubus_try_connect(void) ctx->connection_lost = procd_ubus_connection_lost; ubus_connected = true; ubus_init_service(ctx); - if (getpid() == 1) { + ubus_init_system(ctx); + if (getpid() == 1) ubus_init_log(ctx); - ubus_init_system(ctx); - } } static void procd_ubus_connection_lost(struct ubus_context *old_ctx) { + if (!reconnect) + return; + procd_ubus_try_connect(); while (!ubus_connected) { procd_restart_ubus(); @@ -101,3 +104,8 @@ void procd_connect_ubus(void) procd_ubus_connection_lost(NULL); } +void procd_reconnect_ubus(int _reconnect) +{ + reconnect = _reconnect; +} +