GDB crashes when using GDB/MI and python pretty printers in some cases
Simon Marchi
simark@simark.ca
Fri Mar 18 15:57:26 GMT 2022
On 2022-03-17 09:29, Jan Vrany via Gdb wrote:
> Hi Simon, others,
>
> TL;DR:
>
> I'm experiencing GDB crashes with recent GDB which seem to be
> caused by commit 5f8ab46. Why is that I do not know (yet). Some
> details below.
>
> Full story:
>
> After updating my every-day-use GDB to commit
>
> commit c9178f285acf19e066be8367185d52837161b0a2 (HEAD -> master, origin/master)
> Author: Alan Modra <amodra@gmail.com>
> Date: Thu Mar 17 20:05:39 2022 +1030
>
> I'm experiencing GDB to crash on assertion failure in value_copy (value.c:1731).
> This is triggered when I single-step through code while having (my, custom) GDB/MI
> frontent displaying local variables with python pretty printers enabled.
>
> For example: doing this in frontend triggers the assertion failure:
>
> file gdb/testsuite/outputs/gdb.python/py-prettyprint/py-prettyprint-cxx
> source gdb/testsuite/outputs/gdb.python/py-prettyprint/py-prettyprint.py
> b add_item(container*, int)
> r
> dis 1
> fin
> n
> n (few more times until it crashes)
>
> This is the backtrace when it crashes:
>
> /home/jv/Proj...atches/gdb/gdb [stopped]
> Thread 1 [stopped] "gdb"
> 0 0x0000556077ADABD0 internal_error (errors.cc:51)
> 1 0x00005560776148A7 value_copy (value.c:1731)
> 2 0x0000556077360028 gdbpy_get_varobj_pretty_printer (py-prettyprint.c:655)
> 3 0x0000556077620E60 install_default_visualizer (varobj.c:1056)
> 4 0x00005560776210E9 install_new_value_visualizer (varobj.c:1127)
> 5 0x00005560776218B2 install_new_value (varobj.c:1339)
> 6 0x000055607761F6FB varobj_create (varobj.c:378)
> 7 0x0000556077245C05 mi_cmd_var_create (mi-cmd-var.c:132)
> 8 0x0000556077249F2B mi_command_mi::invoke (mi-cmds.c:58)
> 9 0x0000556077264F15 mi_cmd_execute (mi-main.c:2091)
> 10 0x000055607726450C captured_mi_execute_command (mi-main.c:1823)
> 11 0x000055607726498A mi_execute_command (mi-main.c:1947)
> 12 0x000055607724D21B mi_execute_command_wrapper (mi-interp.c:285)
> 13 0x000055607724D2A4 mi_execute_command_input_handler (mi-interp.c:314)
> 14 0x00005560770D7149 gdb_readline_no_editing_callback (event-top.c:878)
> 15 0x00005560770D6948 stdin_event_handler (event-top.c:524)
> 16 0x0000556077ADB57E gdb_wait_for_event (event-loop.cc:700)
> 17 0x0000556077ADB7FB gdb_wait_for_event (event-loop.cc:596)
> 18 0x0000556077ADB7FB gdb_do_one_event (event-loop.cc:237)
> 19 0x000055607721BA1B start_event_loop (main.c:421)
> 20 0x000055607721BB3F captured_command_loop (main.c:481)
> 21 0x000055607721D535 captured_main (main.c:1351)
> 22 0x000055607721D59B gdb_main (main.c:1366)
> 23 0x0000556076DA7E93 main (gdb.c:32)
> Thread 2 [stopped] "gdb worker"
> Thread 3 [stopped] "gdb worker"
> Thread 4 [stopped] "gdb worker"
> Thread 5 [stopped] "gdb worker"
>
>
> Unfortunately, so far I was unable to reproduce this outside my frontend. I tried
> to simulate what the frontend does (see attached file), but running GDB like
>
>
> gdb -i mi < crash-in-value_copy-reproducer.txt
>
>
> does not trigger it (arguably, the frontend issues silly / unnecessary MI commands, but still
> it should not crash GDB - I would think :-).
>
> If I revert commit
>
>
> commit 5f8ab46bc6918efb678deb5956c033e466afe301
> Author: Simon Marchi <simon.marchi@polymtl.ca>
> Date: Mon Jan 31 15:57:58 2022 -0500
>
> gdb: constify parameter of value_copy
>
> Everything seems to work just fine for me. I'm not at all familiar with this
> part of the GDB code so I do not know whether this change is the real culprit
> or not, let alone to explain why.
>
> I'll try to investigate further when I find more time, but in case someone brave
> enough to read through this post has an idea, I'll appreciate it!
>
> Thanks, Jan
Can you file a bug? Even if you don't have a simple reproducer yet, that's fine, include
the same info you gave above.
Simon
More information about the Gdb
mailing list