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:
authorMatthew Malcomson <matthew.malcomson@arm.com>2018-11-16 14:45:48 +0300
committerJeff Johnston <jjohnstn@redhat.com>2018-11-26 18:07:55 +0300
commit2d6b71ee6d3459658ebe73c5cb262023b86f472e (patch)
tree99f05b1b9ddc171810889bf94048612de58e1477 /newlib/libc
parent7e72be1c390cb771ef54db4df50d4041bdaa1488 (diff)
Builtin enable return code with SYS_EXIT_EXTENDED
A previous commit introduced the ability to use the semi-hosting SYS_EXIT_EXTENDED operation to libgloss, this commit adds the same ability to the sys/arm/ backend so that building newlib only will provide the same capabilities.
Diffstat (limited to 'newlib/libc')
-rw-r--r--newlib/libc/sys/arm/syscalls.c62
1 files changed, 43 insertions, 19 deletions
diff --git a/newlib/libc/sys/arm/syscalls.c b/newlib/libc/sys/arm/syscalls.c
index 87ddca706..b52107491 100644
--- a/newlib/libc/sys/arm/syscalls.c
+++ b/newlib/libc/sys/arm/syscalls.c
@@ -30,7 +30,7 @@ int _stat (const char *, struct stat *);
int _fstat (int, struct stat *);
void * _sbrk (ptrdiff_t);
pid_t _getpid (void);
-int _kill (int, int) __attribute__((__noreturn__));
+int _kill (int, int);
void _exit (int);
int _close (int);
int _swiclose (int);
@@ -49,6 +49,7 @@ static int error (int);
static int get_errno (void);
static int remap_handle (int);
static int findslot (int);
+static int _kill_shared (int, int, int) __attribute__((__noreturn__));
/* Register name faking - works in collusion with the linker. */
register char * stack_ptr asm ("sp");
@@ -424,21 +425,35 @@ _close (int file)
return wrap (_swiclose (file));
}
-int
-_kill (int pid, int sig)
+static int
+_kill_shared (int pid, int sig, int reason)
{
- (void)pid; (void)sig;
+ (void) pid; (void) sig;
#ifdef ARM_RDI_MONITOR
/* Note: The pid argument is thrown away. */
- switch (sig) {
- case SIGABRT:
- do_AngelSWI (AngelSWI_Reason_ReportException,
- (void *) ADP_Stopped_RunTimeError);
- __builtin_unreachable();
- default:
- do_AngelSWI (AngelSWI_Reason_ReportException,
- (void *) ADP_Stopped_ApplicationExit);
- }
+ int block[2];
+ block[1] = sig;
+ block[0] = reason;
+ int insn;
+
+#if SEMIHOST_V2
+ if (_has_ext_exit_extended ())
+ {
+ insn = AngelSWI_Reason_ReportExceptionExtended;
+ }
+ else
+#endif
+ {
+ insn = AngelSWI_Reason_ReportException;
+ }
+
+#if SEMIHOST_V2
+if (_has_ext_exit_extended ())
+ do_AngelSWI (insn, block);
+else
+#endif
+ do_AngelSWI (insn, (void*)block[0]);
+
#else
asm ("swi %a0" :: "i" (SWI_Exit));
#endif
@@ -446,15 +461,24 @@ _kill (int pid, int sig)
__builtin_unreachable();
}
+int
+_kill (int pid, int sig)
+{
+ if (sig == SIGABRT)
+ _kill_shared (pid, sig, ADP_Stopped_RunTimeError);
+ else
+ _kill_shared (pid, sig, ADP_Stopped_ApplicationExit);
+}
+
void
_exit (int status)
{
- /* There is only one SWI for both _exit and _kill. For _exit, call
- the SWI with the second argument set to -1, an invalid value for
- signum, so that the SWI handler can distinguish the two calls.
- Note: The RDI implementation of _kill throws away both its
- arguments. */
- _kill(status, -1);
+ /* The same SWI is used for both _exit and _kill.
+ For _exit, call the SWI with "reason" set to ADP_Stopped_ApplicationExit
+ to mark a standard exit.
+ Note: The RDI implementation of _kill_shared throws away all its
+ arguments and all implementations ignore the first argument. */
+ _kill_shared (-1, status, ADP_Stopped_ApplicationExit);
}
pid_t