aboutsummaryrefslogtreecommitdiff
path: root/newlib/libc/stdlib/_Exit.c
blob: deb740ee6b366f69c04089b9b9230d42a6ce0a60 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/*
FUNCTION
<<_Exit>>---end program execution with no cleanup processing

INDEX
	_Exit

ANSI_SYNOPSIS
	#include <stdlib.h>
	void _Exit(int <[code]>);

TRAD_SYNOPSIS
	#include <stdlib.h>
	void _Exit(<[code]>)
	int <[code]>;

DESCRIPTION
Use <<_Exit>> to return control from a program to the host operating
environment.  Use the argument <[code]> to pass an exit status to the
operating environment: two particular values, <<EXIT_SUCCESS>> and
<<EXIT_FAILURE>>, are defined in `<<stdlib.h>>' to indicate success or
failure in a portable fashion.

<<_Exit>> differs from <<exit>> in that it does not run any
application-defined cleanup functions registered with <<atexit>> and
it does not clean up files and streams.  It is identical to <<_exit>>.

RETURNS
<<_Exit>> does not return to its caller.

PORTABILITY
<<_Exit>> is defined by the C99 standard.

Supporting OS subroutines required: <<_exit>>.
*/

#include <stdlib.h>
#include <unistd.h>	/* for _exit() declaration */
#include <reent.h>

void 
_DEFUN (_Exit, (code),
	int code)
{
#ifdef REENTRANT_SYSCALLS_PROVIDED
  _exit_r (_REENT, code);
#else
  _exit (code);
#endif
}