This is the mail archive of the
gcc-patches@gcc.gnu.org
mailing list for the GCC project.
Re: [RTL, ColdFire 24/63] Add support for a MODE_INDEX_REG_CLASS macro
- From: Jeffrey Law <law at redhat dot com>
- To: Richard Sandiford <richard at codesourcery dot com>
- Cc: gcc-patches at gcc dot gnu dot org, mark at codesourcery dot com
- Date: Tue, 27 Feb 2007 11:21:45 -0700
- Subject: Re: [RTL, ColdFire 24/63] Add support for a MODE_INDEX_REG_CLASS macro
- References: <874pqzw4w1.fsf@firetop.home> <87odp7tag7.fsf_-_@firetop.home> <87k5zvtad6.fsf_-_@firetop.home> <87fyajtaas.fsf_-_@firetop.home> <87bql7ta58.fsf_-_@firetop.home> <877ivvt9ws.fsf_-_@firetop.home> <873b6jt9r5.fsf_-_@firetop.home> <87y7obrv3h.fsf_-_@firetop.home> <87tzyzrv1p.fsf_-_@firetop.home> <87ps9nruzl.fsf_-_@firetop.home> <87lkkbrux2.fsf_-_@firetop.home> <87hcuzruvd.fsf_-_@firetop.home> <87d55nruu3.fsf_-_@firetop.home> <878xgbruqs.fsf_-_@firetop.home> <1168457319.28081.615.camel@sweet.slc.redhat.com> <87k5zuinc0.fsf@firetop.home> <1168983686.28081.842.camel@sweet.slc.redhat.com> <87ps9efc4t.fsf@talisman.home> <1171321913.4134.162.camel@sweet.slc.redhat.com> <87bqjx9j0r.fsf@firetop.home> <1171472988.4134.196.camel@sweet.slc.redhat.com> <87vei47ij9.fsf@firetop.home>
- Reply-to: law at redhat dot com
On Wed, 2007-02-14 at 17:31 +0000, Richard Sandiford wrote:
> > modes.
>
> Well, I agree making double_reg_address_ok an array of booleans
> make sense in principle. However, I think we first need to make
> INDEX_REG_CLASS and BASE_REG_CLASS agree with G_I_L_A. (INDEX_REG_CLASS
> is supposed to be NO_REGS if indexing isn't supported.)
But the issue here isn't that some index registers are valid in some
cases and not in others. The issue is that indexing as a whole is valid
in some cases and not others.
>
> Once you do that, there is no current need to make double_reg_address_ok
> an array of booleans, and doing so would just make the compiler slightly
> slower. So although I agree we should it if some other port needs it
> (i.e. if some other port allows disp(base,index) addresses for some
> modes and allows only plain (base,index) address for others), I don't
> think we should otherwise.
But I strongly feel that "fixing" INDEX_REG_CLASS is just papering over
the bogus double_reg_address_ok bits. I really wish I had pushed on
getting double_reg_address_ok fixed eons ago, but it was a different
time and a different development environment.
If we look at the MODE_BASE_blah macros they were introduced to deal
with different problems.
For the thumb the set of valid base registers differs based on the mode
of the memory reference. Note that indexing is still valid, only the
set of valid base registers changes.
For the blackfin the set of valid registers changes based on the type
of memory reference as well (reg+d vs autoinc).
The coldfire issue is completely and totally different. For the
coldfire the set of valid index registers does not change. ie,
every mode that allows indexing allows the same set of index
registers. But you're trying to use that hook to deal with your
coldfire issues (where indexing is simply not allowed in some modes).
More shortly...
Jeff