public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc r11-9351] libphobos: Push all callee-save registers on the stack before GC scan on ARM
@ 2021-12-02 14:42 Iain Buclaw
0 siblings, 0 replies; only message in thread
From: Iain Buclaw @ 2021-12-02 14:42 UTC (permalink / raw)
To: gcc-cvs
https://gcc.gnu.org/g:2d5be1fca0fb5b3d69d250531af6c37279eee96a
commit r11-9351-g2d5be1fca0fb5b3d69d250531af6c37279eee96a
Author: Iain Buclaw <ibuclaw@gdcproject.org>
Date: Thu Dec 2 01:53:51 2021 +0100
libphobos: Push all callee-save registers on the stack before GC scan on ARM
This is the library fix for PR103520 that also prevents the garbage
collector from releasing live memory. However this requires that the
host compiler has been patched with this fix, so the GC will remain
disabled in the D front-end for now until enough time has passed for
this to have trickled down into enough releases.
libphobos/ChangeLog:
* libdruntime/core/thread/osthread.d (callWithStackShell): Push all
callee-save registers on the stack for AArch64 and ARM.
(cherry picked from commit 2fb6a57f9ffa9ac964931b439b6d1600a698e377)
Diff:
---
libphobos/libdruntime/core/thread/osthread.d | 29 ++++++++++++++++++++++++++++
1 file changed, 29 insertions(+)
diff --git a/libphobos/libdruntime/core/thread/osthread.d b/libphobos/libdruntime/core/thread/osthread.d
index 9fcd30e50fb..26234c3b174 100644
--- a/libphobos/libdruntime/core/thread/osthread.d
+++ b/libphobos/libdruntime/core/thread/osthread.d
@@ -1475,6 +1475,35 @@ in (fn)
}}
sp = cast(void*)®s[0];
}
+ else version (AArch64)
+ {
+ // Callee-save registers, x19-x28 according to AAPCS64, section
+ // 5.1.1. Include x29 fp because it optionally can be a callee
+ // saved reg
+ size_t[11] regs = void;
+ // store the registers in pairs
+ asm pure nothrow @nogc
+ {
+ "stp x19, x20, %0" : "=m" (regs[ 0]), "=m" (regs[1]);
+ "stp x21, x22, %0" : "=m" (regs[ 2]), "=m" (regs[3]);
+ "stp x23, x24, %0" : "=m" (regs[ 4]), "=m" (regs[5]);
+ "stp x25, x26, %0" : "=m" (regs[ 6]), "=m" (regs[7]);
+ "stp x27, x28, %0" : "=m" (regs[ 8]), "=m" (regs[9]);
+ "str x29, %0" : "=m" (regs[10]);
+ "mov %0, sp" : "=r" (sp);
+ }
+ }
+ else version (ARM)
+ {
+ // Callee-save registers, according to AAPCS, section 5.1.1.
+ // arm and thumb2 instructions
+ size_t[8] regs = void;
+ asm pure nothrow @nogc
+ {
+ "stm %0, {r4-r11}" : : "r" (regs.ptr) : "memory";
+ "mov %0, sp" : "=r" (sp);
+ }
+ }
else
{
__builtin_unwind_init();
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2021-12-02 14:42 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-12-02 14:42 [gcc r11-9351] libphobos: Push all callee-save registers on the stack before GC scan on ARM Iain Buclaw
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).