<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">2015-04-28 16:26 GMT-07:00 Matthias Braun <span dir="ltr"><<a href="mailto:matze@braunis.de" target="_blank">matze@braunis.de</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">To get this out first: I'd love to have a way to serialize machine-IR! I often spend a lot of time trying to create .ll files in a way that the machine-IR still looks a certain way when it finally hits the relevant passes in codegen. It would be so much easier to just specify the machine IR immediately before the pass I'm interested in.<br>
<br>
For that use case it is worth keeping the following things in mind:<br>
- Please try to keep the output of the various dump functions, esp. MachineInstr::dump(), MachineOperand::dump(), MachineBasicBlock::dump() as close as possible to the format you use for serializing. It would be unnecessary confusing to have the dump()s while I debug different from what I can read in a textfile. Having said that you don't necessarily have to change your serialization format to be like the dump() functions, you may just as well adjust the dump() functions - just avoid them being different without reason. I can also imagine that the serialization shows a bit less information in cases where the information which is obvious in a serialization context but not when dump()ing a piece in isolation.<br></blockquote><div><br></div><div>Ideally the new syntax would replace the existing print/dump syntax. The new syntax will lead to certain missing information when</div><div>this information can be inferred (e.g. the TiedTo and IsEarlyClobber attributes for register operands that I mentioned earlier in this thread),</div><div>so maybe we could have some sort of verbose dumping option where absolutely everything is dumped.</div><div>The syntax does try to be kind of similar to the current format, but at the same time it tries to be more parser and human friendly as well.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
- Design the format in a way that makes it easy for humans to create it. If the only way to produce these files reliably is by dumping existing machine-ir I will have a hard time designing minimal and easy to understand testcases. By that I mean mostly the possibility to leave out information that can be inferred or guessed, so the resulting test is compact and shows what it is about. Just looking at your example below there is a lot of information that is redundant or which could be filled in by sensible defaults: the function "number", the basic block number, predecessors and successors of a basic block, maybe allowing to leave out the llvm IR (though that probably is not allowed by CodeGen at the moment). </blockquote><div><br></div><div>I agree, one of my goals is to try to make it minimal and leave out things where it makes sense to do so. </div><div>I plan on making a lot of the YAML attributes optional, so that the user won't necessarily have to specify them,</div><div>and the parser will set the attributes to some predetermined default values or will try to infer them. I will</div><div>present my plans for those optional attributes in data structures when I will send out patches that serialize </div><div>the specific data structures, so feel free to check them out. </div><div><br></div><div>The LLVM IR is optional by the way, but a lot of passes will probably crash if you don't include it ;)</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<span class="HOEnZb"><font color="#888888"><br>
- Matthias<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
> On Apr 28, 2015, at 2:08 PM, Bevin Hansson <<a href="mailto:bevinh@sics.se">bevinh@sics.se</a>> wrote:<br>
><br>
> On 2015-04-28 20:18, Alex L wrote:<br>
>> 2015-04-28 10:15 GMT-07:00 Hal Finkel <<a href="mailto:hfinkel@anl.gov">hfinkel@anl.gov</a>>:<br>
>> Hi Alex,<br>
>> I think this looks promising. What are the 1 an 4 above? How are you<br>
>> proposing to serialize operand flags (dead, etc.)?<br>
>> -Hal<br>
>> Hi Hal,<br>
>> The 1 and 4 above are constants that are specific to x86 memory addressing,<br>
>> I believe they basically compute the address RSP + 1 * 0 + 4.<br>
>> I haven't settled on a final version of the operand flags (for registers)<br>
>> syntax, but at the moment I'm thinking of something like this:<br>
>> - The IsDef flag is implied by the use of the register before the '=',<br>
>> unless it's implicit.<br>
>> - TiedTo and IsEarlyClobber aren't not serialized, as they are defined by<br>
>> the instruction description. (I believe that's true in all cases, but I'm<br>
>> not 100% sure).<br>
>> - IsUndef, IsImp, IsKill, IsDead, IsInternalRead, IsDebug - keywords like<br>
>> 'implicit', 'undef', 'kill', 'dead' are used before the register e.g.<br>
>> 'undef %rax', 'implicit-def kill %eflags'.<br>
>> I don't have a syntax for the SubReg_TargetFlags at the moment.<br>
><br>
> Since the instruction format is partially based on the machine dump format,<br>
> you could use something similar to that, like '%reg:subreg'.<br>
><br>
> On an tangential note, IIRC the machine dumps store the virtual register<br>
> information (register class, mainly) in-band at the end of the instruction.<br>
> Based on the format you described, I'm assuming this is what would be stored<br>
> out-of-band in 'regInfo'.<br>
><br>
> / Bevin<br>
</div></div><div class="HOEnZb"><div class="h5">> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
<br>
</div></div></blockquote></div><br></div></div>