Skip to content

Commit

Permalink
ci in iseq can only be object or null
Browse files Browse the repository at this point in the history
It looks like rb_callinfo in iseq can only be either a Ruby object or
null, since it cannot be allocated on the stack.
  • Loading branch information
peterzhu2118 committed Jan 19, 2023
1 parent f7b7246 commit dcc676a
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions iseq.c
Expand Up @@ -324,7 +324,7 @@ rb_iseq_update_references(rb_iseq_t *iseq)
if (body->call_data) {
for (unsigned int i=0; i<body->ci_size; i++) {
struct rb_call_data *cds = body->call_data;
if (!SPECIAL_CONST_P((VALUE)cds[i].ci)) {
if (cds[i].ci) {
cds[i].ci = (struct rb_callinfo *)rb_gc_location((VALUE)cds[i].ci);
}
cds[i].cc = (struct rb_callcache *)rb_gc_location((VALUE)cds[i].cc);
Expand Down Expand Up @@ -400,7 +400,7 @@ rb_iseq_mark(const rb_iseq_t *iseq)
const struct rb_callinfo *ci = cds[i].ci;
const struct rb_callcache *cc = cds[i].cc;

if (vm_ci_markable(ci)) {
if (ci) {
rb_gc_mark_movable((VALUE)ci);
}

Expand Down

0 comments on commit dcc676a

Please sign in to comment.