[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Octave-bug-tracker] [bug #55397] test imwrite error with address saniti
From: |
Dmitri A. Sergatskov |
Subject: |
[Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer |
Date: |
Sat, 5 Jan 2019 13:41:11 -0500 (EST) |
User-agent: |
Mozilla/5.0 (X11; Fedora; Linux x86_64; rv:64.0) Gecko/20100101 Firefox/64.0 |
Follow-up Comment #1, bug #55397 (project octave):
Here is the same test with a minimal octave (no qt, no java):
test image/imwrite.m
[Detaching after fork from child process 27877]
[Detaching after fork from child process 27878]
warning: Loadable section ".note.gnu.property" outside of ELF segments
warning: Loadable section ".note.gnu.property" outside of ELF segments
[Detaching after fork from child process 27879]
=================================================================
==27830==ERROR: AddressSanitizer: heap-use-after-free on address
0x62500003e9f8 at pc 0x7ffff72792dd bp 0x7ffffffed1a0 sp 0x7ffffffec948
READ of size 5 at 0x62500003e9f8 thread T0
#0 0x7ffff72792dc (/lib64/libasan.so.5+0xa22dc)
#1 0x7ffff297e7b0 in GetLocaleExceptionMessage
(/lib64/libGraphicsMagick-Q16.so.3+0xa97b0)
#2 0x7ffff297ec9e in ThrowLoggedException
(/lib64/libGraphicsMagick-Q16.so.3+0xa9c9e)
#3 0x7ffff2963103 in WriteImage
(/lib64/libGraphicsMagick-Q16.so.3+0x8e103)
#4 0x7ffff296335a in WriteImages
(/lib64/libGraphicsMagick-Q16.so.3+0x8e35a)
#5 0x7ffff5ff1301 in void
Magick::writeImages<__gnu_cxx::__normal_iterator<Magick::Image*,
std::vector<Magick::Image, std::allocator<Magick::Image> > >
>(__gnu_cxx::__normal_iterator<Magick::Image*, std::vector<Magick::Image,
std::allocator<Magick::Image> > >,
__gnu_cxx::__normal_iterator<Magick::Image*, std::vector<Magick::Image,
std::allocator<Magick::Image> > >, std::__cxx11::basic_string<char,
std::char_traits<char>, std::allocator<char> > const&, bool)
(/home/dima/src/octave/gcc_asan_min/libinterp/.libs/liboctinterp.so.6+0x1828301)
#6 0x7ffff5fc7bb7 in write_file
../libinterp/corefcn/__magick_read__.cc:1446
#7 0x7ffff5fca960 in F__magick_write__(octave_value_list const&, int)
../libinterp/corefcn/__magick_read__.cc:1631
#8 0x7ffff5a93a30 in octave_builtin::call(octave::tree_evaluator&, int,
octave_value_list const&) ../libinterp/octave-value/ov-builtin.cc:65
#9 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#10 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#11 0x7ffff5b67641 in
octave::tree_evaluator::evaluate(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:312
#12 0x7ffff5f0bb1b in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2775
#13 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#14 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#15 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#16 0x7ffff5f008e0 in
octave::tree_evaluator::execute_user_function(octave_user_function&, int,
octave_value_list const&) ../libinterp/parse-tree/pt-eval.cc:1694
#17 0x7ffff5ce782e in octave_user_function::call(octave::tree_evaluator&,
int, octave_value_list const&) ../libinterp/octave-value/ov-usr-fcn.cc:455
#18 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#19 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#20 0x7ffff5b67641 in
octave::tree_evaluator::evaluate(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:312
#21 0x7ffff5f0bb1b in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2775
#22 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#23 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#24 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#25 0x7ffff5f02997 in
octave::tree_evaluator::visit_if_command_list(octave::tree_if_command_list&)
../libinterp/parse-tree/pt-eval.cc:1862
#26 0x7ffff5ee55ce in
octave::tree_if_command_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:115
#27 0x7ffff5f025a9 in
octave::tree_evaluator::visit_if_command(octave::tree_if_command&)
../libinterp/parse-tree/pt-eval.cc:1840
#28 0x7ffff5f532ae in
octave::tree_if_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:148
#29 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#30 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#31 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#32 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#33 0x7ffff5f008e0 in
octave::tree_evaluator::execute_user_function(octave_user_function&, int,
octave_value_list const&) ../libinterp/parse-tree/pt-eval.cc:1694
#34 0x7ffff5ce782e in octave_user_function::call(octave::tree_evaluator&,
int, octave_value_list const&) ../libinterp/octave-value/ov-usr-fcn.cc:455
#35 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#36 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#37 0x7ffff5b67641 in
octave::tree_evaluator::evaluate(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:312
#38 0x7ffff5f0bb1b in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2775
#39 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#40 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#41 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#42 0x7ffff5f008e0 in
octave::tree_evaluator::execute_user_function(octave_user_function&, int,
octave_value_list const&) ../libinterp/parse-tree/pt-eval.cc:1694
#43 0x7ffff5ce782e in octave_user_function::call(octave::tree_evaluator&,
int, octave_value_list const&) ../libinterp/octave-value/ov-usr-fcn.cc:455
#44 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#45 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#46 0x7ffff5f1be0d in
octave::tree_evaluator::evaluate_n(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:343
#47 0x7ffff5ef27d6 in
octave::tree_evaluator::eval_string(std::__cxx11::basic_string<char,
std::char_traits<char>, std::allocator<char> > const&, bool, int&, int)
../libinterp/parse-tree/pt-eval.cc:242
#48 0x7ffff5ef2ffe in octave::tree_evaluator::eval_string(octave_value
const&, bool, int&, int) ../libinterp/parse-tree/pt-eval.cc:286
#49 0x7ffff66edc37 in octave::interpreter::eval_string(octave_value
const&, bool, int&, int) ../libinterp/corefcn/interpreter.cc:1150
#50 0x7ffff5e9c5fc in Feval(octave::interpreter&, octave_value_list
const&, int) ../libinterp/parse-tree/oct-parse.yy:5485
#51 0x7ffff5a93c1b in octave_builtin::call(octave::tree_evaluator&, int,
octave_value_list const&) ../libinterp/octave-value/ov-builtin.cc:71
#52 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#53 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#54 0x7ffff5b67641 in
octave::tree_evaluator::evaluate(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:312
#55 0x7ffff5f0bb1b in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2775
#56 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#57 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#58 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#59 0x7ffff5f0cf27 in
octave::tree_evaluator::visit_try_catch_command(octave::tree_try_catch_command&)
../libinterp/parse-tree/pt-eval.cc:2961
#60 0x7ffff5f36a00 in
octave::tree_try_catch_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-except.h:81
#61 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#62 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#63 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#64 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#65 0x7ffff5f02997 in
octave::tree_evaluator::visit_if_command_list(octave::tree_if_command_list&)
../libinterp/parse-tree/pt-eval.cc:1862
#66 0x7ffff5ee55ce in
octave::tree_if_command_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:115
#67 0x7ffff5f025a9 in
octave::tree_evaluator::visit_if_command(octave::tree_if_command&)
../libinterp/parse-tree/pt-eval.cc:1840
#68 0x7ffff5f532ae in
octave::tree_if_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:148
#69 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#70 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#71 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#72 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#73 0x7ffff5f02997 in
octave::tree_evaluator::visit_if_command_list(octave::tree_if_command_list&)
../libinterp/parse-tree/pt-eval.cc:1862
#74 0x7ffff5ee55ce in
octave::tree_if_command_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:115
#75 0x7ffff5f025a9 in
octave::tree_evaluator::visit_if_command(octave::tree_if_command&)
../libinterp/parse-tree/pt-eval.cc:1840
#76 0x7ffff5f532ae in
octave::tree_if_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-select.h:148
#77 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#78 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#79 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#80 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#81 0x7ffff5f0e2c2 in
octave::tree_evaluator::visit_unwind_protect_command(octave::tree_unwind_protect_command&)
../libinterp/parse-tree/pt-eval.cc:3100
#82 0x7ffff5f36a74 in
octave::tree_unwind_protect_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-except.h:148
#83 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#84 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#85 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#86 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#87 0x7ffff5efce6d in
octave::tree_evaluator::visit_simple_for_command(octave::tree_simple_for_command&)
../libinterp/parse-tree/pt-eval.cc:1295
#88 0x7ffff5f46b9e in
octave::tree_simple_for_command::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-loop.h:219
#89 0x7ffff5f0b946 in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2753
#90 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#91 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#92 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#93 0x7ffff5f008e0 in
octave::tree_evaluator::execute_user_function(octave_user_function&, int,
octave_value_list const&) ../libinterp/parse-tree/pt-eval.cc:1694
#94 0x7ffff5ce782e in octave_user_function::call(octave::tree_evaluator&,
int, octave_value_list const&) ../libinterp/octave-value/ov-usr-fcn.cc:455
#95 0x7ffff5f0379e in
octave::tree_evaluator::visit_index_expression(octave::tree_index_expression&)
../libinterp/parse-tree/pt-eval.cc:2007
#96 0x7ffff5f3ece4 in
octave::tree_index_expression::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-idx.h:102
#97 0x7ffff5b67641 in
octave::tree_evaluator::evaluate(octave::tree_expression*, int)
../libinterp/parse-tree/pt-eval.h:312
#98 0x7ffff5f0bb1b in
octave::tree_evaluator::visit_statement(octave::tree_statement&)
../libinterp/parse-tree/pt-eval.cc:2775
#99 0x7ffff5f56566 in octave::tree_statement::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:119
#100 0x7ffff5f0c1fc in
octave::tree_evaluator::visit_statement_list(octave::tree_statement_list&)
../libinterp/parse-tree/pt-eval.cc:2844
#101 0x7ffff5b6826c in
octave::tree_statement_list::accept(octave::tree_walker&)
../libinterp/parse-tree/pt-stmt.h:194
#102 0x7ffff5ef19ef in octave::tree_evaluator::repl(bool)
../libinterp/parse-tree/pt-eval.cc:105
#103 0x7ffff66ea724 in octave::interpreter::main_loop()
../libinterp/corefcn/interpreter.cc:949
#104 0x7ffff66e77c7 in octave::interpreter::execute()
../libinterp/corefcn/interpreter.cc:694
#105 0x7ffff50245fe in octave::cli_application::execute()
../libinterp/octave.cc:391
#106 0x402954 in main ../src/main-cli.cc:92
#107 0x7fffeefe8412 in __libc_start_main (/lib64/libc.so.6+0x24412)
#108 0x4022ad in _start
(/home/dima/src/octave/gcc_asan_min/src/.libs/lt-octave-cli+0x4022ad)
0x62500003e9f8 is located 248 bytes inside of 8536-byte region
[0x62500003e900,0x625000040a58)
freed by thread T0 here:
#0 0x7ffff72c6480 in free (/lib64/libasan.so.5+0xef480)
#1 0x7ffff29630cf in WriteImage
(/lib64/libGraphicsMagick-Q16.so.3+0x8e0cf)
previously allocated by thread T0 here:
#0 0x7ffff72c6848 in __interceptor_malloc (/lib64/libasan.so.5+0xef848)
#1 0x7ffff2990096 in CloneImageInfo
(/lib64/libGraphicsMagick-Q16.so.3+0xbb096)
SUMMARY: AddressSanitizer: heap-use-after-free (/lib64/libasan.so.5+0xa22dc)
Shadow bytes around the buggy address:
0x0c4a7ffffce0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
0x0c4a7ffffcf0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
0x0c4a7ffffd00: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
0x0c4a7ffffd10: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
0x0c4a7ffffd20: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
=>0x0c4a7ffffd30: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd[fd]
0x0c4a7ffffd40: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
0x0c4a7ffffd50: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
0x0c4a7ffffd60: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
0x0c4a7ffffd70: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
0x0c4a7ffffd80: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
Shadow byte legend (one shadow byte represents 8 application bytes):
Addressable: 00
Partially addressable: 01 02 03 04 05 06 07
Heap left redzone: fa
Freed heap region: fd
Stack left redzone: f1
Stack mid redzone: f2
Stack right redzone: f3
Stack after return: f5
Stack use after scope: f8
Global redzone: f9
Global init order: f6
Poisoned by user: f7
Container overflow: fc
Array cookie: ac
Intra object redzone: bb
ASan internal: fe
Left alloca redzone: ca
Right alloca redzone: cb
==27830==ABORTING
Dmitri.
--
_______________________________________________________
Reply to this item at:
<https://savannah.gnu.org/bugs/?55397>
_______________________________________________
Message sent via Savannah
https://savannah.gnu.org/
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/05
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer,
Dmitri A. Sergatskov <=
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Rik, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Rik, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/06
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Rik, 2019/01/07
- [Octave-bug-tracker] [bug #55397] test imwrite error with address sanitizer, Dmitri A. Sergatskov, 2019/01/08