labath added a comment.

In D134041#3806994 <https://reviews.llvm.org/D134041#3806994>, @jasonmolenda 
wrote:

> In D134041#3805941 <https://reviews.llvm.org/D134041#3805941>, @labath wrote:
>
>> In D134041#3805034 <https://reviews.llvm.org/D134041#3805034>, 
>> @DavidSpickett wrote:
>>
>>>> That said I would *love* is someone changed the RegisterInfo structs into 
>>>> something saner, but I think that will need to be more elaborate than 
>>>> simply stuffing a std::vector member into it. I can give you my idea of 
>>>> how this could work, if you're interested in trying this out.
>>>
>>> Sure I'd be interested in that. I've just been hacking on this small part 
>>> of it so I don't have the full picture yet.
>>
>> I think that part of the problem is that nobody has a full picture of how 
>> RegisterInfos work anymore. :)
>>
>> I don't claim to have this fully thought out, but the idea goes roughly like 
>> this. For the past few years, we've been moving towards a world where LLDB 
>> is able to fill in lots of details about the target registers. I think we're 
>> now at a state where it is sufficient for the remote stub to specify the 
>> register name and number, and lldb will be able to fill on most of the 
>> details about that register: EH/DWARF/"generic" numbers, subregisters, etc. 
>> However, this code is only invoked when communicating remote stub -- not for 
>> core files.
>> On one hand, this kind of makes sense -- for core files, we are the source 
>> of the register info, so why wouldn't we provide the complete info straight 
>> away?
>
> An aside, I'm working with a group inside apple that has a JTAG style 
> debugger that can access not only the normal general purpose 
> registers/floating point/vector registers, but control registers like 
> AArch64's MDSCR_EL1 as one example. I haven't figured out the best format for 
> them to express this information in a Mach-O corefile yet, but I am thinking 
> towards a Mach-O LC_NOTE where they embed an XML register description for all 
> the registers they can provide (and it will require that size and maybe 
> offset are explicitly specified, at least), and a register context buffer of 
> bytes for all of the registers.  lldb would need to augment its list of 
> available registers with this.

Thanks for jumping in Jason. I forgot about the size field. I think that we 
need that as well. As for the offset, how do the Mach-O core files work? Are 
all registers placed into a single note segment? (so that an "offset" is 
well-defined). In elf, the registers are scattered in multiple notes (roughly 
according to register sets), and we need to (arbitrarily) concatenate them so 
that a single offset value is meaningful. But what this really confirms to me 
that the notion of "static" register info lists is just not sufficient any more.

> My vague memory is that they may have different registers available on each 
> core ("thread") so we would need to do this on per-"thread" basis.

That's interesting, but I think we should actually be in a fairly good shape 
for that now, since in the case of ARM SVE, we can have each thread configure 
the scalable registers with a different size.

> This is all vague hand-wavy at this point, but they have the information and 
> the debugger users want this information. At some point I'll want the 
> corefile to be able to augment or replace lldb's register information 
> (probably augment).

Seems reasonable to me.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D134041/new/

https://reviews.llvm.org/D134041

_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to