Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add context ucontext for windows.
[simgrid.git] / src / win32 / compiler / visualc.h
index a8af217..6844375 100644 (file)
@@ -3,7 +3,8 @@
 
 /* borland.h - simgrid config for Borland C++ Builder   */
 
-/* Copyright (c) 2003, 2004 Cherier Malek. All rights reserved.            */
+/* Copyright (c) 2007, 2008, 2010. The SimGrid Team.
+ * All rights reserved.                                                     */
 
 /* This program is free software; you can redistribute it and/or modify it
  * under the terms of the license (GNU LGPL) which comes with this package. */
 
 #include <win32/platform/select_platform_features.h>
 
+#ifdef _WIN32_WINNT
+       #if _WIN32_WINNT < 0x0400
+               #undef _WIN32_WINNT
+               #define _WIN32_WINNT 0x0400
+       #endif
+#else
+       #define _WIN32_WINNT 0x0400     
+#endif
+
 /* 
  * include files. 
  */
@@ -308,7 +318,7 @@ the double. For now, GRAS requires the structures to be compacted. */
        #undef GRAS_THISARCH
 #endif
 
-#define GRAS_THISARCH 0
+#define GRAS_THISARCH 3
 
  
  /* Path to the addr2line tool */
@@ -316,41 +326,65 @@ the double. For now, GRAS requires the structures to be compacted. */
        #undef ADDR2LINE
 #endif
 
-#if !defined(HAVE_VA_COPY)
-       #define HAVE_VA_COPY 1
-#endif
 
-/* This macro is not defined in borland stdarg.h include file, adds it. */
-#define va_copy(dest,src)   ((dest)=(src))  
+#ifndef __VISUALC__
 
-/* Predefined possible va_copy() implementation (id: ASP) */
-#define __VA_COPY_USE_ASP(d, s) do { *(d) = *(s); } while (0)
+       #if !defined(HAVE_VA_COPY)
+               #define HAVE_VA_COPY 1
+       #endif
 
-/* Predefined possible va_copy() implementation (id: ASS) */
-#define __VA_COPY_USE_ASS(d, s) do { (d) = (s); } while (0)
+       /* This macro is not defined in borland stdarg.h include file, adds it. */
+       #ifndef va_copy(dest,src)
+               #define va_copy(dest,src)   ((dest)=(src))
+       #endif
 
-/* Predefined possible va_copy() implementation (id: C99) */
-#define __VA_COPY_USE_C99(d, s) va_copy((d), (s))
+       #ifndef __VA_COPY_USE_ASP(d, s)
+       /* Predefined possible va_copy() implementation (id: ASP) */
+               #define __VA_COPY_USE_ASP(d, s) do { *(d) = *(s); } while (0)
+       #endif
 
-/* Predefined possible va_copy() implementation (id: CPP) */
-#define __VA_COPY_USE_CPP(d, s) memcpy((void *)(d), (void *)(s)), sizeof(*(s))
+       #ifndef __VA_COPY_USE_ASS(d, s)
+       /* Predefined possible va_copy() implementation (id: ASS) */
+               #define __VA_COPY_USE_ASS(d, s) do { (d) = (s); } while (0)
+       #endif
 
-/* Predefined possible va_copy() implementation (id: CPS) */
-#define __VA_COPY_USE_CPS(d, s) memcpy((void *)&(d), (void *)&(s)), sizeof((s))
+       #ifndef __VA_COPY_USE_C99(d, s)
+       /* Predefined possible va_copy() implementation (id: C99) */
+               #define __VA_COPY_USE_C99(d, s) va_copy((d), (s))
+       #endif
 
-/* Predefined possible va_copy() implementation (id: GCB) */
-#define __VA_COPY_USE_GCB(d, s) __builtin_va_copy((d), (s))
+       #ifndef __VA_COPY_USE_CPP(d, s)
+       /* Predefined possible va_copy() implementation (id: CPP) */
+               #define __VA_COPY_USE_CPP(d, s) memcpy((void *)(d), (void *)(s)), sizeof(*(s))
+       #endif
 
