Hi,

>> My first shot at this would be to emit RTV/N in a dummy form as 
>> part of the epilogue and leave the usual Rn--->R0 setup as it is,
>> producing

>> (set (reg R0) (reg Rn))
...
>> (parallel [
>>      (set (reg R0) (reg R0))
>>      (return)
>> ])

>> and hope that the rnreg pass changes this to

>> (set (reg R0) (reg Rn))
...
>> (parallel [
>>      (set (reg R0) (reg Rn))
>>      (return)
>> ])

Thanks for your valuable suggestion.

We had implemented an insn as:-

(define_insn "return_rtv"
 [(parallel [
        (set (reg:SI R0_REG)
             (match_operand:SI "register_operand" "r"))
        (return)])]

We modified the implementation after the suggestion as:-

(define_insn "return_rtv"
 [(parallel [
        (set (reg:SI R0_REG)
             (reg:SI R0_REG))
        (return)])]

The complier still did not recognize the RTL pattern and the RTV/N Rn
instruction was not generated.

Can you please comment on the above modifications?

Regards,
Naveen.H.S.
KPIT Cummins Infosystems Ltd,
Pune (INDIA) 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  
Free download of GNU based tool-chains for Renesas' SH, H8, R8C, M16C   
and M32C Series. The following site also offers free technical support  
to its users. Visit http://www.kpitgnutools.com for details.    
Latest versions of KPIT GNU tools were released on June 1, 2007.        
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Reply via email to