public inbox for gdb-prs@sourceware.org
help / color / mirror / Atom feed
* [Bug mi/31324] New: -var-create: slowdown due to children printing
@ 2024-02-01 12:17 dmitry.neverov at jetbrains dot com
2024-02-01 12:51 ` [Bug mi/31324] " dmitry.neverov at jetbrains dot com
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: dmitry.neverov at jetbrains dot com @ 2024-02-01 12:17 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=31324
Bug ID: 31324
Summary: -var-create: slowdown due to children printing
Product: gdb
Version: 14.1
Status: UNCONFIRMED
Severity: normal
Priority: P2
Component: mi
Assignee: unassigned at sourceware dot org
Reporter: dmitry.neverov at jetbrains dot com
Target Milestone: ---
Fix for https://sourceware.org/bugzilla/show_bug.cgi?id=11335
changed the logic of -var-create. Before, if a var had children,
-var-create returned "{...}" as a value. Now, it appends the
pretty printer's to_string result to the printed children.
It looks like there is no way to disable this behavior.
New logic has performance implications. For example, running
-var-create v1 * "ss"
in the following program:
typedef struct {
int x, y;
} SlowStruct;
int main() {
SlowStruct ss[100] = {0};
return 0; //break
}
will be slow if SlowStruct has a slow pretty-printer:
import gdb
import gdb.printing
import time
class SlowStructPrinter:
def __init__(self, val):
self.val = val
def to_string(self):
time.sleep(1)
return ("slow struct")
def slowStructPrinterMatcher(val):
if "SlowStruct" in str(val.type):
return SlowStructPrinter(val)
gdb.pretty_printers.append(slowStructPrinterMatcher)
This was fast in 13.2, because children were not printed.
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug mi/31324] -var-create: slowdown due to children printing
2024-02-01 12:17 [Bug mi/31324] New: -var-create: slowdown due to children printing dmitry.neverov at jetbrains dot com
@ 2024-02-01 12:51 ` dmitry.neverov at jetbrains dot com
2024-02-01 16:20 ` tromey at sourceware dot org
2024-02-02 9:07 ` dmitry.neverov at jetbrains dot com
2 siblings, 0 replies; 4+ messages in thread
From: dmitry.neverov at jetbrains dot com @ 2024-02-01 12:51 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=31324
--- Comment #1 from Dmitry Neverov <dmitry.neverov at jetbrains dot com> ---
To reproduce, one needs to register a pretty-printer for arrays:
class ArrayPrinter(object):
def __init__(self, val, type):
self.val = val
self.type = type
def display_hint(self):
return 'array'
def to_string(self):
return None
def children(self):
return self.Iterator(self.val, self.type)
class Iterator:
def __init__(self, val, type):
self.val = val
try:
(start_index, end_index) = type.range()
self.index = start_index - 1
self.end_index = end_index + 1
except:
self.index = -1
self.end_index = untypedef(type).sizeof //
untypedef(type).target().sizeof
def __iter__(self):
return self
def __next__(self):
self.index += 1
if self.index == self.end_index:
raise StopIteration
return ('[{0}]'.format(self.index), self.val[self.index])
def next(self):
return self.__next__()
def arrayMatcher(val):
if val.type.code == gdb.TYPE_CODE_ARRAY:
return ArrayPrinter(val, type)
return None
gdb.pretty_printers.append(arrayMatcher)
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug mi/31324] -var-create: slowdown due to children printing
2024-02-01 12:17 [Bug mi/31324] New: -var-create: slowdown due to children printing dmitry.neverov at jetbrains dot com
2024-02-01 12:51 ` [Bug mi/31324] " dmitry.neverov at jetbrains dot com
@ 2024-02-01 16:20 ` tromey at sourceware dot org
2024-02-02 9:07 ` dmitry.neverov at jetbrains dot com
2 siblings, 0 replies; 4+ messages in thread
From: tromey at sourceware dot org @ 2024-02-01 16:20 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=31324
Tom Tromey <tromey at sourceware dot org> changed:
What |Removed |Added
----------------------------------------------------------------------------
CC| |tromey at sourceware dot org
--- Comment #2 from Tom Tromey <tromey at sourceware dot org> ---
(In reply to Dmitry Neverov from comment #1)
> To reproduce, one needs to register a pretty-printer for arrays:
> def to_string(self):
> return None
I wouldn't expect this to be slow.
Anyway, an MI feature to support this would be ok, I guess.
Normally it's better to just fix the pretty-printer though,
since if that is slow it's going to impact interactive
use as well.
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug mi/31324] -var-create: slowdown due to children printing
2024-02-01 12:17 [Bug mi/31324] New: -var-create: slowdown due to children printing dmitry.neverov at jetbrains dot com
2024-02-01 12:51 ` [Bug mi/31324] " dmitry.neverov at jetbrains dot com
2024-02-01 16:20 ` tromey at sourceware dot org
@ 2024-02-02 9:07 ` dmitry.neverov at jetbrains dot com
2 siblings, 0 replies; 4+ messages in thread
From: dmitry.neverov at jetbrains dot com @ 2024-02-02 9:07 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=31324
--- Comment #3 from Dmitry Neverov <dmitry.neverov at jetbrains dot com> ---
Created attachment 15348
--> https://sourceware.org/bugzilla/attachment.cgi?id=15348&action=edit
slow array pretty-printing reproducible
> I wouldn't expect this to be slow.
It is slow because children's pretty-printing result is included into
the parent value. The attached script is instant with gdb 13.2, but
takes several seconds in gdb 14.1.
> Normally it's better to just fix the pretty-printer though,
> since if that is slow it's going to impact interactive
> use as well.
The pretty-printer can be slow due to slow symbol lookup
(e.g. https://sourceware.org/bugzilla/show_bug.cgi?id=30520). It is
not clear how to fix it.
In an interactive front-end with gdb 13.2 there was a slow-down only
when array is expanded, so users could avoid it if they didn't want to
inspect array elements.
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2024-02-02 9:07 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-02-01 12:17 [Bug mi/31324] New: -var-create: slowdown due to children printing dmitry.neverov at jetbrains dot com
2024-02-01 12:51 ` [Bug mi/31324] " dmitry.neverov at jetbrains dot com
2024-02-01 16:20 ` tromey at sourceware dot org
2024-02-02 9:07 ` dmitry.neverov at jetbrains dot com
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).