| 1 |
706 |
jeremybenn |
/****************************************************************************
|
| 2 |
|
|
* *
|
| 3 |
|
|
* GNAT RUN-TIME LIBRARY (GNARL) COMPONENTS *
|
| 4 |
|
|
* *
|
| 5 |
|
|
* E R R N O *
|
| 6 |
|
|
* *
|
| 7 |
|
|
* C Implementation File *
|
| 8 |
|
|
* *
|
| 9 |
|
|
* Copyright (C) 1992-2009, Free Software Foundation, Inc. *
|
| 10 |
|
|
* *
|
| 11 |
|
|
* GNAT is free software; you can redistribute it and/or modify it under *
|
| 12 |
|
|
* terms of the GNU General Public License as published by the Free Soft- *
|
| 13 |
|
|
* ware Foundation; either version 3, or (at your option) any later ver- *
|
| 14 |
|
|
* sion. GNAT is distributed in the hope that it will be useful, but WITH- *
|
| 15 |
|
|
* OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
|
| 16 |
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. *
|
| 17 |
|
|
* *
|
| 18 |
|
|
* As a special exception under Section 7 of GPL version 3, you are granted *
|
| 19 |
|
|
* additional permissions described in the GCC Runtime Library Exception, *
|
| 20 |
|
|
* version 3.1, as published by the Free Software Foundation. *
|
| 21 |
|
|
* *
|
| 22 |
|
|
* You should have received a copy of the GNU General Public License and *
|
| 23 |
|
|
* a copy of the GCC Runtime Library Exception along with this program; *
|
| 24 |
|
|
* see the files COPYING3 and COPYING.RUNTIME respectively. If not, see *
|
| 25 |
|
|
* <http://www.gnu.org/licenses/>. *
|
| 26 |
|
|
* *
|
| 27 |
|
|
* GNAT was originally developed by the GNAT team at New York University. *
|
| 28 |
|
|
* Extensive contributions were provided by Ada Core Technologies Inc. *
|
| 29 |
|
|
* *
|
| 30 |
|
|
****************************************************************************/
|
| 31 |
|
|
|
| 32 |
|
|
/* This file provides access to the C-language errno to the Ada interface
|
| 33 |
|
|
for POSIX. It is not possible in general to import errno, even in
|
| 34 |
|
|
Ada compilers that allow (as GNAT does) the importation of variables,
|
| 35 |
|
|
as it may be defined using a macro.
|
| 36 |
|
|
*/
|
| 37 |
|
|
|
| 38 |
|
|
|
| 39 |
|
|
#define _REENTRANT
|
| 40 |
|
|
#define _THREAD_SAFE
|
| 41 |
|
|
#define _SGI_MP_SOURCE
|
| 42 |
|
|
|
| 43 |
|
|
#ifdef MaRTE
|
| 44 |
|
|
|
| 45 |
|
|
/* MaRTE OS provides its own implementation of errno related functionality. We
|
| 46 |
|
|
want to ensure the use of the MaRTE version for tasking programs (the MaRTE
|
| 47 |
|
|
library will not be linked if no tasking constructs are used), so we use the
|
| 48 |
|
|
weak symbols mechanism to use the MaRTE version whenever is available. */
|
| 49 |
|
|
|
| 50 |
|
|
#pragma weak __get_errno
|
| 51 |
|
|
#pragma weak __set_errno
|
| 52 |
|
|
|
| 53 |
|
|
#endif
|
| 54 |
|
|
|
| 55 |
|
|
#include <errno.h>
|
| 56 |
|
|
int
|
| 57 |
|
|
__get_errno(void)
|
| 58 |
|
|
{
|
| 59 |
|
|
return errno;
|
| 60 |
|
|
}
|
| 61 |
|
|
|
| 62 |
|
|
void
|
| 63 |
|
|
__set_errno(int err)
|
| 64 |
|
|
{
|
| 65 |
|
|
errno = err;
|
| 66 |
|
|
}
|