errno.c (__get_errno, [...]): Transform then into weak symbols so we use the version...
authorJose Ruiz <ruiz@adacore.com>
Wed, 20 Aug 2008 16:12:17 +0000 (18:12 +0200)
committerArnaud Charlet <charlet@gcc.gnu.org>
Wed, 20 Aug 2008 16:12:17 +0000 (18:12 +0200)
2008-08-20  Jose Ruiz  <ruiz@adacore.com>

* errno.c (__get_errno, __set_errno for MaRTE): Transform then into
weak symbols so we use the version provided by MaRTE when available.

From-SVN: r139332

gcc/ada/errno.c

index 1f3497dad9e9cdfd9e5d3a1f954877510fdbbda1..811cbdbbf8d813ebf3c7027cee6286b459734bd2 100644 (file)
 
 #ifdef MaRTE
 
-/* Function that returns a pointer to the per-task errno variable */
-extern int *pthread_errno (void);
+/* MaRTE OS provides its own implementation of errno related functionality. We
+   want to ensure the use of the MaRTE version for tasking programs (the MaRTE
+   library will not be linked if no tasking constructs are used), so we use the
+   weak symbols mechanism to use the MaRTE version whenever is available. */
 
-int
-__get_errno (void)
-{
-  return *pthread_errno ();
-}
-
-/* Function __set_errno is already defined in package MaRTE.POSIX_Pthread */
+#pragma weak __get_errno
+#pragma weak __set_errno
 
-#else
+#endif
 
 #include <errno.h>
 int
@@ -68,5 +65,3 @@ __set_errno(int err)
 {
   errno = err;
 }
-
-#endif