<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Jun 7, 2012, at 10:54 PM, Hal Finkel wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><span class="Apple-style-span" style="border-collapse: separate; font-family: Optima; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; "><span class="Apple-style-span" style="font-family: monospace; ">For example, sometimes LiveIntervals asserts with:<br> register:<br>%CTR8<br>clang: /llvm-trunk/lib/CodeGen/LiveIntervalAnalysis.cpp:446:<br>void llvm::LiveInterval<br>s::handlePhysicalRegisterDef(llvm::MachineBasicBlock*,<br>llvm::MachineBasicBlock::iterator, llvm::SlotIndex,<br>llvm::MachineOperand&, llvm::LiveInt erval&): Assertion<br>`!isAllocatable(interval.reg) && "Physregs shouldn't be live out!"'<br>failed.<br></span></span></blockquote></div><div><br></div><div>When machine code is still in SSA form, there are restrictions on what can be done with physical registers, which by their nature can't be in SSA form. Lang and I have been trying to come up with some rules, but we haven't found the right set yet.</div><div><br></div><div>So far, we are enforcing:</div><div><br></div><div>- Allocatable registers cannot be live across basic blocks, except on entry to ABI blocks (the entry block and landing pads).</div><div><br></div><div>- Unallocatable registers may be live across basic blocks, but you can't use aliases. (For example, you can't define CTR8 in one block and read CTR in another).</div><div><br></div><div>- Reserved registers can do whatever you want, but defs are treated as having side effects, blocking certain optimizations like dead code elimination. (You don't want to DCE a stack pointer update).</div><div><br></div><div>In this case, the problem is that CTR and CTR8 are allocatable because CTRRC and CTRRC8 are allocatable. You can set 'isAllocatable = 0' in those register classes.</div><div><br></div><div>Unfortunately, that breaks your TCRETURNri instructions. Sorry!</div><div><br></div><div>Singleton register classes are dangerous because it is so easy to extend the live range of virtual registers without checking for interference. If you accidentally cross two live ranges, you get horrible spilling as you've seen. We try to use explicit unallocatable physreg liveness for singletons like X86::EFLAGS and ARM::CPSR, but isel and TableGen aren't making it easy.</div><div><br></div><div>/jakob</div><div><br></div></body></html>