X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=iface.h;h=53d3441c99df59fd8ebac1f89bbad2b15363a6d0;hb=ba8547ee3f34d8fe7bedb559530b2c0374f2089c;hp=50cc98f09c25bf64c1e1b8d8cc15ee5ffe9d2a5e;hpb=c18626ad35cdf94edbff196070ccbb6ae825abd0;p=catta diff --git a/iface.h b/iface.h index 50cc98f..53d3441 100644 --- a/iface.h +++ b/iface.h @@ -3,14 +3,10 @@ #include -struct _flxInterfaceMonitor; typedef struct _flxInterfaceMonitor flxInterfaceMonitor; - -struct _flxInterfaceAddress; typedef struct _flxInterfaceAddress flxInterfaceAddress; - -struct _flxInterface; typedef struct _flxInterface flxInterface; +typedef struct _flxHwInterface flxHwInterface; #include "address.h" #include "server.h" @@ -19,6 +15,7 @@ typedef struct _flxInterface flxInterface; #include "llist.h" #include "psched.h" #include "dns.h" +#include "announce.h" struct _flxInterfaceMonitor { flxServer *server; @@ -26,55 +23,78 @@ struct _flxInterfaceMonitor { GHashTable *hash_table; FLX_LLIST_HEAD(flxInterface, interfaces); + FLX_LLIST_HEAD(flxHwInterface, hw_interfaces); guint query_addr_seq, query_link_seq; - enum { LIST_IFACE, LIST_ADDR, LIST_DONE } list; + enum { + LIST_IFACE, + LIST_ADDR, + LIST_DONE + } list; }; -struct _flxInterface { +struct _flxHwInterface { + FLX_LLIST_FIELDS(flxHwInterface, hardware); flxInterfaceMonitor *monitor; + gchar *name; gint index; guint flags; + guint mtu; - FLX_LLIST_HEAD(flxInterfaceAddress, addresses); - FLX_LLIST_FIELDS(flxInterface, interface); + FLX_LLIST_HEAD(flxInterface, interfaces); +}; - guint n_ipv6_addrs, n_ipv4_addrs; - flxCache *ipv4_cache, *ipv6_cache; +struct _flxInterface { + FLX_LLIST_FIELDS(flxInterface, interface); + FLX_LLIST_FIELDS(flxInterface, by_hardware); + flxInterfaceMonitor *monitor; + + flxHwInterface *hardware; + guchar protocol; + gboolean announcing; - guint mtu; + flxCache *cache; + flxPacketScheduler *scheduler; - flxPacketScheduler *ipv4_scheduler, *ipv6_scheduler; + FLX_LLIST_HEAD(flxInterfaceAddress, addresses); + FLX_LLIST_HEAD(flxAnnouncement, announcements); }; struct _flxInterfaceAddress { + FLX_LLIST_FIELDS(flxInterfaceAddress, address); + flxInterfaceMonitor *monitor; + guchar flags; guchar scope; flxAddress address; - flxInterface *interface; - - FLX_LLIST_FIELDS(flxInterfaceAddress, address); - gint rr_id; + flxInterface *interface; }; flxInterfaceMonitor *flx_interface_monitor_new(flxServer *server); void flx_interface_monitor_free(flxInterfaceMonitor *m); -flxInterface* flx_interface_monitor_get_interface(flxInterfaceMonitor *m, gint index); -flxInterface* flx_interface_monitor_get_first(flxInterfaceMonitor *m); +flxInterface* flx_interface_monitor_get_interface(flxInterfaceMonitor *m, gint index, guchar protocol); +flxHwInterface* flx_interface_monitor_get_hw_interface(flxInterfaceMonitor *m, gint index); -int flx_interface_is_relevant(flxInterface *i); -int flx_address_is_relevant(flxInterfaceAddress *a); +void flx_interface_send_packet(flxInterface *i, flxDnsPacket *p); -void flx_interface_send_packet(flxInterface *i, guchar protocol, flxDnsPacket *p); +void flx_interface_post_query(flxInterface *i, flxKey *k, gboolean immediately); +void flx_interface_post_probe(flxInterface *i, flxRecord *p, gboolean immediately); +void flx_interface_post_response(flxInterface *i, const flxAddress *a, flxRecord *record, gboolean flush_cache, gboolean immediately); -void flx_interface_post_query(flxInterface *i, guchar protocol, flxKey *k); -void flx_interface_post_response(flxInterface *i, guchar protocol, flxRecord *rr); +void flx_dump_caches(flxInterfaceMonitor *m, FILE *f); -void flx_dump_caches(flxServer *s, FILE *f); +gboolean flx_interface_relevant(flxInterface *i); +gboolean flx_interface_address_relevant(flxInterfaceAddress *a); + +gboolean flx_interface_match(flxInterface *i, gint index, guchar protocol); + +typedef void (*flxInterfaceMonitorWalkCallback)(flxInterfaceMonitor *m, flxInterface *i, gpointer userdata); + +void flx_interface_monitor_walk(flxInterfaceMonitor *m, gint index, guchar protocol, flxInterfaceMonitorWalkCallback callback, gpointer userdata); #endif