From 513d8b349f3e37c3fa43a11148a68a2e14836fcb Mon Sep 17 00:00:00 2001 From: normal Date: Sun, 1 Nov 2015 02:13:54 +0000 Subject: iseq.c (iseq_memsize): account for rb_call_cache entries Add some comments to clarify the allocated field used for the allocations while we're at it. TODO: figure out a better way of testing/maintaining this... git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52419 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- iseq.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'iseq.c') diff --git a/iseq.c b/iseq.c index 6b243feb7e..b1f05a2d62 100644 --- a/iseq.c +++ b/iseq.c @@ -174,10 +174,18 @@ iseq_memsize(const rb_iseq_t *iseq) } size += (body->param.opt_num + 1) * sizeof(VALUE); size += param_keyword_size(body->param.keyword); + + /* body->is_entries */ size += body->is_size * sizeof(union iseq_inline_storage_entry); + + /* body->ci_entries */ size += body->ci_size * sizeof(struct rb_call_info); size += body->ci_kw_size * sizeof(struct rb_call_info_with_kwarg); + /* body->cc_entries */ + size += body->ci_size * sizeof(struct rb_call_cache); + size += body->ci_kw_size * sizeof(struct rb_call_cache); + if (ci_kw_entries) { unsigned int i; -- cgit v1.2.3