[LLVMdev] [PATCH] Support asm comment output

David Greene dag at cray.com
Mon Jul 13 10:02:28 PDT 2009


On Monday 13 July 2009 11:40, Chris Lattner wrote:

> > I was attempting to reduce the number of files affected, but if you
> > want this change I'll go ahead and do it.
>
> Makes sense, thanks.  Please do it as a separate patch from the other
> changes though since it will be large and mechanical.

Ok, no problem.

> > - Tag instructons with source line information (customers really
> > want this).
>
> Right, that would be nice.  This should be synthesizable from the
> DebugLoc on the instruction in the asm printer, no need to redundantly
> encode it into the comment field.

Except the DebugLoc stuff isn't all there yet AFAIK.  We've been using the
comment mechanism for over a year.  I agree we should move to synthesizing 
it from DebugLoc when it's ready.

We're not going to submit our line number stuff anyway (it's too much of a
hack) but we would like the comment infrastructure to be there.

> > - Tag instructions as register spills or reloads.
>
> I'm not sure what this means exactly, but would it be sufficient for
> the asmprinter to use isLoadFromStackSlot and print this if the FI is
> a spill slot?

Maybe.  I'm not sure what information is available here.  The other thing
this code does is tag it as a vector or scalar spill/reload.  Synthesizing
that might be trickier as you have to take the opcode into account.  It's a
lot of work, at the very least.

> > - Tag instructions with an ID of the tblgen pattern that generated
> > them.  This
> >  is super useful for debugging.
>
> this would also be really nice :).  This can be generated by the asm
> printer as well.

How so?  Where is the pattern information available?

> > - Tag instructions as top-of-loop, with nesting information (we use
> > this
> >  to do some static analysis on asm files).
>
> What part of the code generator would identify this?  It seems that
> the asmprinter could do this, but it is less obvious than the former
> ones.  It also seems that this is really a basic block property, not
> an instruction property.

Yes, we tag basic blocks.  That patch is coming later.  I added a pass
that explicitly examines loop information and adds the appropriate comments.
So this could be synthesized on-the-fly, I think.

> If these are the planned uses of the comments, it would be nice try to
> not add a per-machine-instr list of comments.  Instead, the asmprinter
> could synthesize the list as it processes each instruction.  This
> makes the list of comments transient instead of persistent in the
> machineinstrs.  Does that sound reasonable to you?

I still don't know how to synthesize tblgen pattern information in the 
asmprinter.  Except line numbers, which we need today.  Maybe all of the other 
current stuff can be synthesized.  I don't know what might come down the road, 
though.

What's the plan for meta-information?  Could comments go there when it's 
ready?  Would it be ok to add these for now and remove them as other 
mechanisms (DebugLoc, meta-information) come on-line?

                                -Dave



More information about the llvm-dev mailing list