Use metric when adding/removing routes!
[olsrd.git] / src / win32 / kernel_routes.c
index 727aa9c..d2183f8 100644 (file)
@@ -1,25 +1,42 @@
-/* 
- * OLSR ad-hoc routing table management protocol
- * 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 the olsr.org OLSR daemon.
+ * Redistribution and use in source and binary forms, with or without 
+ * modification, are permitted provided that the following conditions 
+ * are met:
  *
- * olsr.org 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.
  *
- * olsr.org 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 olsr.org; 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.
  *
- * $Id: kernel_routes.c,v 1.5 2004/10/19 21:44:56 tlopatic Exp $
+ * 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>
@@ -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);
 
@@ -78,20 +94,8 @@ int olsr_ioctl_add_route(struct rt_entry *Dest)
   }
 
   if(olsr_cnf->open_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);
-  }
+    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);
@@ -124,6 +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
+  Row.dwForwardMetric1 = Dest->rt_metric;
 
   Res = DeleteIpForwardEntry(&Row);
 
@@ -139,19 +143,7 @@ int olsr_ioctl_del_route(struct rt_entry *Dest)
   }
 
   if(olsr_cnf->open_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);
-  }
+    ipc_route_send_rtentry(&Dest->rt_dst, NULL, Dest->rt_metric, 0, NULL);
 
   return 0;
 }
@@ -162,10 +154,3 @@ int olsr_ioctl_del_route6(struct rt_entry *Dest)
 {
   return 0;
 }
-
-// XXX - to be implemented
-
-int delete_tunnel_route()
-{
-  return 0;
-}