From: Heiko Carstens <heiko.carstens@de.ibm.com>
To: Anton Blanchard <anton@samba.org>
Cc: torvalds@linux-foundation.org, akpm@linux-foundation.org,
willy@linux.intel.com, benh@kernel.crashing.org,
paulus@samba.org, linux-arch@vger.kernel.org,
linux-kernel@vger.kernel.org,
Martin Schwidefsky <schwidefsky@de.ibm.com>
Subject: Re: [PATCH 2/2]: atomic_t: Remove volatile from atomic_t definition
Date: Mon, 17 May 2010 10:58:34 +0200 [thread overview]
Message-ID: <20100517085833.GA2404@osiris.boeblingen.de.ibm.com> (raw)
In-Reply-To: <20100517043457.GA22416@kryten>
On Mon, May 17, 2010 at 02:34:57PM +1000, Anton Blanchard wrote:
>
> When looking at a performance problem on PowerPC, I noticed some awful code
> generation:
>
> c00000000051fc98: 3b 60 00 01 li r27,1
> ...
> c00000000051fca0: 3b 80 00 00 li r28,0
> ...
> c00000000051fcdc: 93 61 00 70 stw r27,112(r1)
> c00000000051fce0: 93 81 00 74 stw r28,116(r1)
> c00000000051fce4: 81 21 00 70 lwz r9,112(r1)
> c00000000051fce8: 80 01 00 74 lwz r0,116(r1)
> c00000000051fcec: 7d 29 07 b4 extsw r9,r9
> c00000000051fcf0: 7c 00 07 b4 extsw r0,r0
>
> c00000000051fcf4: 7c 20 04 ac lwsync
> c00000000051fcf8: 7d 60 f8 28 lwarx r11,0,r31
> c00000000051fcfc: 7c 0b 48 00 cmpw r11,r9
> c00000000051fd00: 40 c2 00 10 bne- c00000000051fd10
> c00000000051fd04: 7c 00 f9 2d stwcx. r0,0,r31
> c00000000051fd08: 40 c2 ff f0 bne+ c00000000051fcf8
> c00000000051fd0c: 4c 00 01 2c isync
>
> We create two constants, write them out to the stack, read them straight back
> in and sign extend them. What a mess.
>
> It turns out this bad code is a result of us defining atomic_t as a
> volatile int.
>
> We removed the volatile attribute from the powerpc atomic_t definition years
> ago, but commit ea435467500612636f8f4fb639ff6e76b2496e4b (atomic_t: unify all
> arch definitions) added it back in.
With your patches we can also revert 39475179d40996b4efa662e3825735a84d2526d1
"[S390] Improve code generated by atomic operations." which was created for
the very same reason.
Thanks!
next prev parent reply other threads:[~2010-05-17 8:57 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-05-17 4:33 [PATCH 1/2]: atomic_t: Cast to volatile when accessing atomic variables Anton Blanchard
2010-05-17 4:34 ` [PATCH 2/2]: atomic_t: Remove volatile from atomic_t definition Anton Blanchard
2010-05-17 8:58 ` Heiko Carstens [this message]
2010-05-17 15:01 ` Linus Torvalds
2010-05-17 20:13 ` Jamie Lokier
2010-05-17 20:20 ` Linus Torvalds
2010-05-19 13:03 ` Nick Piggin
2010-05-19 14:55 ` Linus Torvalds
2010-05-19 15:01 ` Paul E. McKenney
2010-05-19 19:54 ` David Miller
2010-05-19 22:50 ` Paul E. McKenney
2010-05-21 5:27 ` Nick Piggin
2010-05-21 5:54 ` David Miller
2010-05-21 6:06 ` Nick Piggin
2010-05-21 6:10 ` David Miller
2010-05-21 6:44 ` Eric Dumazet
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20100517085833.GA2404@osiris.boeblingen.de.ibm.com \
--to=heiko.carstens@de.ibm.com \
--cc=akpm@linux-foundation.org \
--cc=anton@samba.org \
--cc=benh@kernel.crashing.org \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=paulus@samba.org \
--cc=schwidefsky@de.ibm.com \
--cc=torvalds@linux-foundation.org \
--cc=willy@linux.intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).