From 5f7d4d6e9f47d328e7c4ef71030bdc9e34892798 Mon Sep 17 00:00:00 2001 From: Oxore Date: Tue, 7 Mar 2023 16:05:46 +0300 Subject: Get rid of libc, take just parts of it --- third_party/newlib/stdlib/abort.c | 61 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 third_party/newlib/stdlib/abort.c (limited to 'third_party/newlib/stdlib/abort.c') diff --git a/third_party/newlib/stdlib/abort.c b/third_party/newlib/stdlib/abort.c new file mode 100644 index 0000000..c3c8adb --- /dev/null +++ b/third_party/newlib/stdlib/abort.c @@ -0,0 +1,61 @@ +/* NetWare can not use this implementation of abort. It provides its + own version of abort in clib.nlm. If we can not use clib.nlm, then + we must write abort in sys/netware. */ + +#ifdef ABORT_PROVIDED + +int _dummy_abort = 1; + +#else + +/* +FUNCTION +<>---abnormal termination of a program + +INDEX + abort + +SYNOPSIS + #include + void abort(void); + +DESCRIPTION +Use <> to signal that your program has detected a condition it +cannot deal with. Normally, <> ends your program's execution. + +Before terminating your program, <> raises the exception <> +(using `<>'). If you have used <> to register +an exception handler for this condition, that handler has the +opportunity to retain control, thereby avoiding program termination. + +In this implementation, <> does not perform any stream- or +file-related cleanup (the host environment may do so; if not, you can +arrange for your program to do its own cleanup with a <> +exception handler). + +RETURNS +<> does not return to its caller. + +PORTABILITY +ANSI C requires <>. + +Supporting OS subroutines required: <<_exit>> and optionally, <>. +*/ + +#include +#include + +void +abort (void) +{ +#ifdef ABORT_MESSAGE + write (2, "Abort called\n", sizeof ("Abort called\n")-1); +#endif + + while (1) + { + _exit (1); + } +} + +#endif -- cgit v1.2.3