Fixed semihosting for AArch64 when heapinfo parameters are not provided by debugger

This commit is contained in:
Alexander Fedotov 2017-10-11 14:52:20 +03:00 committed by Corinna Vinschen
parent 56e494c074
commit f6ef29c48f
2 changed files with 59 additions and 26 deletions

View File

@ -102,33 +102,44 @@
ldr x0, .LC0 /* point at returned values */ ldr x0, .LC0 /* point at returned values */
ldr x1, [x0, #8] /* get heap_limit */ ldr x1, [x0, #8] /* get heap_limit */
/* Set __heap_limit. */
#ifdef __ILP32__
/* Sanity check on the __heap_limit. */
tst x1, #0xffffffff00000000
bne .Linsanepar
#endif
cmp x1, xzr
beq .LC4
adrp x2, __heap_limit
add x2, x2, #:lo12:__heap_limit
str x1, [x2]
.LC4:
ldr x1, [x0] /* get heap_base */
#ifdef __ILP32__ #ifdef __ILP32__
/* Sanity check on the heap base. */ /* Sanity check on the heap base. */
ldr x0, [x0] /* get heap_base */
tst x0, #0xffffffff00000000
beq 1f
/* Exit with 1 if the heap base is not within the 32-bit address
space. */
mov x0, ADP_Stopped_ApplicationExit & 0xff
movk x0, ADP_Stopped_ApplicationExit >> 16, lsl #16
adrp x1, HeapBase /* Reuse to construct the parameter block. */
add x1, x1, #:lo12:HeapBase
str x0, [x1]
mov x0, 1
str x0, [x1, #8]
mov w0, #AngelSVC_Reason_ReportException
AngelSVCAsm AngelSVC
1:
/* For the sake of safety, set the stack base to the top end of
the 32-bit address space if the returned value from the
Angel API call is larger than or equal to 4 GiB. */
tst x1, #0xffffffff00000000 tst x1, #0xffffffff00000000
csinv w1, w1, wzr, eq bne .Linsanepar
#endif #endif
#else cmp x1, xzr
/* Set up the stack pointer to a fixed value. */ bne .LC5
ldr x1, .Lstack /* If the heap base value [x0, #0] is 0 then the heap base is actually
at the end of program data (i.e. __end__) */
ldr x1, .LC3
str x1, [x0, #0]
.LC5:
ldr x1, [x0, #16] /* get stack_base */
#ifdef __ILP32__
/* Sanity check on the stack_base. */
tst x1, #0xffffffff00000000
bne .Linsanepar
#endif #endif
cmp x1, xzr
bne .LC6
#endif
ldr x1, .Lstack /* Set up the stack pointer to a fixed value */
.LC6:
/* Ensure quad-word stack alignment. */ /* Ensure quad-word stack alignment. */
and x0, x1, #~15 and x0, x1, #~15
@ -234,6 +245,22 @@
b FUNCTION (exit) /* Cannot return. */ b FUNCTION (exit) /* Cannot return. */
#if defined (ARM_RDI_MONITOR) && defined (__ILP32__)
.Linsanepar:
/* Exit with 1 if the parameter is not within the 32-bit address
space. */
mov x1, ADP_Stopped_ApplicationExit & 0xff
movk x1, ADP_Stopped_ApplicationExit >> 16, lsl #16
adrp x0, HeapBase /* Reuse to construct the parameter block. */
add x0, x0, #:lo12:HeapBase
str x1, [x0]
mov x1, 1
str x1, [x0, #8]
mov w1, #AngelSVC_Reason_ReportException
AngelSVCAsm AngelSVC
b .
#endif
/* Function initializing exception vector table, flatmap, etc. /* Function initializing exception vector table, flatmap, etc.
Declared as weak symbol so that user can override this definition Declared as weak symbol so that user can override this definition
by linking in their own version of the function. */ by linking in their own version of the function. */
@ -245,12 +272,13 @@ FUNCTION (_cpu_init_hook):
#ifdef ARM_RDI_MONITOR #ifdef ARM_RDI_MONITOR
.LC0: .LC0:
GEN_DWORD HeapBase GEN_DWORD HeapBase
#else .LC3:
GEN_DWORD __end__
#endif
.Lstack: .Lstack:
GEN_DWORD __stack GEN_DWORD __stack
.weak __stack .weak __stack
#endif
.LC1: .LC1:
GEN_DWORD __bss_start__ GEN_DWORD __bss_start__
.LC2: .LC2:

View File

@ -625,6 +625,9 @@ _getpid (int n __attribute__ ((unused)))
return 1; return 1;
} }
/* Heap limit returned from SYS_HEAPINFO Angel semihost call. */
ulong __heap_limit __attribute__ ((aligned (8))) = 0xcafedead;
caddr_t caddr_t
_sbrk (int incr) _sbrk (int incr)
{ {
@ -637,7 +640,9 @@ _sbrk (int incr)
prev_heap_end = heap_end; prev_heap_end = heap_end;
if (heap_end + incr > stack_ptr) if ((heap_end + incr > stack_ptr)
/* Honour heap limit if it's valid. */
|| ((__heap_limit != 0xcafedead) && (heap_end + incr > __heap_limit)))
{ {
/* Some of the libstdc++-v3 tests rely upon detecting /* Some of the libstdc++-v3 tests rely upon detecting
out of memory errors, so do not abort here. */ out of memory errors, so do not abort here. */