diff options
author | k0kubun <k0kubun@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-08-12 12:59:47 +0000 |
---|---|---|
committer | k0kubun <k0kubun@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-08-12 12:59:47 +0000 |
commit | c55e10a9eaee956ac6fbc12d6962658a510a79ff (patch) | |
tree | 1a6c41d6baabc16e10da88fbf073d25292bdc197 /mjit.c | |
parent | af2e98ae801695155f98288836d814e373be769a (diff) |
mjit.c: reduce the number of variables
in mark_ec_units() to simplify code.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@64321 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'mjit.c')
-rw-r--r-- | mjit.c | 12 |
1 files changed, 5 insertions, 7 deletions
@@ -192,22 +192,20 @@ create_unit(const rb_iseq_t *iseq) static void mark_ec_units(rb_execution_context_t *ec) { - const rb_iseq_t *iseq; const rb_control_frame_t *cfp; - rb_control_frame_t *last_cfp = ec->cfp; - const rb_control_frame_t *end_marker_cfp; - uintptr_t i, size; if (ec->vm_stack == NULL) return; - end_marker_cfp = RUBY_VM_END_CONTROL_FRAME(ec); - size = end_marker_cfp - last_cfp; - for (i = 0, cfp = end_marker_cfp - 1; i < size; i++, cfp = RUBY_VM_NEXT_CONTROL_FRAME(cfp)) { + for (cfp = RUBY_VM_END_CONTROL_FRAME(ec) - 1; ; cfp = RUBY_VM_NEXT_CONTROL_FRAME(cfp)) { + const rb_iseq_t *iseq; if (cfp->pc && (iseq = cfp->iseq) != NULL && imemo_type((VALUE) iseq) == imemo_iseq && (iseq->body->jit_unit) != NULL) { iseq->body->jit_unit->used_code_p = TRUE; } + + if (cfp == ec->cfp) + break; /* reached the most recent cfp */ } } |