From: Doug Evans <xdje42@gmail.com>
To: Tom Tromey <tromey@redhat.com>
Cc: gdb-patches@sourceware.org
Subject: Re: [PATCH 0/4] baby step toward multi-target
Date: Sun, 10 Aug 2014 20:02:00 -0000 [thread overview]
Message-ID: <m3a97c9kqs.fsf@sspiff.org> (raw)
In-Reply-To: <1405711635-1102-1-git-send-email-tromey@redhat.com> (Tom Tromey's message of "Fri, 18 Jul 2014 13:27:11 -0600")
Tom Tromey <tromey@redhat.com> writes:
> My multi-target branch is basically dead, I think, mostly due to heavy
> conflicts with all the other target changes that have happened in the
> meantime.
This is an important bit of functionality that needs to be done.
Since we just released 7.8, and in order to prevent such things
happening again, I think it would be reasonable to put more
resources into getting this done, and delay other things for awhile.
[Assuming various factors like it won't take an inordinate amount
of time, and the end result is the more preferred one, and probably
a few others :-).]
$0.02
> However recently I realized that there is a less invasive
> way to achieve many of the same effects, and a way to salvage some of
> the smaller cleanups done there.
>
> In particular on the branch I attempted to split target_ops into a
> vtable-like object and a target state object. As you might imagine
> this patch touches a large amount of code and is hard both to keep up
> to date, and to test.
That was my understanding of where we were headed.
> This little series, on the other hand, takes a less invasive approach.
> The idea here is that rather than doing a huge target_ops split,
> instead just sometimes make copies of the target_ops when pushing.
> This lets the copies keep their own state; copies are needed in the
> long run because multiple target stacks will be active and a given
> target_ops only has one "beneath" pointer.
Which version of the long run?
Wouldn't dynamic properties of the object be kept in the object
and not the vtable?
Or is some custom dynamic interitance being done here?
I can imagine that being useful to facilitate inserting
debug targets into the mix.
By way of analogy, I'd be curious how this would be done in c++.
[Just trying to understand the situation better.]
> Here corelow is used as the example of how to do a conversion.
> There's a bit of cleanup and infrastructure initially, and then the
> final patch moves the corelow global state into a new subclass of
> target_ops, which is instantiated and pushed.
>
> If this approach seems reasonable then it's not too hard to pull over
> some of the other target conversions from the branch.
>
> This series also shows the spots to change if you want to make the
> debug target wrap each stratum in the target stack -- each wrapping
> debug target would be to_xclose-ish, and spots like target_is_pushed
> would be taught to unwrap.
>
> Built and regtested on x86-64 Fedora 20.
prev parent reply other threads:[~2014-08-10 20:02 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-18 19:27 Tom Tromey
2014-07-18 19:27 ` [PATCH 2/4] simplify target_is_pushed Tom Tromey
2014-07-29 13:22 ` Joel Brobecker
2014-07-29 15:16 ` Tom Tromey
2014-07-18 19:27 ` [PATCH 1/4] move core_bfd to program space Tom Tromey
2014-07-18 19:45 ` [PATCH 3/4] add to_identity Tom Tromey
2014-07-29 14:56 ` Joel Brobecker
2014-07-29 15:11 ` Tom Tromey
2014-07-18 20:44 ` [PATCH 4/4] convert corelow to to_xclose Tom Tromey
2014-07-29 15:11 ` [PATCH 0/4] baby step toward multi-target Pedro Alves
2014-07-29 15:15 ` Tom Tromey
2014-07-29 16:32 ` Pedro Alves
2014-07-29 19:04 ` Tom Tromey
2014-07-29 21:32 ` Doug Evans
2014-08-11 5:54 ` Doug Evans
2014-07-29 15:40 ` Doug Evans
2014-08-10 20:02 ` Doug Evans [this message]
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=m3a97c9kqs.fsf@sspiff.org \
--to=xdje42@gmail.com \
--cc=gdb-patches@sourceware.org \
--cc=tromey@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