RFR: 8293474: RISC-V: Unify the way of moving function pointer
    Aleksey Shipilev 
    shade at openjdk.org
       
    Wed Sep  7 13:11:40 UTC 2022
    
    
  
On Wed, 7 Sep 2022 08:36:49 GMT, Fei Yang <fyang at openjdk.org> wrote:
> Currently, there are two different ways of moving function pointer on riscv with either 'li' or 'mv' assembler functions.
> For example, in file shenandoahBarrierSetAssembler_riscv.cpp, we use 'li' function:
>   li(ra, (int64_t)(uintptr_t)ShenandoahRuntime::load_reference_barrier_strong_narrow)
> 
> But in file templateInterpreterGenerator_riscv.cpp, we use 'mv' function:
>   mv(t1, CAST_FROM_FN_PTR(address, JavaThread::check_special_condition_for_native_trans))
> 
> Use of 'mv' here calls 'movptr' and emits fixed length instruction sequence, which is neither necessary nor optimal compared with use of 'li'. This changes to use 'li' instead of 'movptr' to implement 'mv' and unifies the way of moving function pointer.
> 
> Testing: Passed Tier1 test on Linux-riscv64 SiFive Unmatched board.
Looks fine.
-------------
Marked as reviewed by shade (Reviewer).
PR: https://git.openjdk.org/jdk/pull/10194
    
    
More information about the shenandoah-dev
mailing list