< prev index next >

src/hotspot/cpu/aarch64/gc/shenandoah/shenandoahBarrierSetAssembler_aarch64.hpp

Print this page
*** 85,10 ***
--- 85,16 ---
    void generate_c1_pre_barrier_runtime_stub(StubAssembler* sasm);
    void generate_c1_load_reference_barrier_runtime_stub(StubAssembler* sasm, DecoratorSet decorators);
  #endif
  
  #ifdef COMPILER2
+   // Barrier hotpatching
+   static address parse_stub_address(address pc);
+   static bool is_active(address pc);
+   static void patch_branch_to_nop(address pc);
+   static void patch_nop_to_branch(address pc, address stub_addr);
+ 
    // Entry points from Matcher
    void load_c2(const MachNode* node, MacroAssembler* masm, Register dst, Address addr, Register tmp1, Register tmp2, bool is_narrow, bool is_acquire);
    void store_c2(const MachNode* node, MacroAssembler* masm, Address dst, bool dst_narrow, Register src, bool src_narrow, Register tmp1, Register tmp2, Register tmp3, bool is_volatile);
    void compare_and_set_c2(const MachNode* node, MacroAssembler* masm, Register res, Register addr, Register oldval,
        Register newval, Register tmp1, Register tmp2, Register tmp3, bool exchange, bool narrow, bool weak, bool acquire);
< prev index next >