1 |
281 |
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 |
|
|
}
|