This is the mail archive of the
mailing list for the GCC project.
Re: RTL generation patterns
- From: Jan Hubicka <jh at suse dot cz>
- To: Danish Samad <danishsamad at yahoo dot com>
- Cc: gcc at gcc dot gnu dot org, durdana at enabtech dot com, syed_rauf_ul_hassan at hotmail dot com
- Date: Wed, 27 Feb 2002 15:56:47 +0100
- Subject: Re: RTL generation patterns
- References: <firstname.lastname@example.org>
> I fail to understand how the second rtl
> (store)instrucion is generated from this pattern. how
> (match_operand:SI 0 "general_operand" "") produce
> (mem/f:SI (plus:SI (reg:SI 28)
> (const_int -16 [0xfffffff0])) 0)
> shouldnt it only produce a single rtl instruction like
> only a mem? please comment
When optimizing, gcc forces all nontrivial operands to be load to
registers first in order to asist CSE to do more optimizations.
Also may be that ARM is simply refusing constant 1 as general_operand
making gcc code generator to do the move in order to make expander
> Do You Yahoo!?
> Yahoo! Greetings - Send FREE e-cards for every occasion!