X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fodhcpd.git;a=blobdiff_plain;f=src%2Frouter.c;h=dfbcf60dca73e4fb62f0b3e1b7eeb895f1cb971b;hp=a75b847fbb2b29de358b75ac3c8e757236c2c3c5;hb=84cfd09747332071c83de4882daecb9bfb80897b;hpb=9cd9c3ba82c341de1af091575e11cd3ddd433c8c diff --git a/src/router.c b/src/router.c index a75b847..dfbcf60 100644 --- a/src/router.c +++ b/src/router.c @@ -451,12 +451,14 @@ static void send_router_advert(struct uloop_timeout *event) odhcpd_send(router_event.uloop.fd, &all_nodes, iov, ARRAY_SIZE(iov), iface); - // Rearm timer - int msecs; - odhcpd_urandom(&msecs, sizeof(msecs)); - msecs = (labs(msecs) % (1000 * (MaxRtrAdvInterval - - MinRtrAdvInterval))) + (MinRtrAdvInterval * 1000); - uloop_timeout_set(&iface->timer_rs, msecs); + // Rearm timer if not shut down + if (event->cb) { + int msecs; + odhcpd_urandom(&msecs, sizeof(msecs)); + msecs = (labs(msecs) % (1000 * (MaxRtrAdvInterval + - MinRtrAdvInterval))) + (MinRtrAdvInterval * 1000); + uloop_timeout_set(&iface->timer_rs, msecs); + } }