RFR: JDK-8293676: riscv: Trampoline not created for far runtime targets outside small CodeCache
Yadong Wang
yadongwang at openjdk.org
Tue Sep 13 03:15:44 UTC 2022
On Tue, 13 Sep 2022 02:41:12 GMT, Dingli Zhang <dzhang at openjdk.org> wrote:
> Follow up [JDK-8286314](https://bugs.openjdk.org/browse/JDK-8286314), this case also exists in riscv.
>
> `relocInfo::runtime_call_type` calls can have targets inside or outside CodeCache. If offsets to the targets are not in range, trampoline calls must be used. Currently trampolines for calls are generated based on the size of CodeCache and the maximum possible branch range. If the size of CodeCache is smaller than the range, no trampoline is generated. This works well if a target is inside CodeCache. It does not work if a target is outside CodeCache and CodeCache size is smaller than the maximum possible branch range.
>
> ## Testing:
>
> - hotspot/jdk tier1 on unmatched board
src/hotspot/cpu/riscv/macroAssembler_riscv.cpp line 2831:
> 2829: address longest_branch_start = (target < CodeCache::low_bound()) ? CodeCache::high_bound() - NativeInstruction::instruction_size
> 2830: : CodeCache::low_bound();
> 2831: need_trampoline = !reachable_from_branch_at(longest_branch_start, target);
We have only +/-1Mb range in the riscv architecture, which is not enough for CodeCache in most case. In contrast, the branch range is 128 Mb in AArch64. So, is this modification necessary for the rv port?
-------------
PR: https://git.openjdk.org/jdk/pull/10246
More information about the hotspot-dev
mailing list