Use metric when adding/removing routes!
[olsrd.git] / src / win32 / kernel_routes.c
index 6428c1b..d2183f8 100644 (file)
@@ -1,31 +1,48 @@
 /*
- * Functions for the Windows port
- * Copyright (C) 2004 Thomas Lopatic (thomas@lopatic.de)
+ * The olsr.org Optimized Link-State Routing daemon (olsrd)
+ * Copyright (c) 2004, Thomas Lopatic (thomas@lopatic.de)
+ * All rights reserved.
  *
- * This file is part of olsrd-unik.
+ * Redistribution and use in source and binary forms, with or without 
+ * modification, are permitted provided that the following conditions 
+ * are met:
  *
- * olsrd-unik is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
+ * * Redistributions of source code must retain the above copyright 
+ *   notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright 
+ *   notice, this list of conditions and the following disclaimer in 
+ *   the documentation and/or other materials provided with the 
+ *   distribution.
+ * * Neither the name of olsr.org, olsrd nor the names of its 
+ *   contributors may be used to endorse or promote products derived 
+ *   from this software without specific prior written permission.
  *
- * olsrd-unik is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
+ * POSSIBILITY OF SUCH DAMAGE.
  *
- * You should have received a copy of the GNU General Public License
- * along with olsrd-unik; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ * Visit http://www.olsr.org for more information.
  *
+ * If you find this software useful feel free to make a donation
+ * to the project. For more information see the website or contact
+ * the copyright holders.
+ *
+ * $Id: kernel_routes.c,v 1.12 2004/12/03 18:01:59 tlopatic Exp $
  */
 
 #include <stdio.h>
-
-#include "../olsr_protocol.h"
 #include "net/route.h"
-#include "../routing_table.h"
-#include "../olsr.h"
+
+#include "../kernel_routes.h"
 #include "../defs.h"
 
 #define WIN32_LEAN_AND_MEAN
@@ -39,8 +56,6 @@ int olsr_ioctl_add_route(struct rt_entry *Dest)
 {
   MIB_IPFORWARDROW Row;
   unsigned long Res;
-  union olsr_kernel_route Route;
-  char *IntString;
   char Str1[16], Str2[16], Str3[16];
 
   inet_ntop(AF_INET, &Dest->rt_dst.v4, Str1, 16);
@@ -57,6 +72,7 @@ int olsr_ioctl_add_route(struct rt_entry *Dest)
   Row.dwForwardIfIndex = Dest->rt_if->if_index;
   Row.dwForwardType = (Dest->rt_dst.v4 == Dest->rt_router.v4) ? 3 : 4;
   Row.dwForwardProto = 3; // PROTO_IP_NETMGMT
+  Row.dwForwardMetric1 = Dest->rt_metric;
 
   Res = SetIpForwardEntry(&Row);
 
@@ -77,21 +93,9 @@ int olsr_ioctl_add_route(struct rt_entry *Dest)
     return -1;
   }
 
-  if(use_ipc)
-  {
-    memset(&Route, 0, sizeof (Route));
-
-    Route.v4.rt_metric = Dest->rt_metric;
-
-    ((struct sockaddr_in *)&Route.v4.rt_gateway)->sin_addr.s_addr =
-      Dest->rt_router.v4;
-
-    ((struct sockaddr_in *)&Route.v4.rt_dst)->sin_addr.s_addr =
-      Dest->rt_dst.v4;
-
-    IntString = (Dest->rt_router.v4 == 0) ? NULL : Dest->rt_if->int_name;
-    ipc_route_send_rtentry(&Route, 1, IntString);
-  }
+  if(olsr_cnf->open_ipc)
+    ipc_route_send_rtentry(&Dest->rt_dst, &Dest->rt_router, Dest->rt_metric,
+                           1, Dest->rt_if->int_name);
 
   return 0;
 }
@@ -107,7 +111,6 @@ int olsr_ioctl_del_route(struct rt_entry *Dest)
 {
   MIB_IPFORWARDROW Row;
   unsigned long Res;
-  union olsr_kernel_route Route;
   char Str1[16], Str2[16], Str3[16];
 
   inet_ntop(AF_INET, &Dest->rt_dst.v4, Str1, 16);
@@ -116,20 +119,6 @@ int olsr_ioctl_del_route(struct rt_entry *Dest)
 
   olsr_printf(1, "Deleting IPv4 route to %s/%s via %s.\n", Str1, Str2, Str3);
 
-#if 0
-  Res = GetBestRoute(Dest->rt_dst.v4, 0, &Row);
-
-  if (Res != NO_ERROR)
-  {
-    fprintf(stderr, "GetBestRoute() = %08lx, %s", Res, StrError(Res));
-
-    // XXX - report error in a different way
-
-    errno = Res;
-
-    return -1;
-  }
-#else
   memset(&Row, 0, sizeof (MIB_IPFORWARDROW));
 
   Row.dwForwardDest = Dest->rt_dst.v4;
@@ -138,7 +127,7 @@ int olsr_ioctl_del_route(struct rt_entry *Dest)
   Row.dwForwardIfIndex = Dest->rt_if->if_index;
   Row.dwForwardType = (Dest->rt_dst.v4 == Dest->rt_router.v4) ? 3 : 4;
   Row.dwForwardProto = 3; // PROTO_IP_NETMGMT
-#endif
+  Row.dwForwardMetric1 = Dest->rt_metric;
 
   Res = DeleteIpForwardEntry(&Row);
 
@@ -153,20 +142,8 @@ int olsr_ioctl_del_route(struct rt_entry *Dest)
     return -1;
   }
 
-  if(use_ipc)
-  {
-    memset(&Route, 0, sizeof (Route));
-
-    Route.v4.rt_metric = Dest->rt_metric;
-
-    ((struct sockaddr_in *)&Route.v4.rt_gateway)->sin_addr.s_addr =
-      Dest->rt_router.v4;
-
-    ((struct sockaddr_in *)&Route.v4.rt_dst)->sin_addr.s_addr =
-      Dest->rt_dst.v4;
-
-    ipc_route_send_rtentry(&Route, 0, NULL);
-  }
+  if(olsr_cnf->open_ipc)
+    ipc_route_send_rtentry(&Dest->rt_dst, NULL, Dest->rt_metric, 0, NULL);
 
   return 0;
 }
@@ -177,10 +154,3 @@ int olsr_ioctl_del_route6(struct rt_entry *Dest)
 {
   return 0;
 }
-
-// XXX - to be implemented
-
-int delete_tunnel_route()
-{
-  return 0;
-}