From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from az33egw02.freescale.net (az33egw02.freescale.net [192.88.158.103]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "az33egw02.freescale.net", Issuer "Thawte Premium Server CA" (verified OK)) by ozlabs.org (Postfix) with ESMTPS id 64A95DDEF1 for ; Wed, 21 May 2008 09:20:02 +1000 (EST) Date: Tue, 20 May 2008 16:14:49 -0700 (PDT) From: Trent Piepho To: Andreas Schwab Subject: Re: [PATCH] [POWERPC] Improve (in|out)_beXX() asm code In-Reply-To: Message-ID: References: <1211316025-29069-1-git-send-email-tpiepho@freescale.com> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: Scott Wood , linuxppc-dev@ozlabs.org, linux-kernel@vger.kernel.org List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , On Wed, 21 May 2008, Andreas Schwab wrote: > Trent Piepho writes: > >> It's the _le versions that have a problem, since we can't get gcc to just use >> the register indexed mode. It seems like an obvious thing to have a >> constraint for, but I guess there weren't enough instructions that only come >> in 'x' versions to bother with it. There is a 'Z' constraint, "Memory operand >> that is an indexed or indirect from a register", but I tried it and it can use >> both "rb,ri" and "disp(rb)" forms. Actually, I'm not sure how 'Z' is any >> different than "m"? > > 'Z' will never emit a non-zero constant displacement. It's too bad gas doesn't appear to be smart enough to turn: stwbrx 0, 0(3) -or- stwbr 0, 0(3) into the desired: stwbrx 0, 0, 3