]> git.meshlink.io Git - catta/blobdiff - iface.h
add client part of probing
[catta] / iface.h
diff --git a/iface.h b/iface.h
index 207c0b2f1e30ad02f3e52c542077c24fc61b268b..53d3441c99df59fd8ebac1f89bbad2b15363a6d0 100644 (file)
--- a/iface.h
+++ b/iface.h
@@ -3,20 +3,19 @@
 
 #include <glib.h>
 
-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"
 #include "netlink.h"
 #include "cache.h"
 #include "llist.h"
+#include "psched.h"
+#include "dns.h"
+#include "announce.h"
 
 struct _flxInterfaceMonitor {
     flxServer *server;
@@ -24,48 +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_HEAD(flxInterface, interfaces);
+};
+
+struct _flxInterface {
     FLX_LLIST_FIELDS(flxInterface, interface);
+    FLX_LLIST_FIELDS(flxInterface, by_hardware);
+    flxInterfaceMonitor *monitor;
+    
+    flxHwInterface *hardware;
+    guchar protocol;
+    gboolean announcing;
+
+    flxCache *cache;
+    flxPacketScheduler *scheduler;
 
-    guint n_ipv6_addrs, n_ipv4_addrs;
-    flxCache *ipv4_cache, *ipv6_cache;
+    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);
+
+void flx_interface_send_packet(flxInterface *i, flxDnsPacket *p);
 
-int flx_interface_is_relevant(flxInterface *i);
-int flx_address_is_relevant(flxInterfaceAddress *a);
+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_send_query(flxInterface *i, guchar protocol, flxKey *k);
+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