RFR: 8283737: riscv: MacroAssembler::stop() should emit fixed-length instruction sequence [v3]
Aleksey Shipilev
shade at openjdk.java.net
Wed Mar 30 07:19:45 UTC 2022
On Tue, 29 Mar 2022 08:53:16 GMT, Xiaolin Zheng <xlinzheng at openjdk.org> wrote:
>> Hi team,
>>
>> Could I have a review of this simple patch? -
>>
>> `PhaseOutput::fill_buffer` detects if the real size of a node matches (<=) the size of it in scratch_emit(). The call chain for MacroAssembler::stop() is:
>>
>>
>> MachEpilogNode::emit
>> -> reserved_stack_check()
>> -> should_not_reach_here()
>> -> stop(const char *msg)
>>
>>
>> `li()` on RISCV could generate 1~6 instructions, and the msg argument could be an on-stack buffer; `stop()` also uses `__ pc()` that could also be different in `scratch_emit()` and `emit()`. They both have the potential issue here so the size generated in `MacroAssembler::stop()` needs to be a fixed value.
>>
>> Could be reproduced in the fastdebug build by adding one line:
>>
>>
>> // Die now.
>> instruct ShouldNotReachHere() %{
>> match(Halt);
>> ins_cost(BRANCH_COST);
>> format %{ "#@ShouldNotReachHere" %}
>> ins_encode %{
>> Assembler::CompressibleRegion cr(&_masm);
>> if (is_reachable()) {
>> __ halt();
>> + __ unimplemented("this is an on-stack char literal"); // assertion fail at 'assert(false, "wrong size of mach node");'
>> }
>> %}
>> ins_pipe(pipe_class_default);
>> %}
>>
>>
>> This patch also fixes a typo introduced in JDK-8278994: `c_bnez` is mistakenly written to `c_beqz`, though not used until now, needing a fix for future usage.
>>
>>
>> Tests passed in hotspot tier1 & jdk tier1 without new errors found.
>>
>> Thanks,
>> Xiaolin
>
> Xiaolin Zheng has updated the pull request incrementally with one additional commit since the last revision:
>
> Polish comments as the suggestion
Looks fine. But I would rather push `c_beqz` change under a separate PR, so that the issue tracking is clean.
-------------
Marked as reviewed by shade (Reviewer).
PR: https://git.openjdk.java.net/jdk/pull/7982
More information about the hotspot-compiler-dev
mailing list