include route/address flags in vlist comparison
[project/netifd.git] / system-dummy.c
index d1557f9..b3aefbe 100644 (file)
@@ -1,3 +1,4 @@
+#include <sys/time.h>
 #include <stdio.h>
 #include <string.h>
 
@@ -16,7 +17,7 @@ int system_init(void)
        return 0;
 }
 
-int system_bridge_addbr(struct device *bridge)
+int system_bridge_addbr(struct device *bridge, struct bridge_config *cfg)
 {
        D(SYSTEM, "brctl addbr %s\n", bridge->ifname);
        return 0;
@@ -64,6 +65,10 @@ int system_if_down(struct device *dev)
        return 0;
 }
 
+void system_if_clear_state(struct device *dev)
+{
+}
+
 int system_if_check(struct device *dev)
 {
        dev->ifindex = 0;
@@ -74,6 +79,28 @@ int system_if_check(struct device *dev)
        return 0;
 }
 
+struct device *
+system_if_get_parent(struct device *dev)
+{
+       if (!strcmp(dev->ifname, "eth0"))
+               return device_get("eth1", true);
+
+       return NULL;
+}
+
+int
+system_if_dump_info(struct device *dev, struct blob_buf *b)
+{
+       blobmsg_add_u8(b, "link", dev->present);
+       return 0;
+}
+
+int
+system_if_dump_stats(struct device *dev, struct blob_buf *b)
+{
+       return 0;
+}
+
 int system_add_address(struct device *dev, struct device_addr *addr)
 {
        uint8_t *a = (uint8_t *) &addr->addr.in;
@@ -129,8 +156,10 @@ int system_add_route(struct device *dev, struct device_route *route)
                sprintf(gw, " gw %d.%d.%d.%d",
                        a2[0], a2[1], a2[2], a2[3]);
 
-       if (route->flags & DEVADDR_DEVICE)
-               sprintf(devstr, " dev %s", dev->ifname);
+       sprintf(devstr, " dev %s", dev->ifname);
+
+       if (route->metric > 0)
+               sprintf(devstr, " metric %d", route->metric);
 
        D(SYSTEM, "route add %s%s%s\n", addr, gw, devstr);
        return 0;
@@ -155,9 +184,33 @@ int system_del_route(struct device *dev, struct device_route *route)
                sprintf(gw, " gw %d.%d.%d.%d",
                        a2[0], a2[1], a2[2], a2[3]);
 
-       if (route->flags & DEVADDR_DEVICE)
-               sprintf(devstr, " dev %s", dev->ifname);
+       sprintf(devstr, " dev %s", dev->ifname);
 
        D(SYSTEM, "route del %s%s%s\n", addr, gw, devstr);
        return 0;
 }
+
+int system_flush_routes(void)
+{
+       return 0;
+}
+
+time_t system_get_rtime(void)
+{
+       struct timeval tv;
+
+       if (gettimeofday(&tv, NULL) == 0)
+               return tv.tv_sec;
+
+       return 0;
+}
+
+int system_del_ip_tunnel(const char *name)
+{
+       return 0;
+}
+
+int system_add_ip_tunnel(const char *name, struct blob_attr *attr)
+{
+       return 0;
+}