-/* Predefined possible va_copy() implementation (id: GCH) */
-#define __VA_COPY_USE_GCH(d, s) __va_copy((d), (s))
+       #ifndef __VA_COPY_USE_CPS(d, s)
+       /* Predefined possible va_copy() implementation (id: CPS) */
+               #define __VA_COPY_USE_CPS(d, s) memcpy((void *)&(d), (void *)&(s)), sizeof((s))
+       #endif
 
-/* Predefined possible va_copy() implementation (id: GCM) */
-#define __VA_COPY_USE_GCM(d, s) VA_COPY((d), (s))
+       #ifndef __VA_COPY_USE_GCB(d, s)
+       /* Predefined possible va_copy() implementation (id: GCB) */
+               #define __VA_COPY_USE_GCB(d, s) __builtin_va_copy((d), (s))
+       #endif
 
+       #ifndef __VA_COPY_USE_GCH(d, s)
+       /* Predefined possible va_copy() implementation (id: GCH) */
+               #define __VA_COPY_USE_GCH(d, s) __va_copy((d), (s))
+       #endif
+       /* Predefined possible va_copy() implementation (id: GCM) */
+       #define __VA_COPY_USE_GCM(d, s) VA_COPY((d), (s))
 
-/* Optional va_copy() implementation activation */
-#ifndef HAVE_VA_COPY
-#define va_copy(d, s) __VA_COPY_USE(d, s)
+
+       /* Optional va_copy() implementation activation */
+       #ifndef HAVE_VA_COPY
+       #define va_copy(d, s) __VA_COPY_USE(d, s)
+       #endif
+
+       /* Define to id of used va_copy() implementation */
+       #ifndef __VA_COPY_USE
+               #define __VA_COPY_USE __VA_COPY_USE_C99
+       #endif
 #endif
 
 /* xbt contexts are based on our threads implementation */
@@ -358,13 +392,12 @@ the double. For now, GRAS requires the structures to be compacted. */
 #define CONTEXT_THREADS 1
 #endif
 
+
 /* xbt contexts are not based on ucontext */
 #ifdef CONTEXT_UCONTEXT
 #undef CONTEXT_UCONTEXT
 #endif
 
-/* Define to id of used va_copy() implementation */
-#define __VA_COPY_USE __VA_COPY_USE_C99
 
 #ifndef _XBT_CALL
        #if defined(_XBT_DESIGNATED_DLL)
@@ -412,20 +445,6 @@ the double. For now, GRAS requires the structures to be compacted. */
 #define S_IWUSR _S_IWRITE
 #define S_IRUSR _S_IREAD
 
-#define HAVE_STRUCT_TIMESPEC           0
-
-#define HAVE_STRUCT_TM                         1
-
-#define HAVE_GETTIMEOFDAY                      1
-
-#ifdef _WIN32_WINNT
-       #if _WIN32_WINNT < 0x0400
-               #undef _WIN32_WINNT
-               #define _WIN32_WINNT 0x0400
-       #endif
-#else
-       #define _WIN32_WINNT 0x0400     
-#endif
 
 /* Visual C++ does not declare the ssize_t type */
 typedef int ssize_t;
@@ -436,20 +455,5 @@ typedef unsigned int mode_t;
 /* Visual C++ does not declare the uint32_t type */
 typedef unsigned int uint32_t;
 
-/* Visual C++ doesn't declare the structure timespec */
-struct timespec 
-{
-       long    tv_sec;        /* seconds                                                       */
-       long    tv_nsec;       /* nanoseconds                                           */
-};
-
-/* Visual C++ doesn't declare the structure timezone :
- *(a structure used to indicate the local time zone)
- */
-struct timezone 
-{
-       int tz_minuteswest;     /* of Greenwich                                         */
-    int tz_dsttime;            /* type of dst correction to apply      */
-};
 
 #endif /* #ifndef __XBT_VISUALC_COMPILER_CONFIG_H__ */