diff options
| author | Felix Morgner <felix.morgner@ost.ch> | 2026-05-01 21:00:39 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@ost.ch> | 2026-05-01 21:00:39 +0200 |
| commit | 128e4a2adca6721254e8ffd290b670cc58b7a898 (patch) | |
| tree | 9c971205dd4a1ce733507961f6096bc96f511499 /scripts/gdb/kstd/smart_pointers.py | |
| parent | 61949538ad6d114c1c2a788928a0b9706b4efc76 (diff) | |
| download | kernel-128e4a2adca6721254e8ffd290b670cc58b7a898.tar.xz kernel-128e4a2adca6721254e8ffd290b670cc58b7a898.zip | |
debug: add support for smart pointer pretty printing
Diffstat (limited to 'scripts/gdb/kstd/smart_pointers.py')
| -rw-r--r-- | scripts/gdb/kstd/smart_pointers.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/scripts/gdb/kstd/smart_pointers.py b/scripts/gdb/kstd/smart_pointers.py new file mode 100644 index 0000000..9af16fd --- /dev/null +++ b/scripts/gdb/kstd/smart_pointers.py @@ -0,0 +1,50 @@ +import gdb + + +class KstdUniquePtrPrinter: + + def __init__(self, val): + self.val = val + self.type = val.type.template_argument(0) + + def to_string(self): + pointer = self.val["pointer"] + if int(pointer) == 0: + return f"kstd::unique_ptr<{self.type}> (empty)" + return f"kstd::unique_ptr<{self.type}>" + + def children(self): + pointer = self.val["m_ptr"] + if int(pointer) != 0: + yield ("get()", pointer) + yield ("*get()", pointer.dereference()) + + +class KstdSharedPtrPrinter: + + def __init__(self, val): + self.val = val + self.type = val.type.template_argument(0) + + def to_string(self): + pointer = self.val["pointer"] + cb = self.val["control_block"] + + if int(pointer) == 0 or int(cb) == 0: + return f"kstd::shared_ptr<{self.type}> (empty)" + + strong_refs = int(cb["m_strong_refs"]) + weak_refs = int(cb["m_weak_refs"]) + + return f"kstd::shared_ptr<{self.type}> (use_count={strong_refs}, weak_count={weak_refs})" + + def children(self): + pointer = self.val["pointer"] + control_block = self.val["control"] + + if int(pointer) != 0: + yield ("get()", pointer) + yield ("*get()", pointer.dereference()) + + if int(control_block) != 0: + yield ("[control_block]", control_block.dereference()) |
