[PATCH 2/8] bfd/binutils: support for gdb target descriptions in the core file
Andrew Burgess
andrew.burgess@embecosm.com
Mon Jan 11 10:19:48 GMT 2021
* Andrew Burgess <andrew.burgess@embecosm.com> [2020-12-14 11:55:12 +0000]:
> * Luis Machado <luis.machado@linaro.org> [2020-12-03 09:16:33 -0300]:
>
> > On 12/2/20 7:58 PM, Jim Wilson wrote:
> > > On Wed, Dec 2, 2020 at 10:21 AM Luis Machado via Gdb-patches
> > > <gdb-patches@sourceware.org <mailto:gdb-patches@sourceware.org>> wrote:
> > >
> > > For the constant, I find the magic number amusing, but I don't think it
> > > does any good when you're trying to find out why that particular magic
> > > number was picked, and what the next number should be.
> > >
> > > Should we go with the basic increasing ID instead? I think this
> > > would be
> > > 7, right after NT_AUXV.
> > >
> > >
> > > 7 is NT_FREEBSD_THRMISC which would prevent use of this on FreeBSD. I
> > > know this is primarily for bare metal core files, but it might be useful
> > > for linux and *bsd systems that have different register sets, because of
> > > different extensions, with vector versus without vector, or because
> > > different hardware has different sets of implemented CSRs. We don't
> > > appear to have reserved ranges for NT_* values, though we sort of have a
> > > scheme for processor specific values, e.g. 0x1XX for ppc, 0x2XX for x86,
> > > 0x3XX for s390, etc. OS specific values tend to be low values below
> > > 0x100 but above 6, with only FreeBSD starting at 7 and most others
> > > starting at 10. So that leaves high values like ascii encodings of the
> > > NT_* name as safe for new uses. There are 3 of these already, this
> > > would be a fourth one.
> >
> > Sure, we should make this generic for all OS' to use.
> >
> > The processor-specific values are a good example of organized ID structure.
> > They're all pretty obvious to look at and to identify.
> >
> > If the OS-specific values are low ID's, then maybe we should start a new
> > range of high values for the generic NT_* notes. That should make things
> > more organized in the future, and folks will know what the next ID is.
> >
> > I don't particularly think having 3 ascii encoded constants is a good
> > motivation for having more. NT_PRXFPREG is Linux-specific, which is not
> > good.
> >
> > Otherwise, if we're sticking to the ascii encodings, we should document that
> > and group them together in their own section instead of just grouping them
> > with the Linux ones, which is a bit misleading.
>
> What if I set aside the values 0xff000000 to 0xffffffff for non-os
> specific notes, the new comment and code might look like this:
>
> /* The range 0xff000000 to 0xffffffff is set aside for notes that
> might be applicable for any OS. This range of values will
> hopefully not conflict with OS specific, but architecture
> agnostic notes, which tend to have low values, or architecture
> specific notes that tend to have values in the range 0x100+. */
>
> #define NT_GDB_TDESC 0xff000000
>
> Thoughts?
Ping!
Any thoughts on the above suggestion (using constant 0xff000000)
compared to the original suggestion (using constant 0x54444553)?
Thanks,
Andrew
>
> Thanks,
> Andrew
More information about the Gdb-patches
mailing list