Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2000-02-17 22:39:52 +0300
committerChristopher Faylor <me@cgf.cx>2000-02-17 22:39:52 +0300
commit8a0efa53e44919bcf5ccb1d3353618a82afdf8bc (patch)
tree68c3dbf3f2c6fd5d49777def9914d77b5cd4589d /newlib/libc/sys/sysnecv850/_exit.c
parent1fd5e000ace55b323124c7e556a7a864b972a5c4 (diff)
import newlib-2000-02-17 snapshot
Diffstat (limited to 'newlib/libc/sys/sysnecv850/_exit.c')
-rw-r--r--newlib/libc/sys/sysnecv850/_exit.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/newlib/libc/sys/sysnecv850/_exit.c b/newlib/libc/sys/sysnecv850/_exit.c
new file mode 100644
index 000000000..b45ae96c8
--- /dev/null
+++ b/newlib/libc/sys/sysnecv850/_exit.c
@@ -0,0 +1,34 @@
+#include <_ansi.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include "sys/syscall.h"
+
+int errno;
+
+int __trap0 (int function, int p1, int p2, int p3);
+
+#define TRAP0(f, p1, p2, p3) __trap0(f, (int)(p1), (int)(p2), (int)(p3))
+
+static void _do_dtors()
+{
+ /* The loop variable is static so that if a destructor calls exit,
+ and we return here, we simply continue with the next destructor. */
+ typedef void (*pfunc) ();
+ extern pfunc __dtors[];
+ extern pfunc __dtors_end[];
+ static pfunc *p = __dtors;
+
+ while (p < __dtors_end)
+ (*p++) ();
+}
+
+
+void _exit (n)
+{
+ /* Destructors should be done earlier because they need to be done before the
+ files are closed, but here is better than nowhere (and this balances the
+ constructors done in crt1.c. */
+ _do_dtors();
+
+ TRAP0 (SYS_exit, n, 0, 0);
+}