Integrated: 8293100: RISC-V: Need to save and restore callee-saved FloatRegisters in StubGenerator::generate_call_stub
Xiaolin Zheng
xlinzheng at openjdk.org
Fri Sep 2 07:04:12 UTC 2022
On Wed, 31 Aug 2022 08:47:50 GMT, Xiaolin Zheng <xlinzheng at openjdk.org> wrote:
> Hi team,
>
> 1. Tests described in JDK-8293100 are failed, for callee-saved float registers used in C++ code are observed being killed after entering the Java world since callee-saved float registers are unfortunately missed to be saved in `StubGenerator::generate_call_stub()`. So the phenomenon presented in the failed tests seems to be weird.
>
> 2. This patch also fixes some typos in `vmreg_riscv.cpp` when debugging the same issue:
> (before)
> 
> This one seems not right, either; and it also gets fixed in this patch:
> (after)
> 
>
> 3. Also, branch nodes for float registers in OptoAssembly didn't show their destination blocks. This patch adds a little enhancement for those.
>
> Hotspot tier1 has passed both on my board and qemu, and `vmTestbase/nsk/stress` tests failed before have passed as well.
> The test process on the board is slow and I am testing the remaining but I consider this as ready for review.
>
> Best,
> Xiaolin
This pull request has now been integrated.
Changeset: bc5ffc8e
Author: Xiaolin Zheng <xlinzheng at openjdk.org>
Committer: Fei Yang <fyang at openjdk.org>
URL: https://git.openjdk.org/jdk/commit/bc5ffc8e472ba7bbafbf68d19d1f06dd1cba10e1
Stats: 81 lines in 4 files changed: 64 ins; 0 del; 17 mod
8293100: RISC-V: Need to save and restore callee-saved FloatRegisters in StubGenerator::generate_call_stub
Reviewed-by: yadongwang, fjiang, shade, vkempik
-------------
PR: https://git.openjdk.org/jdk/pull/10095
More information about the hotspot-dev
mailing list