diff options
| author | Simon Génier <[email protected]> | 2015-02-05 15:12:21 -0500 |
|---|---|---|
| committer | Simon Génier <[email protected]> | 2015-02-05 15:12:21 -0500 |
| commit | df382dea73f30c71ee09099277444facd20ee152 (patch) | |
| tree | 1861234a40aa4631de97d038073ce60c63fc6f59 /src | |
| parent | 4957c852696c9559bfbea988325fd9bf94fc34bc (diff) | |
| download | mruby-df382dea73f30c71ee09099277444facd20ee152.tar.gz mruby-df382dea73f30c71ee09099277444facd20ee152.zip | |
Fix possible segfault when accessing backtrace with MRB_WORD_BOXING.
Diffstat (limited to 'src')
| -rw-r--r-- | src/backtrace.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/backtrace.c b/src/backtrace.c index a82d8f343..9427c3c8d 100644 --- a/src/backtrace.c +++ b/src/backtrace.c @@ -132,9 +132,18 @@ output_backtrace(mrb_state *mrb, mrb_int ciidx, mrb_code *pc0, output_stream_fun static void exc_output_backtrace(mrb_state *mrb, struct RObject *exc, output_stream_func func, void *stream) { + mrb_value lastpc; + mrb_code *code; + + lastpc = mrb_obj_iv_get(mrb, exc, mrb_intern_lit(mrb, "lastpc")); + if (mrb_nil_p(lastpc)) { + code = NULL; + } else { + code = (mrb_code*)mrb_cptr(lastpc); + } + output_backtrace(mrb, mrb_fixnum(mrb_obj_iv_get(mrb, exc, mrb_intern_lit(mrb, "ciidx"))), - (mrb_code*)mrb_cptr(mrb_obj_iv_get(mrb, exc, mrb_intern_lit(mrb, "lastpc"))), - func, stream); + code, func, stream); } /* mrb_print_backtrace/mrb_get_backtrace: |
