diff options
author | mirabilos <tg@debian.org> | 2021-05-05 21:26:33 +0200 |
---|---|---|
committer | Ben Hutchings <ben@decadent.org.uk> | 2021-12-26 18:56:52 +0100 |
commit | 12db27ba0db4fabe1230d1d9b8be56453991e6a9 (patch) | |
tree | 8f24af7a5bc8b9b576253268287eb3f68769f9ff | |
parent | eb10cf8c3128612a089ace8489a81bc4ffd5d07a (diff) | |
download | klibc-12db27ba0db4fabe1230d1d9b8be56453991e6a9.tar.gz |
{set,long}jmp [s390x]: save/restore the correct registers
The s390x ABI actually has FPU registers f8‥f15, not f1/f3/f5/f7,
to be saved. (Closes: Debian #943425)
Signed-off-by: mirabilos <tg@debian.org>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
-rw-r--r-- | usr/include/arch/s390/klibc/archsetjmp.h | 2 | ||||
-rw-r--r-- | usr/klibc/arch/s390/setjmp.S | 24 |
2 files changed, 17 insertions, 9 deletions
diff --git a/usr/include/arch/s390/klibc/archsetjmp.h b/usr/include/arch/s390/klibc/archsetjmp.h index 728780add2df5d..1167c8b6733832 100644 --- a/usr/include/arch/s390/klibc/archsetjmp.h +++ b/usr/include/arch/s390/klibc/archsetjmp.h @@ -16,7 +16,7 @@ struct __jmp_buf { struct __jmp_buf { uint64_t __gregs[10]; /* general registers r6-r15 */ - uint64_t __fpregs[4]; /* fp registers f1, f3, f5, f7 */ + uint64_t __fpregs[8]; /* fp registers f8-f15 */ }; #endif /* __s390x__ */ diff --git a/usr/klibc/arch/s390/setjmp.S b/usr/klibc/arch/s390/setjmp.S index c36a0517ccf211..1386419a26ae3c 100644 --- a/usr/klibc/arch/s390/setjmp.S +++ b/usr/klibc/arch/s390/setjmp.S @@ -38,10 +38,14 @@ longjmp: setjmp: stmg %r6,%r15,0(%r2) # save all general registers - std %f1,80(%r2) # save fp registers f4 and f6 - std %f3,88(%r2) - std %f5,96(%r2) - std %f7,104(%r2) + std %f8,80(%r2) # save fp registers f8 to f15 + std %f9,88(%r2) + std %f10,96(%r2) + std %f11,104(%r2) + std %f12,112(%r2) + std %f13,120(%r2) + std %f14,128(%r2) + std %f15,136(%r2) lghi %r2,0 # return 0 br %r14 @@ -54,10 +58,14 @@ setjmp: longjmp: lgr %r1,%r2 # jmp_buf lgr %r2,%r3 # return value - ld %f7,104(%r1) # restore all saved registers - ld %f5,96(%r1) - ld %f3,88(%r1) - ld %f1,80(%r1) + ld %f15,136(%r1) # restore all saved registers + ld %f14,128(%r1) + ld %f13,120(%r1) + ld %f12,112(%r1) + ld %f11,104(%r1) + ld %f10,96(%r1) + ld %f9,88(%r1) + ld %f8,80(%r1) lmg %r6,%r15,0(%r1) br %r14 # return to restored address |