<table cellspacing="0" cellpadding="0" border="0" ><tr><td valign="top" style="font: inherit;">I try to define a register class<br>def GPR64 : RegisterClass<"mytarget", [i64], 64, [T0, T1.....]<br>to simulate even/odd pair of GPR32 register.<br>Actually, I just use GPR64 as a temporary register. <br>My CPU just support i32 Integer type directly.<br>I use FDR to save f64.<br>def FDR : RegisterClass<"mytarget", [f64], 64,[FD0, FD1, ....]<br><br>When I move f64 to even/odd pair register, I first move f64 into GPR64, <br>then move to 2 GPR32 register.<br><br>It worked very well for register binding.<br><br>But When I test some case. I find a register class error.<br>--------------<br><br>11405   0x9321bc8: f64,ch = FLDI 0x93436f8, 0x9343c20, 0x9321ac0, 0x9343674
 --<br>                                                                     |<br>                                                                     |<br>11428         0x9321304: f64 = Register 
 #1066---------|                 |<br>153 11429         0x9321bc8: <multiple use>             |                 |  <br>154 11430       0x93447fc: ch = CopyToReg 0x9320fdc, 0x9321304, 0x9321bc8 <--| <br><br>---------------<br>When llc merge the result of FLDI and register #1066, It find #1066 is <br>in GPR64 Register Class.<br>But I define FLDI to save it's result with FDR register at mytargetInstructInfo.td file.<br>So a error given.<br>12493 VReg = 1066<br>12494 VReg RegClass     size = 8, align = 8<br>12495 Expected RegClass size = 8, align = 8<br>12496 Fatal error, aborting.<br>12497 0  
 llc       0x08bbc5cb<br>12498 1   llc       0x08bbc93c<br>12499 2             0x00110400 __kernel_sigreturn + 0<br>++++++++++++++++++++++++++++<br>I define register class in mytargetRegisterInfo.td. In here, I binding all<br>register class with supported variable type. <br>I believe leaf node--Register is band with virtual register number at Initial DAG.<br><br>But I do not know why LLC use my GPR64 register to save f64 type variable?<br><br>I want to know where pass or function llc binding type with register class?<br><br>I guess the initial DAG is created incorrectly. <br><br>Which function first create IR--Register from *.bc and give it a virtual register number ,  I want to debug it to find error reason.<br><br>Best Regards,<br><br>   Ren Kun<br><br><br><br><br>--- <b>09年2月21日,周六, Evan Cheng
 <i><evan.cheng@apple.com></i></b> 写道:<br><blockquote style="border-left: 2px solid rgb(16, 16, 255); margin-left: 5px; padding-left: 5px;">发件人: Evan Cheng <evan.cheng@apple.com><br>主题: Re: [LLVMdev] help: about how to use tblgen to constraint operand.<br>收件人: hbrenkun@yahoo.cn, "LLVM Developers Mailing List" <llvmdev@cs.uiuc.edu><br>日期: 2009,221,周六,2:51上午<br><br><div id="yiv154800084"><br><div><div>On Feb 19, 2009, at 8:26 PM, 任坤 wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><table style="" border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font-family: inherit; font-style: inherit; font-variant: inherit; font-weight: inherit; font-size: inherit; line-height: inherit; font-size-adjust: inherit; font-stretch: inherit; -x-system-font: none;" valign="top"><div id="yiv110945996">hi, Dear Evan Cheng:<br><br>My cpu is i32 embeded CPU. I define pseudo register
 pair registers.<br><br>In mytargetRegisterInfo.td:<br>def T0: RegisterWithSubRegs<"t0",[R0,R1]>;<br>...<br>def GPR64 : RegisterClass<"mytarget", [i64], 64, [T0, T1.....]<br><br>In mytargetISelLowering.cpp:<br>I define i1, i8 , i16 and i32 are legal. <br><br>1. I still have problem. I save my function return double  value in R0 and R1. <br> It is expanded into two i32. But my GPR64 is defined to save i64. llvm finds<br> I have i64 GPR register. It will automatically decide not to expand i64 to two i32.<br><br>2. I guess I need a special pseudo instruction to move between GPR32 and GPR64.<br>How to move R0, R1 to T1( R2, R3 pair). and don't convert two i32 to i64?<br>Could I  use MyTargetInstrInfo::copyRegToReg() to handle this logic issue?</div></td></tr></tbody></table></blockquote><div><br></div>No. copyRegToReg only supports copying registers of the same (or compatible register classes).</div><div><br><blockquote
 type="cite"><table style="" border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font-family: inherit; font-style: inherit; font-variant: inherit; font-weight: inherit; font-size: inherit; line-height: inherit; font-size-adjust: inherit; font-stretch: inherit; -x-system-font: none;" valign="top"><div id="yiv110945996"><br><br>3. Maybe I can  study INSERT_SUBREG/EXTRACT_SUBREG at X86 porting file.</div></td></tr></tbody></table></blockquote><div><br></div>Yes.</div><div><br><blockquote type="cite"><table style="" border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font-family: inherit; font-style: inherit; font-variant: inherit; font-weight: inherit; font-size: inherit; line-height: inherit; font-size-adjust: inherit; font-stretch: inherit; -x-system-font: none;" valign="top"><div id="yiv110945996"><br><br>I will  do some research more deeply. I think the best way is that TableGen has register pair TypeProfile feature. :(
 </div></td></tr></tbody></table></blockquote><div><br></div>It's not a tablegen issue. It's easy to add the constraint to tablegen but the register allocator has to be able to allocate register pairs. That is definitely not a trivial task.</div><div><br></div><div>Evan</div><div><br><blockquote type="cite"><table style="" border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font-family: inherit; font-style: inherit; font-variant: inherit; font-weight: inherit; font-size: inherit; line-height: inherit; font-size-adjust: inherit; font-stretch: inherit; -x-system-font: none;" valign="top"><div id="yiv110945996"><br><br><br><br><br>But I find i64 data will not be ex<br>--- <b>09年2月20日,周五, Evan Cheng <i><<a rel="nofollow" target="_blank" href="mailto:echeng@apple.com">echeng@apple.com</a>></i></b> 写道:<br><blockquote style="border-left: 2px solid rgb(16, 16, 255); margin-left: 5px; padding-left: 5px;">发件人: Evan Cheng
 <<a rel="nofollow" target="_blank" href="mailto:echeng@apple.com">echeng@apple.com</a>><br>主题: Re: [LLVMdev] help: about how to use tblgen to constraint operand.<br>收件人: <a rel="nofollow" target="_blank" href="mailto:hbrenkun@yahoo.cn">hbrenkun@yahoo.cn</a>, "LLVM Developers Mailing List" <<a rel="nofollow" target="_blank" href="mailto:llvmdev@cs.uiuc.edu">llvmdev@cs.uiuc.edu</a>><br>日期: 2009,220,周五,1:11上午<br><br><div id="yiv2016100483">Currently there is no constraint that tells the register allocator to allocate a consecutive register pair. What I would suggest you do is to declare pseudo register pair registers (and corresponding register class, say PAIR_GPR). In this case, your myFMDRR would take one input of  PAIR_GPR class. The asm printer should be taught to print a PAIR_GPR register as two GPR registers (you should also teach the JIT of the same thing).<div><br></div><div>A PAIR_GPR register should be a super
 register of two GPR registers. e.g. r0r1_pair is a super register of r0 and r1. In order to *construct* a PAIR_GPR register, you have to use two INSERT_SUBREG. To extract out a GPR from a PAIR_GPR, you need to issue EXTRACT_SUBREG. In most cases, these will be nop's. In other cases, they are copies.</div><div><br></div><div>Evan</div><div><br><div><div>On Feb 19, 2009, at 2:00 AM, 任坤 wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><table border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font-style: inherit; font-variant: inherit; font-weight: inherit; font-size: inherit; line-height: inherit;" valign="top">I define a pattern to move two 32bits gpr to 64bits fpr. like arm instructure  fmdrr.<br>But I need to use an even/odd register pair to save  its 2 operands.<br>I define in mytarget.td:<br><br>myfmdrr:<br> SDTypeProfile<1, 2, [SDTCisVT<0, f64>, SDTCisVT<1, i32>,<br>
     SDTCisSameAs<1, 2>]>;<br>def my_fmdrr : ...........<br>def myFMDRR : ....<br>                      (outs FPR: $result), ins(GPR: $op1, GPR:$op2 )<br>                       [(setFPR: $result, (my_fmdrr GPR: $op1, GPR:$op2) )]<br><br>I create myfmdrr instructure in mytargetISelLowering.cpp. and its operands are in R0 and R1.<br>But after optimization, the operands are save R2 and R1. I know optimization pass does not <br>know myfmdrr operands constraint. But How I tell optimzition pass by tblgen??<br><br>Could I can control operand constraint in mytargetiSelLowering.cpp? How do I control?? <br><br></td></tr></tbody></table><br><hr size="1"><a rel="nofollow" target="_blank"
 href="http://cn.rd.yahoo.com/mail_cn/tagline/card/*http://card.mail.cn.yahoo.com/">  好玩贺卡等你发,邮箱贺卡全新上线!</a>_______________________________________________<br>LLVM Developers mailing list<br><a rel="nofollow" target="_blank" href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a rel="nofollow" target="_blank" href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a><br><a rel="nofollow" target="_blank" href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br></blockquote></div><br></div></div></blockquote></div></td></tr></tbody></table><br>       <hr size="1"><a rel="nofollow" target="_blank" href="http://cn.rd.yahoo.com/mail_cn/tagline/card/*http://card.mail.cn.yahoo.com/">  好玩贺卡等你发,邮箱贺卡全新上线!</a>_______________________________________________<br>LLVM Developers mailing
 list<br><a rel="nofollow" target="_blank" href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a rel="nofollow" target="_blank" href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a><br><a rel="nofollow" target="_blank" href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br></blockquote></div><br></div></blockquote></td></tr></table><br>


      <hr size=1><a href="http://cn.rd.yahoo.com/mail_cn/tagline/card/*http://card.mail.cn.yahoo.com/">  好玩贺卡等你发,邮箱贺卡全新上线!</a>