move route interface assignment to the vlist update
[project/netifd.git] / system-dummy.c
index 4c9a8fc..b3aefbe 100644 (file)
@@ -79,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;
@@ -134,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;
@@ -160,13 +184,17 @@ 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;
@@ -176,3 +204,13 @@ time_t system_get_rtime(void)
 
        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;
+}