aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--vm.c16
-rw-r--r--vm_eval.c4
2 files changed, 10 insertions, 10 deletions
diff --git a/vm.c b/vm.c
index 93e5f2a01a..d8c9cb7e75 100644
--- a/vm.c
+++ b/vm.c
@@ -822,7 +822,7 @@ frame_info_to_str_override(rb_frame_info_t *fi, VALUE *args)
typedef struct rb_backtrace_struct {
rb_frame_info_t *backtrace;
- int backtrace_size;
+ size_t backtrace_size;
VALUE str;
} rb_backtrace_t;
@@ -831,7 +831,7 @@ backtrace_mark(void *ptr)
{
if (ptr) {
rb_backtrace_t *bt = (rb_backtrace_t *)ptr;
- int i, s = bt->backtrace_size;
+ size_t i, s = bt->backtrace_size;
for (i=0; i<s; i++) {
frame_info_mark(&bt->backtrace[i]);
@@ -885,19 +885,19 @@ backtrace_alloc(VALUE klass)
}
static VALUE
-backtrace_object(rb_thread_t *th, int lev, int n)
+backtrace_object(rb_thread_t *th, int lev, ptrdiff_t n)
{
VALUE btobj = backtrace_alloc(rb_cBacktrace);
rb_backtrace_t *bt;
rb_control_frame_t *last_cfp = th->cfp;
rb_control_frame_t *start_cfp = RUBY_VM_END_CONTROL_FRAME(th);
rb_control_frame_t *cfp;
- int size, i, j;
+ ptrdiff_t size, i, j;
start_cfp = RUBY_VM_NEXT_CONTROL_FRAME(
RUBY_VM_NEXT_CONTROL_FRAME(
RUBY_VM_NEXT_CONTROL_FRAME(start_cfp))); /* skip top frames */
- size = (int)(start_cfp - last_cfp) + 1; /* TODO: check overflow */
+ size = (start_cfp - last_cfp) + 1;
if (n <= 0) {
n = size + n;
@@ -949,7 +949,7 @@ static VALUE
backtreace_collect(rb_backtrace_t *bt, VALUE (*func)(rb_frame_info_t *, VALUE *))
{
VALUE btary;
- int i;
+ size_t i;
VALUE args[3];
rb_thread_t *th = GET_THREAD();
@@ -1016,7 +1016,7 @@ backtrace_load_data(VALUE self, VALUE str)
/* old style backtrace for compatibility */
static int
-vm_backtrace_each(rb_thread_t *th, int lev, int n, void (*init)(void *), rb_backtrace_iter_func *iter, void *arg)
+vm_backtrace_each(rb_thread_t *th, int lev, ptrdiff_t n, void (*init)(void *), rb_backtrace_iter_func *iter, void *arg)
{
const rb_control_frame_t *limit_cfp = th->cfp;
const rb_control_frame_t *cfp = (void *)(th->stack + th->stack_size);
@@ -1024,7 +1024,7 @@ vm_backtrace_each(rb_thread_t *th, int lev, int n, void (*init)(void *), rb_back
int line_no = 0;
if (n <= 0) {
- n = (int)(cfp - limit_cfp); /* TODO: check overflow */
+ n = cfp - limit_cfp;
}
cfp -= 2;
diff --git a/vm_eval.c b/vm_eval.c
index 340abfc610..ff7d785354 100644
--- a/vm_eval.c
+++ b/vm_eval.c
@@ -20,8 +20,8 @@ static VALUE vm_exec(rb_thread_t *th);
static void vm_set_eval_stack(rb_thread_t * th, VALUE iseqval, const NODE *cref);
static int vm_collect_local_variables_in_heap(rb_thread_t *th, VALUE *dfp, VALUE ary);
-static int vm_backtrace_each(rb_thread_t *th, int lev, int n, void (*init)(void *), rb_backtrace_iter_func *iter, void *arg);
-static VALUE backtrace_object(rb_thread_t *th, int lev, int n);
+static int vm_backtrace_each(rb_thread_t *th, int lev, ptrdiff_t n, void (*init)(void *), rb_backtrace_iter_func *iter, void *arg);
+static VALUE backtrace_object(rb_thread_t *th, int lev, ptrdiff_t n);
static VALUE vm_backtrace_str_ary(rb_thread_t *th, int lev, int n);
typedef enum call_type {