Nagaraju Mekala via llvm-dev
2018-Mar-02 11:09 UTC
[llvm-dev] generating multiple instructions for a single pattern
Hi All, I am working on a target which requires to generated two instructions for a single branch instruction. ex: imm 1 br r4,0xabcd branch address is 0x1abcd, imm has the upper 16 bits and br has lower 16 bits. Can anyone let me know how to write these kind of patterns in the InstrInfo.td file. Thanks in Advance, Nagaraju
David Chisnall via llvm-dev
2018-Mar-02 11:29 UTC
[llvm-dev] generating multiple instructions for a single pattern
On 2 Mar 2018, at 11:09, Nagaraju Mekala via llvm-dev <llvm-dev at lists.llvm.org> wrote:> > I am working on a target which requires to generated two > instructions for a single branch instruction. > ex: > imm 1 > br r4,0xabcd > branch address is 0x1abcd, imm has the upper 16 bits and br has > lower 16 bits. > > Can anyone let me know how to write these kind of patterns in the > InstrInfo.td file.Do the two instructions need to be together? Is one providing an operand via an implicit register? If the two are simply a sequence that must be emitted together, then the easiest thing to do is make it a pseudo and then expand it into two instructions later. If one is really providing part of the operand via an implicit register, then it’s best to describe that directly and let the scheduler decide where to put the first instruction. David
Nagaraju Mekala via llvm-dev
2018-Mar-02 11:45 UTC
[llvm-dev] generating multiple instructions for a single pattern
On Fri, Mar 2, 2018 at 4:59 PM, David Chisnall <David.Chisnall at cl.cam.ac.uk> wrote:> On 2 Mar 2018, at 11:09, Nagaraju Mekala via llvm-dev <llvm-dev at lists.llvm.org> wrote: >> >> I am working on a target which requires to generated two >> instructions for a single branch instruction. >> ex: >> imm 1 >> br r4,0xabcd >> branch address is 0x1abcd, imm has the upper 16 bits and br has >> lower 16 bits. >> >> Can anyone let me know how to write these kind of patterns in the >> InstrInfo.td file. > > Do the two instructions need to be together? Is one providing an operand via an implicit register? > > If the two are simply a sequence that must be emitted together, then the easiest thing to do is make it a pseudo and then expand it into two instructions later. If one is really providing part of the operand via an implicit register, then it’s best to describe that directly and let the scheduler decide where to put the first instruction.Thanks for the reply. yes they are dependent if the branch immediate value is > 0xffff then the imm instruction should generate other wise only "br" instruction is enough. Thanks, Nagaraju> > David >
Jatin Bhateja via llvm-dev
2018-Mar-02 14:49 UTC
[llvm-dev] generating multiple instructions for a single pattern
Hi Nagaraju, Few suggestions split this into following steps. 1/ DAG Legalization : Custom lower the instruction (branch in your case) appropriately in legalization to target specific DAG nodes and glue the nodes together which you want scheduler should schedule together. 2/ Instruction Selection : Define patterns to match the custom DAG nodes. Thus actual decision of creating multiple instruction is taken care by legalizer and selection phase is dump which does pattern matching over whatever DAG is feeded to it. Thanks, Jatin On Fri, Mar 2, 2018 at 4:39 PM, Nagaraju Mekala via llvm-dev < llvm-dev at lists.llvm.org> wrote:> Hi All, > > I am working on a target which requires to generated two > instructions for a single branch instruction. > ex: > imm 1 > br r4,0xabcd > branch address is 0x1abcd, imm has the upper 16 bits and br has > lower 16 bits. > > Can anyone let me know how to write these kind of patterns in the > InstrInfo.td file. > > Thanks in Advance, > Nagaraju > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20180302/88146190/attachment.html>
Jatin Bhateja via llvm-dev
2018-Mar-02 15:02 UTC
[llvm-dev] generating multiple instructions for a single pattern
Other suggestions 1/ Write a separate MI pass to split the macro MI which was generated earlier as a result of ISel to multiple MIs. 2/ Take the decision of splitting later in the pipeling during MC lowering. Decision about when you need to split should be driven by your intent to do any further processing over constituent instruction. ~ Jatin On Fri, Mar 2, 2018 at 8:19 PM, Jatin Bhateja <jatin.bhateja at gmail.com> wrote:> Hi Nagaraju, > > Few suggestions split this into following steps. > > 1/ DAG Legalization : Custom lower the instruction (branch in your case) > appropriately in legalization to target specific DAG nodes and glue the > nodes together which you want scheduler should schedule together. > > 2/ Instruction Selection : Define patterns to match the custom DAG nodes. > > Thus actual decision of creating multiple instruction is taken care by > legalizer and selection phase is dump which does pattern matching over > whatever DAG is > feeded to it. > > Thanks, > Jatin > > On Fri, Mar 2, 2018 at 4:39 PM, Nagaraju Mekala via llvm-dev < > llvm-dev at lists.llvm.org> wrote: > >> Hi All, >> >> I am working on a target which requires to generated two >> instructions for a single branch instruction. >> ex: >> imm 1 >> br r4,0xabcd >> branch address is 0x1abcd, imm has the upper 16 bits and br has >> lower 16 bits. >> >> Can anyone let me know how to write these kind of patterns in the >> InstrInfo.td file. >> >> Thanks in Advance, >> Nagaraju >> _______________________________________________ >> LLVM Developers mailing list >> llvm-dev at lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >> > >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20180302/e7558efd/attachment.html>