On 07/18/2011 05:20 PM, dpadgett_mail-...@yahoo.com wrote:
Hello,

Does gcc IRA provide a mechanism to support spilling to registers instead of 
the stack?  For the particular target I'm looking at, there are some 
non-general-purpose registers that can be copied to and from more quickly than 
the stack, so would be preferable to use as a form of shareable spill slot in 
some cases.  One limitation, which is perhaps a significant one, is that these 
registers are not callee save, so one would only want to save to and restore 
from them when there is no intervening function call. If there is no current 
support for such a mechanism, any opinions on the value and practicality of 
adding one would be much appreciated.

Thanks, Don
It might work for new IRA without cover classes.

Pseudos will have classes containing usual registers and these special registers because they are really less costly than memory. If a pseudo crosses a call, the special registers could be more costly than memory.

All you need is to define the right costs for register and memory move cost hooks to achieve better costs for regular registers, worse costs for the special registers, and the worst cost for memory. If the pseudo intersects the call, the worst cost should be for the special registers. It can be achieved by right definition of move cost between special registers and memory.

Reply via email to