dblaikie accepted this revision.
dblaikie added a comment.

In D94655#2498811 <https://reviews.llvm.org/D94655#2498811>, @MaskRay wrote:

> In D94655#2498669 <https://reviews.llvm.org/D94655#2498669>, @dblaikie wrote:
>
>> In D94655#2498548 <https://reviews.llvm.org/D94655#2498548>, @MaskRay wrote:
>>
>>> In D94655#2498504 <https://reviews.llvm.org/D94655#2498504>, @dblaikie 
>>> wrote:
>>>
>>>> Is there any way to condition this on the type of the output, rather than 
>>>> the input? (or, more specifically, on whether machine code is being 
>>>> generated)
>>>>
>>>> Or maybe we could always pass the split-dwarf-file down through LLVM and 
>>>> not need to conditionalize it at all? It'd be a no-op if there's no DWARF 
>>>> in the IR anyway?
>>>
>>> I tried replacing `if (IRInput || Args.hasArg(options::OPT_g_Group)) {` 
>>> with `if (1)`, -gsplit-dwarf may produce .dwo for regular non-g .c compile.
>>
>> Are you saying that if you make that change -gsplit-dwarf does cause .dwo 
>> files to be created for non-g .c compiles? Do the dwo files have anything in 
>> them? I had modified llvm to dynamically choose split or non-split based on 
>> whether there was enough data to be worth splitting into a .dwo file, but I 
>> guess that situation might still be producing an empty .dwo file which isn't 
>> ideal - I haven't tested that.
>
>
>
>   % clang a.c -gsplit-dwarf -c
>   % readelf -WS a.dwo                
>   There are 2 section headers, starting at offset 0x50:
>   
>   Section Headers:
>     [Nr] Name              Type            Address          Off    Size   ES 
> Flg Lk Inf Al
>     [ 0]                   NULL            0000000000000000 000000 000000 00  
>     0   0  0
>     [ 1] .strtab           STRTAB          0000000000000000 000040 000009 00  
>     0   0  1

OK, thanks. Yeah, wouldn't mind if that got fixed at some point. It turns up in 
existing behavior/without patches with situations like `clang++ -gmlt 
-gsplit-dwarf x.cpp -c` if there's no inlining (that's the feature I 
mentioned/referenced in my previous comment) - since the split CU would be 
empty, LLVM avoids emitting a split CU at all - but does end up with that empty 
dwo situation you described. If that bug were fixed (lazily choosing not to 
create a dwo file at all, if no CUs were emitted into it) then we could pass 
the split dwarf request straight down unmodified all the time - making the 
architecture as orthogonal as the user-facing feature is intended to be.

>>> Since we already have the
>>>
>>>   // For -g0 or -gline-tables-only, drop -gsplit-dwarf. This gets a bit more
>>>   // complicated if you've disabled inline info in the skeleton CUs
>>>   // (SplitDWARFInlining) - then there's value in composing split-dwarf and
>>>   // line-tables-only, so let those compose naturally in that case.
>>>
>>> logic, I think altering `DwarfFission` in the driver is fine. If not, I'd 
>>> hope the backend to process `DwarfFission` ...
>>
>> Sorry, I'm not understanding this comment - could you describe/rephrase it 
>> in more detail?
>
> The driver already decides that DwarfFission should be disabled in -g0 and 
> -g1 cases. If the driver does not already do this, passing through 
> DwarfFission in the driver and letting CC1 handle it seems right to me.
>
> Since the driver already has some logic, I think adding more logic about IR 
> input types is fine.

My concern is that we'll miss other cases where code generation/dwo file 
creation is done when handling special cases like this & the code would be more 
robust if we didn't have to special case things like this.

But I guess it'll do for now.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D94655

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

Reply via email to