From: Simon Marchi <simark@simark.ca>
To: Guinevere Larsen <guinevere@redhat.com>, gdb-patches@sourceware.org
Cc: Guinevere Larsen <blarsen@redhat.com>
Subject: Re: [PATCH v5 3/5] gdb: Migrate frame unwinders to use C++ classes
Date: Fri, 4 Oct 2024 01:21:14 -0400 [thread overview]
Message-ID: <ce6062d9-f068-420f-bd8f-73e90da0b7fc@simark.ca> (raw)
In-Reply-To: <fb8d71cf-6bc0-4df7-9949-83698730697d@simark.ca>
Some more things I thought about...
>> + /* Default frame sniffer. Will always return that the unwinder
>> + is able to unwind the frame. */
>> + virtual int sniffer (const frame_unwind *self,
One nit: I think this method should be called just "sniff". When a
method is named after a thing, my brain adds an implicit "get_" in front
of it. So to me, a method named "sniffer" would return some sniffer
object. Here, I think it would make more sense to use an action verb,
because we want the unwinder to "sniff".
Oh and I guess another naming nit, I think frame_unwind should be named
frame_unwinder. A "thing" that unwinds stuff would be called an
"unwinder", not an "unwind". I don't know how you feel about changing
that.
And something else I just remembered, I am not really a fan of the
very abbreviated parameter names like this:
frame_unwind_trampoline (enum frame_type t, const struct frame_data *d,
frame_prev_arch_ftype *pa)
: frame_unwind ("trampoline", t, FRAME_UNWIND_GDB, d), prev_arch_p (pa)
{ }
When using an editor that provides tooltips when writing a function
call, the abbreviated names in the tooltip are not very helpful. I
would suggest using proper names.
>> +public:
>> + frame_unwind_trampoline (enum frame_type t, const struct frame_data *d,
>> + frame_prev_arch_ftype *pa)
>> + : frame_unwind ("trampoline", t, FRAME_UNWIND_GDB, d), prev_arch_p (pa)
>> + { }
>
> This "frame_data" thing appears to be some kind of opaque / private data
> that frame_unwind implementations can use? For those that you converted
> to proper classes (trampoline and python), could that data be stored in
> the frame_unwind_* object directly? It would remove some unnecessary
> indirections and make things simpler, I think.
>
> Actually, I gave it a try, and trampoline and python are the only
> implementations actually using the frame_data pointer. So if they stop
> using it, we can just get rid of that. That requires touching all the
> frame_unwind_legacy constructor call sites, but I was able to do that
> relatively easily with a global regex find & replace in VScode. [last
> minute edit: I just realized that I was building without
> --enable-targets=all, so take this with a grain of salt]
One more thought about all this: in an ideal world, the tramp_frame uses
should probably become sub-classes of frame_unwind_trampoline. Only
those sites that want to override the prev_arch method would need to do
it (AFAIK, the only one is aarch64_linux_rt_sigframe). The `init` and
`validate` callbacks in `tramp_frame` would become virtual methods of
`frame_unwind_trampoline`, and the other data fields of `tramp_frame`
would become fields of `frame_unwind_trampoline`. I started to
prototype it on top of this patch, and it would be quite a lot of work.
So let's keep that on the wishlist for now.
Simon
next prev parent reply other threads:[~2024-10-04 5:21 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-10-01 18:42 [PATCH v5 0/5] Modernize frame unwinders and add disable feature Guinevere Larsen
2024-10-01 18:42 ` [PATCH v5 1/5] gdb: make gdbarch store a vector of frame unwinders Guinevere Larsen
2024-10-02 21:49 ` Thiago Jung Bauermann
2024-10-08 17:01 ` Guinevere Larsen
2024-10-03 18:33 ` Simon Marchi
2024-10-04 18:37 ` Tom Tromey
2024-10-12 1:34 ` Thiago Jung Bauermann
2024-10-14 18:18 ` Guinevere Larsen
2024-10-17 22:53 ` Tom Tromey
2024-10-18 17:40 ` Guinevere Larsen
2024-10-17 23:41 ` Tom Tromey
2024-10-01 18:42 ` [PATCH v5 2/5] gdb: add "unwinder class" to " Guinevere Larsen
2024-10-02 22:08 ` Thiago Jung Bauermann
2024-10-03 18:46 ` Simon Marchi
2024-10-08 18:22 ` Guinevere Larsen
2024-10-08 18:37 ` Simon Marchi
2024-10-01 18:42 ` [PATCH v5 3/5] gdb: Migrate frame unwinders to use C++ classes Guinevere Larsen
2024-10-03 0:23 ` Thiago Jung Bauermann
2024-10-09 18:16 ` Guinevere Larsen
2024-10-03 20:06 ` Simon Marchi
2024-10-04 5:21 ` Simon Marchi [this message]
2024-10-10 14:10 ` Guinevere Larsen
2024-10-10 16:28 ` Simon Marchi
2024-10-09 20:00 ` Guinevere Larsen
2024-10-01 18:42 ` [PATCH v5 4/5] gdb: introduce ability to disable frame unwinders Guinevere Larsen
2024-10-02 6:10 ` Eli Zaretskii
2024-10-04 17:57 ` Guinevere Larsen
2024-10-03 2:45 ` Thiago Jung Bauermann
2024-10-08 19:23 ` Guinevere Larsen
2024-10-06 2:51 ` Simon Marchi
2024-10-09 13:32 ` Guinevere Larsen
2024-10-09 15:38 ` Simon Marchi
2024-10-01 18:42 ` [PATCH v5 5/5] gdb/testsuite: Test for a backtrace through object without debuginfo Guinevere Larsen
2024-10-03 2:47 ` Thiago Jung Bauermann
2024-10-03 6:58 ` Gerlicher, Klaus
2024-10-09 14:56 ` Guinevere Larsen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ce6062d9-f068-420f-bd8f-73e90da0b7fc@simark.ca \
--to=simark@simark.ca \
--cc=blarsen@redhat.com \
--cc=gdb-patches@sourceware.org \
--cc=guinevere@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox