X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Fiface.h;h=1372e6fd137ffcf7d13e3b42bd217813325590ae;hb=219241ab5223b705ade51485ea9227b0a6089c0d;hp=431dae333ff97c90c1f6cda7f166743744d81318;hpb=602a2b6481587b7da2594db39151ec9380f276df;p=catta diff --git a/avahi-core/iface.h b/avahi-core/iface.h index 431dae3..1372e6f 100644 --- a/avahi-core/iface.h +++ b/avahi-core/iface.h @@ -34,10 +34,14 @@ typedef struct AvahiHwInterface AvahiHwInterface; #include "netlink.h" #include "cache.h" #include "llist.h" -#include "psched.h" +#include "response-sched.h" +#include "query-sched.h" +#include "probe-sched.h" #include "dns.h" #include "announce.h" +#define AVAHI_MAX_MAC_ADDRESS 32 + struct AvahiInterfaceMonitor { AvahiServer *server; AvahiNetlink *netlink; @@ -64,6 +68,11 @@ struct AvahiHwInterface { guint flags; guint mtu; + guint8 mac_address[AVAHI_MAX_MAC_ADDRESS]; + guint mac_address_size; + + AvahiEntryGroup *entry_group; + AVAHI_LLIST_HEAD(AvahiInterface, interfaces); }; @@ -77,7 +86,9 @@ struct AvahiInterface { gboolean announcing; AvahiCache *cache; - AvahiPacketScheduler *scheduler; + AvahiQueryScheduler *query_scheduler; + AvahiResponseScheduler * response_scheduler; + AvahiProbeScheduler *probe_scheduler; AVAHI_LLIST_HEAD(AvahiInterfaceAddress, addresses); AVAHI_LLIST_HEAD(AvahiAnnouncement, announcements); @@ -107,8 +118,8 @@ void avahi_interface_send_packet(AvahiInterface *i, AvahiDnsPacket *p); void avahi_interface_send_packet_unicast(AvahiInterface *i, AvahiDnsPacket *p, const AvahiAddress *a, guint16 port); gboolean avahi_interface_post_query(AvahiInterface *i, AvahiKey *k, gboolean immediately); +gboolean avahi_interface_post_response(AvahiInterface *i, AvahiRecord *record, gboolean flush_cache, const AvahiAddress *querier, gboolean immediately); gboolean avahi_interface_post_probe(AvahiInterface *i, AvahiRecord *p, gboolean immediately); -gboolean avahi_interface_post_response(AvahiInterface *i, const AvahiAddress *a, AvahiRecord *record, gboolean flush_cache, gboolean immediately); void avahi_dump_caches(AvahiInterfaceMonitor *m, FILE *f); @@ -121,4 +132,8 @@ typedef void (*AvahiInterfaceMonitorWalkCallback)(AvahiInterfaceMonitor *m, Avah void avahi_interface_monitor_walk(AvahiInterfaceMonitor *m, gint index, guchar protocol, AvahiInterfaceMonitorWalkCallback callback, gpointer userdata); +void avahi_update_host_rrs(AvahiInterfaceMonitor *m, gboolean remove); + +gboolean avahi_address_is_local(AvahiInterfaceMonitor *m, const AvahiAddress *a); + #endif