All of lore.kernel.org
 help / color / mirror / Atom feed
From: Andi Kleen <andi@firstfloor.org>
To: Mikael Pettersson <mikpe@it.uu.se>
Cc: Andi Kleen <andi@firstfloor.org>,
	roel kluin <roel.kluin@gmail.com>,
	David Miller <davem@davemloft.net>,
	herbert@gondor.apana.org.au, linux-crypto@vger.kernel.org,
	akpm@linux-foundation.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] sha: prevent removal of memset as dead store in sha1_update()
Date: Fri, 26 Feb 2010 16:55:53 +0100	[thread overview]
Message-ID: <20100226155553.GD16335@basil.fritz.box> (raw)
In-Reply-To: <19335.60634.75667.480609@pilspetsen.it.uu.se>

> Instead of barrier(), this works with gcc-3.2.3 up to gcc-4.4.3
> for the purpose of making the memset() not disappear:
> 
> 	{
> 		struct s { char c[n]; };
> 		asm("" : : "m"(*(struct s *)p));
> 	}
> 
> Every byte in the [p,p+n[ range must be used. If you only use the
> first byte, via e.g. asm("" :: "m"(*(char*)p)), then the compiler
> _will_ skip scrubbing bytes beyond the first.
> 
> An explicit loop that uses each byte individually also works, but
> results in awful code with older compilers.

I suspect it would be worth asking for a __builtin for this.
iirc Visual C already has one.

BTW I remember finding a few more such cases in random user space
code in past code review.

-Andi
-- 
ak@linux.intel.com -- Speaking for myself only.

  reply	other threads:[~2010-02-26 15:55 UTC|newest]

Thread overview: 27+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-02-25 15:10 [PATCH] sha: prevent removal of memset as dead store in sha1_update() Roel Kluin
2010-02-25 15:10 ` Roel Kluin
2010-02-25 15:17 ` David Miller
2010-02-25 15:31   ` roel kluin
2010-02-25 15:31     ` roel kluin
2010-02-25 15:37     ` David Miller
2010-02-26 11:55     ` Andi Kleen
2010-02-26 14:20       ` Mikael Pettersson
2010-02-26 15:46         ` Mikael Pettersson
2010-02-26 15:55           ` Andi Kleen [this message]
2010-02-25 15:56 ` Mikael Pettersson
2010-02-25 16:16   ` Pekka Enberg
2010-02-25 16:16     ` Pekka Enberg
2010-02-25 16:29     ` Mikael Pettersson
2010-02-25 16:29       ` Mikael Pettersson
2010-02-25 16:33     ` roel kluin
2010-02-25 16:33       ` roel kluin
2010-02-25 17:06       ` roel kluin
2010-02-25 17:06         ` roel kluin
2010-02-25 16:33   ` Brian Gerst
2010-02-25 16:33     ` Brian Gerst
2010-02-25 17:09     ` Mikael Pettersson
2010-02-25 17:09       ` Mikael Pettersson
2010-02-25 17:32       ` Brian Gerst
2010-02-25 17:32         ` Brian Gerst
2010-02-25 19:47         ` Roel Kluin
2010-02-25 20:43           ` Roel Kluin

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=20100226155553.GD16335@basil.fritz.box \
    --to=andi@firstfloor.org \
    --cc=akpm@linux-foundation.org \
    --cc=davem@davemloft.net \
    --cc=herbert@gondor.apana.org.au \
    --cc=linux-crypto@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mikpe@it.uu.se \
    --cc=roel.kluin@gmail.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.