55
56 if (nm->is_unloading()) {
57 // We don't need to take the lock when unlinking nmethods from
58 // the Method, because it is only concurrently unlinked by
59 // the entry barrier, which acquires the per nmethod lock.
60 nm->unlink_from_method();
61
62 // We can end up calling nmethods that are unloading
63 // since we clear compiled ICs lazily. Returning false
64 // will re-resovle the call and update the compiled IC.
65 return false;
66 }
67
68 // Heal oops
69 ShenandoahNMethod::heal_nmethod(nm);
70
71 // CodeCache unloading support
72 nm->mark_as_maybe_on_stack();
73
74 // Disarm
75 ShenandoahNMethod::disarm_nmethod(nm);
76 return true;
77 }
|
55
56 if (nm->is_unloading()) {
57 // We don't need to take the lock when unlinking nmethods from
58 // the Method, because it is only concurrently unlinked by
59 // the entry barrier, which acquires the per nmethod lock.
60 nm->unlink_from_method();
61
62 // We can end up calling nmethods that are unloading
63 // since we clear compiled ICs lazily. Returning false
64 // will re-resovle the call and update the compiled IC.
65 return false;
66 }
67
68 // Heal oops
69 ShenandoahNMethod::heal_nmethod(nm);
70
71 // CodeCache unloading support
72 nm->mark_as_maybe_on_stack();
73
74 // Disarm
75 ShenandoahNMethod::disarm_nmethod_unlocked(nm);
76 return true;
77 }
|