Removed pthread emulation from Windows port. Fixed IPC route update to
authorThomas Lopatic <thomas@lopatic.de>
Sun, 14 Nov 2004 20:25:34 +0000 (20:25 +0000)
committerThomas Lopatic <thomas@lopatic.de>
Sun, 14 Nov 2004 20:25:34 +0000 (20:25 +0000)
pass arguments according to the new prototype.

src/win32/compat.c
src/win32/kernel_routes.c
src/win32/pthread.h [deleted file]

index c8d9ce3..79b921f 100644 (file)
@@ -18,7 +18,7 @@
  * along with olsr.org; if not, write to the Free Software
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  *
- * $Id: compat.c,v 1.7 2004/11/10 11:08:32 tlopatic Exp $
+ * $Id: compat.c,v 1.8 2004/11/14 20:25:34 tlopatic Exp $
  *
  */
 
  * SOFTWARE.
  */
 
-#include <pthread.h>
 #include <unistd.h>
 #include <sys/time.h>
 #include <ctype.h>
 #include "defs.h"
 
-struct ThreadPara
-{
-  void *(*Func)(void *);
-  void *Arg;
-};
-
-static unsigned long __stdcall ThreadWrapper(void *Para)
-{
-  struct ThreadPara *Cast;
-  void *(*Func)(void *);
-  void *Arg;
-
-  Cast = (struct ThreadPara *)Para;
-
-  Func = Cast->Func;
-  Arg = Cast->Arg;
-  
-  HeapFree(GetProcessHeap(), 0, Para);
-
-  Func(Arg);
-
-  return 0;
-}
-
-int pthread_create(HANDLE *Hand, void *Attr, void *(*Func)(void *), void *Arg)
-{
-  struct ThreadPara *Para;
-  unsigned long ThreadId;
-
-  Para = HeapAlloc(GetProcessHeap(), 0, sizeof (struct ThreadPara));
-
-  if (Para == NULL)
-    return -1;
-
-  Para->Func = Func;
-  Para->Arg = Arg;
-
-  *Hand = CreateThread(NULL, 0, ThreadWrapper, Para, 0, &ThreadId);
-
-  if (*Hand == NULL)
-    return -1;
-
-  return 0;
-}
-
-int pthread_kill(HANDLE Hand, int Sig)
-{
-  if (!TerminateThread(Hand, 0))
-    return -1;
-
-  return 0;
-}
-
-int pthread_mutex_init(HANDLE *Hand, void *Attr)
-{
-  *Hand = CreateMutex(NULL, FALSE, NULL);
-
-  if (*Hand == NULL)
-    return -1;
-
-  return 0;
-}
-
-int pthread_mutex_lock(HANDLE *Hand)
-{
-  if (WaitForSingleObject(*Hand, INFINITE) == WAIT_FAILED)
-    return -1;
-
-  return 0;
-}
-
-int pthread_mutex_unlock(HANDLE *Hand)
-{
-  if (!ReleaseMutex(*Hand))
-    return -1;
-
-  return 0;
-}
-
 void sleep(unsigned int Sec)
 {
   Sleep(Sec * 1000);
index 5f172d1..7d807be 100644 (file)
@@ -18,7 +18,7 @@
  * along with olsr.org; if not, write to the Free Software
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  *
- * $Id: kernel_routes.c,v 1.7 2004/11/05 14:33:31 tlopatic Exp $
+ * $Id: kernel_routes.c,v 1.8 2004/11/14 20:25:34 tlopatic Exp $
  *
  */
 
@@ -39,8 +39,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);
@@ -78,20 +76,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 +93,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);
@@ -139,19 +124,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;
 }
diff --git a/src/win32/pthread.h b/src/win32/pthread.h
deleted file mode 100644 (file)
index a51bb1f..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/* 
- * OLSR ad-hoc routing table management protocol
- * Copyright (C) 2004 Thomas Lopatic (thomas@lopatic.de)
- *
- * This file is part of the olsr.org OLSR daemon.
- *
- * 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.
- *
- * 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.
- *
- * 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
- *
- * $Id: pthread.h,v 1.5 2004/11/05 14:33:31 tlopatic Exp $
- *
- */
-
-#if !defined TL_PTHREAD_H_INCLUDED
-
-#define TL_PTHREAD_H_INCLUDED
-
-#define WIN32_LEAN_AND_MEAN
-#include <windows.h>
-#undef interface
-
-typedef HANDLE pthread_mutex_t;
-typedef HANDLE pthread_t;
-
-int pthread_create(HANDLE *Hand, void *Attr, void *(*Func)(void *), void *Arg);
-int pthread_kill(HANDLE Hand, int Sig);
-int pthread_mutex_init(HANDLE *Hand, void *Attr);
-int pthread_mutex_lock(HANDLE *Hand);
-int pthread_mutex_unlock(HANDLE *Hand);
-
-#endif