summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--avahi-core/server.c7
-rw-r--r--avahi-daemon/simple-protocol.c7
2 files changed, 13 insertions, 1 deletions
diff --git a/avahi-core/server.c b/avahi-core/server.c
index a020f64..356a917 100644
--- a/avahi-core/server.c
+++ b/avahi-core/server.c
@@ -615,7 +615,6 @@ static void handle_query_packet(AvahiServer *s, AvahiDnsPacket *p, AvahiInterfac
fail:
avahi_record_list_flush(s->record_list);
-
}
static void handle_response_packet(AvahiServer *s, AvahiDnsPacket *p, AvahiInterface *i, const AvahiAddress *a) {
@@ -653,6 +652,12 @@ static void handle_response_packet(AvahiServer *s, AvahiDnsPacket *p, AvahiInter
avahi_record_unref(record);
}
+
+ /* If the incoming response contained a conflicting record, some
+ records have been scheduling for sending. We need to flush them
+ here. */
+ if (!avahi_record_list_empty(s->record_list))
+ avahi_server_generate_response(s, i, NULL, NULL, 0, FALSE);
}
static AvahiLegacyUnicastReflectSlot* allocate_slot(AvahiServer *s) {
diff --git a/avahi-daemon/simple-protocol.c b/avahi-daemon/simple-protocol.c
index 8bd8da4..c41e07c 100644
--- a/avahi-daemon/simple-protocol.c
+++ b/avahi-daemon/simple-protocol.c
@@ -386,6 +386,13 @@ int simple_protocol_setup(GMainContext *c) {
sa.sun_family = AF_LOCAL;
strncpy(sa.sun_path, UNIX_SOCKET, sizeof(sa.sun_path)-1);
+ /* We simply remove existing UNIX sockets under this name. The
+ Avahi daemons makes sure that it runs only once on a host,
+ therefore sockets that already exist are stale and may be
+ removed without any ill effects */
+
+ unlink(UNIX_SOCKET);
+
if (bind(server->fd, &sa, sizeof(sa)) < 0) {
avahi_log_warn("bind(): %s", strerror(errno));
goto fail;