X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Fiface.h;h=25eb3247515483e6bba0b4f5dcf0993425df5baf;hb=7b7a022127d14b3a83d042c2aa52c76ec90554d2;hp=00aea9aa9f4906342106432bd4130e4d0d45d76f;hpb=af1ce5fe2245fba0045d2c0d70b58b700938bd2f;p=catta diff --git a/avahi-core/iface.h b/avahi-core/iface.h index 00aea9a..25eb324 100644 --- a/avahi-core/iface.h +++ b/avahi-core/iface.h @@ -22,31 +22,36 @@ USA. ***/ -#include - typedef struct AvahiInterfaceMonitor AvahiInterfaceMonitor; typedef struct AvahiInterfaceAddress AvahiInterfaceAddress; typedef struct AvahiInterface AvahiInterface; typedef struct AvahiHwInterface AvahiHwInterface; -#include "address.h" +#include +#include + #include "server.h" #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" +#include "browse.h" +#include "querier.h" + +#define AVAHI_MAX_MAC_ADDRESS 32 struct AvahiInterfaceMonitor { AvahiServer *server; AvahiNetlink *netlink; - GHashTable *hash_table; + AvahiHashmap *hashmap; AVAHI_LLIST_HEAD(AvahiInterface, interfaces); AVAHI_LLIST_HEAD(AvahiHwInterface, hw_interfaces); - guint query_addr_seq, query_link_seq; + unsigned query_addr_seq, query_link_seq; enum { LIST_IFACE, @@ -59,10 +64,15 @@ struct AvahiHwInterface { AVAHI_LLIST_FIELDS(AvahiHwInterface, hardware); AvahiInterfaceMonitor *monitor; - gchar *name; - gint index; - guint flags; - guint mtu; + char *name; + AvahiIfIndex index; + unsigned flags; + unsigned mtu; + + uint8_t mac_address[AVAHI_MAX_MAC_ADDRESS]; + size_t mac_address_size; + + AvahiSEntryGroup *entry_group; AVAHI_LLIST_HEAD(AvahiInterface, interfaces); }; @@ -73,25 +83,32 @@ struct AvahiInterface { AvahiInterfaceMonitor *monitor; AvahiHwInterface *hardware; - guchar protocol; - gboolean announcing; + AvahiProtocol protocol; + int announcing; AvahiCache *cache; - AvahiPacketScheduler *scheduler; + + AvahiQueryScheduler *query_scheduler; + AvahiResponseScheduler * response_scheduler; + AvahiProbeScheduler *probe_scheduler; AVAHI_LLIST_HEAD(AvahiInterfaceAddress, addresses); AVAHI_LLIST_HEAD(AvahiAnnouncement, announcements); + + AvahiHashmap *queriers_by_key; + AVAHI_LLIST_HEAD(AvahiQuerier, queriers); }; struct AvahiInterfaceAddress { AVAHI_LLIST_FIELDS(AvahiInterfaceAddress, address); AvahiInterfaceMonitor *monitor; - guchar flags; - guchar scope; + unsigned char flags; + unsigned char scope; + unsigned char prefix_len; AvahiAddress address; - AvahiEntryGroup *entry_group; + AvahiSEntryGroup *entry_group; AvahiInterface *interface; }; @@ -100,25 +117,33 @@ void avahi_interface_monitor_free(AvahiInterfaceMonitor *m); void avahi_interface_monitor_sync(AvahiInterfaceMonitor *m); -AvahiInterface* avahi_interface_monitor_get_interface(AvahiInterfaceMonitor *m, gint index, guchar protocol); -AvahiHwInterface* avahi_interface_monitor_get_hw_interface(AvahiInterfaceMonitor *m, gint index); +AvahiInterface* avahi_interface_monitor_get_interface(AvahiInterfaceMonitor *m, AvahiIfIndex idx, AvahiProtocol protocol); +AvahiHwInterface* avahi_interface_monitor_get_hw_interface(AvahiInterfaceMonitor *m, int idx); void avahi_interface_send_packet(AvahiInterface *i, AvahiDnsPacket *p); -void avahi_interface_send_packet_unicast(AvahiInterface *i, AvahiDnsPacket *p, const AvahiAddress *a, guint16 port); +void avahi_interface_send_packet_unicast(AvahiInterface *i, AvahiDnsPacket *p, const AvahiAddress *a, uint16_t port); -gboolean avahi_interface_post_query(AvahiInterface *i, AvahiKey *k, gboolean immediately); -gboolean avahi_interface_post_probe(AvahiInterface *i, AvahiRecord *p, gboolean immediately); -gboolean avahi_interface_post_response(AvahiInterface *i, AvahiRecord *record, gboolean flush_cache, gboolean immediately); +int avahi_interface_post_query(AvahiInterface *i, AvahiKey *k, int immediately); +int avahi_interface_post_response(AvahiInterface *i, AvahiRecord *record, int flush_cache, const AvahiAddress *querier, int immediately); +int avahi_interface_post_probe(AvahiInterface *i, AvahiRecord *p, int immediately); -void avahi_dump_caches(AvahiInterfaceMonitor *m, FILE *f); +int avahi_dump_caches(AvahiInterfaceMonitor *m, AvahiDumpCallback callback, void* userdata); -gboolean avahi_interface_relevant(AvahiInterface *i); -gboolean avahi_interface_address_relevant(AvahiInterfaceAddress *a); +int avahi_interface_relevant(AvahiInterface *i); +int avahi_interface_address_relevant(AvahiInterfaceAddress *a); -gboolean avahi_interface_match(AvahiInterface *i, gint index, guchar protocol); +int avahi_interface_match(AvahiInterface *i, AvahiIfIndex idx, AvahiProtocol protocol); -typedef void (*AvahiInterfaceMonitorWalkCallback)(AvahiInterfaceMonitor *m, AvahiInterface *i, gpointer userdata); +typedef void (*AvahiInterfaceMonitorWalkCallback)(AvahiInterfaceMonitor *m, AvahiInterface *i, void* userdata); -void avahi_interface_monitor_walk(AvahiInterfaceMonitor *m, gint index, guchar protocol, AvahiInterfaceMonitorWalkCallback callback, gpointer userdata); +void avahi_interface_monitor_walk(AvahiInterfaceMonitor *m, AvahiIfIndex idx, AvahiProtocol protocol, AvahiInterfaceMonitorWalkCallback callback, void* userdata); + +void avahi_update_host_rrs(AvahiInterfaceMonitor *m, int remove_rrs); + +int avahi_address_is_local(AvahiInterfaceMonitor *m, const AvahiAddress *a); + +int avahi_interface_address_on_link(AvahiInterface *i, const AvahiAddress *a); + +int avahi_interface_has_address(AvahiInterfaceMonitor *m, AvahiIfIndex iface, const AvahiAddress *a); #endif