dblaikie added a comment.

Side note: This has become complicated enough it might be worth separating 
these patches now rather than later - changes to dumping should be separate 
from changes to llvm-dwp, for instance.

In D75929#1926834 <https://reviews.llvm.org/D75929#1926834>, @labath wrote:

> In D75929#1924373 <https://reviews.llvm.org/D75929#1924373>, @ikudrin wrote:
>
> > @dblaikie, @labath, as far as I can understand, the patch complies with 
> > your vision. The main difference is that the enum is still intended for 
> > internal use only, but it probably should not go to the public part before 
> > the proposed values are accepted. Anyway, even while the proposal of the 
> > combined index is not approved, I believe that the patch is useful per se 
> > because it allows reading standard index sections and can later be easily 
> > extended for combined indexes. The patch does not restrict that movement. 
> > Please, correct me if I misunderstand anything.
>
>
> Sorry about the delay. It took a while to get this to the top of my stack.
>
> Yes, this "complies with my/our vission", but looking at the 
> `UnknownColumnIds` field, I am starting to have second thoughts about that 
> vision. :( Being able to represent "unknown" columns and at the same time 
> mapping all columns to a internal representation makes things a bit awkward.
>
> The reason this wasn't a problem for location lists is that you cannot "skip 
> over" an unknown DW_LLE entry -- it terminates the parse right away.
>
> However, that is not the case for debug_?u_index, where you can easily ignore 
> unknown columns. In that light, I am wondering if it wouldn't be better after 
> all to stick to the on-disk column numbers internally (but maybe still keep 
> the "unified" v5 enum in the public interface). @dblaikie, what do you make 
> of that?
>
> (btw, is there a test case for the "unknown column" code path?)


I'm undecided - yeah, it is awkward having an extra data structure to store the 
original parsed values & then remapping them back, etc. Alternatively we could 
use a single 64 bit value - and store unknown values shifted up into the top 32 
bits (really I sort of wish they'd just used only 1 byte for these values - 
seems unreasonable that we'd need 256 sections... clearly we don't need them 
now)? & shift them back if the values too high & report it as unknown. Sort of 
doing something /like/ if the DWARF spec actually had an range reserved for 
implementation extensions, which will hopefully be added in the future.

But I wouldn't be completely opposed to the data structure keeping things in 
its parsed form & printing out based on the version of the index, etc. While 
having an API for querying based on the v5-with-extensions identifiers, though 
that seems a bit awkward.



================
Comment at: llvm/include/llvm/DebugInfo/DWARF/DWARFUnitIndex.h:47-48
+// For pre-standard ones, which correspond to sections being deprecated in
+// DWARFv5, the values are chosen more or less arbitrary and a tag "_EXT_"
+// is added to the names.
+//
----------------
Probably not arbitrarily - in the sense that this is an extension that 
consumers/producers will need to agree to - so maybe saying that ("non-standard 
extension"/"proposed for standardization" or something to that effect) and/or 
linking to the dwarf-discuss thread to support why these values were chosen & 
they can't be changed arbitrarily.


================
Comment at: llvm/lib/DebugInfo/DWARF/DWARFUnitIndex.cpp:96-100
   Version = IndexData.getU32(OffsetPtr);
+  if (Version != 2) {
+    *OffsetPtr = BeginOffset;
+    Version = IndexData.getU16(OffsetPtr);
+    if (Version != 5)
----------------
What endianness is this encoded with? If it's little endian, then a 2 byte 
field with 2 bytes of zero padding should be the same as reading a 4 bytes, or 
the other way around, right? So perhaps we could just always read it as 2 bytes 
then 2 bytes of padding rather than having to the version/reset/reread dance 
here?


================
Comment at: llvm/lib/DebugInfo/DWARF/DWARFUnitIndex.cpp:131
 
+  // Fix InfoColumnKind: in DWARFv5, type units also lay in .debug_info.dwo.
+  if (Header.Version == 5)
----------------
jhenderson wrote:
> also lay -> are
Should we be fixing it up here - or should we avoid setting it incorrectly in 
the first place?


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

https://reviews.llvm.org/D75929



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

Reply via email to