#include <netinet/in.h>
#include <arpa/nameser.h>
+#include <udebug.h>
#include <libubus.h>
#include <libubox/uloop.h>
#include "interface.h"
int cfg_proto = 0;
+int cfg_no_subnet = 0;
+
+static struct udebug ud;
+static struct udebug_buf udb;
+static bool udebug_enabled;
+
+static void
+umdns_udebug_vprintf(const char *format, va_list ap)
+{
+ if (!udebug_enabled)
+ return;
+
+ udebug_entry_init(&udb);
+ udebug_entry_vprintf(&udb, format, ap);
+ udebug_entry_add(&udb);
+}
+
+void umdns_udebug_printf(const char *format, ...)
+{
+ va_list ap;
+
+ va_start(ap, format);
+ umdns_udebug_vprintf(format, ap);
+ va_end(ap);
+}
+
+void umdns_udebug_set_enabled(bool val)
+{
+ static const struct udebug_buf_meta meta = {
+ .name = "umdns_log",
+ .format = UDEBUG_FORMAT_STRING,
+ };
+
+ if (udebug_enabled == val)
+ return;
+
+ udebug_enabled = val;
+ if (!val) {
+ udebug_buf_free(&udb);
+ udebug_free(&ud);
+ return;
+ }
+
+ udebug_init(&ud);
+ udebug_auto_connect(&ud, NULL);
+ udebug_buf_init(&udb, 1024, 64 * 1024);
+ udebug_buf_add(&ud, &udb, &meta);
+}
static void
signal_shutdown(int signal)
uloop_init();
- while ((ch = getopt(argc, argv, "t:i:d46")) != -1) {
+ while ((ch = getopt(argc, argv, "t:i:d46n")) != -1) {
switch (ch) {
case 't':
ttl = atoi(optarg);
case '6':
cfg_proto = 6;
break;
+ case 'n':
+ cfg_no_subnet = 1;
+ break;
+
default:
return -1;
}
uloop_done();
interface_shutdown();
- cache_cleanup();
+ cache_cleanup(NULL);
service_cleanup();
vlist_flush(&interfaces);