From: Thomas Weber <weber@corscience.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v4] ARM: Avoid compiler optimization for readb, writeb and friends.
Date: Wed, 12 Jan 2011 16:17:00 +0100 [thread overview]
Message-ID: <4D2DC5EC.3040607@corscience.de> (raw)
In-Reply-To: <1294611584-6098-1-git-send-email-wd@denx.de>
Am 09.01.2011 23:19, schrieb Wolfgang Denk:
> From: Alexander Holler <holler@ahsoftware.de>
>
> gcc 4.5.1 seems to ignore (at least some) volatile definitions,
> avoid that as done in the kernel.
>
> Reading C99 6.7.3 8 and the comment 114) there, I think it is a bug of that
> gcc version to ignore the volatile type qualifier used e.g. in __arch_getl().
> Anyway, using a definition as in the kernel headers avoids such optimizations when
> gcc 4.5.1 is used.
>
> Maybe the headers as used in the current linux-kernel should be used,
> but to avoid large changes, I've just added a small change to the current headers.
>
> Signed-off-by: Alexander Holler <holler@ahsoftware.de>
> Signed-off-by: Dirk Behme <dirk.behme@googlemail.com>
> Signed-off-by: Wolfgang Denk <wd@denx.de>
> Cc: Alessandro Rubini <rubini-list@gnudd.com>
> ---
> arch/arm/include/asm/io.h | 32 ++++++++++++++++++++------------
> 1 files changed, 20 insertions(+), 12 deletions(-)
>
> diff --git a/arch/arm/include/asm/io.h b/arch/arm/include/asm/io.h
> index ff1518e..3886f15 100644
> --- a/arch/arm/include/asm/io.h
> +++ b/arch/arm/include/asm/io.h
> @@ -117,21 +117,29 @@ extern inline void __raw_readsl(unsigned int addr, void *data, int longlen)
> *buf++ = __arch_getl(addr);
> }
>
> -#define __raw_writeb(v,a) __arch_putb(v,a)
> -#define __raw_writew(v,a) __arch_putw(v,a)
> -#define __raw_writel(v,a) __arch_putl(v,a)
> +#define __raw_writeb(v,a) __arch_putb(v,a)
> +#define __raw_writew(v,a) __arch_putw(v,a)
> +#define __raw_writel(v,a) __arch_putl(v,a)
>
> -#define __raw_readb(a) __arch_getb(a)
> -#define __raw_readw(a) __arch_getw(a)
> -#define __raw_readl(a) __arch_getl(a)
> +#define __raw_readb(a) __arch_getb(a)
> +#define __raw_readw(a) __arch_getw(a)
> +#define __raw_readl(a) __arch_getl(a)
>
> -#define writeb(v,a) __arch_putb(v,a)
> -#define writew(v,a) __arch_putw(v,a)
> -#define writel(v,a) __arch_putl(v,a)
> +/*
> + * TODO: The kernel offers some more advanced versions of barriers, it might
> + * have some advantages to use them instead of the simple one here.
> + */
> +#define dmb() __asm__ __volatile__ ("" : : : "memory")
> +#define __iormb() dmb()
> +#define __iowmb() dmb()
> +
> +#define writeb(v,c) ({ __iowmb(); __arch_putb(v,c); v; })
> +#define writew(v,c) ({ __iowmb(); __arch_putw(v,c); v; })
> +#define writel(v,c) ({ __iowmb(); __arch_putl(v,c); v; })
>
> -#define readb(a) __arch_getb(a)
> -#define readw(a) __arch_getw(a)
> -#define readl(a) __arch_getl(a)
> +#define readb(c) ({ u8 __v = __arch_getb(c); __iormb(); __v; })
> +#define readw(c) ({ u16 __v = __arch_getw(c); __iormb(); __v; })
> +#define readl(c) ({ u32 __v = __arch_getl(c); __iormb(); __v; })
>
> /*
> * The compiler seems to be incapable of optimising constants
Tested-by: Thomas Weber <weber@corscience.de>
on Devkit8000 with codesourcery arm2010.09 (gcc4.5.1) and arm2010q1 (gcc
4.4.1)
next prev parent reply other threads:[~2011-01-12 15:17 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-12-22 11:04 [U-Boot] [PATCH v3] ARM: Avoid compiler optimization for usages of readb, writeb and friends Alexander Holler
2010-12-22 14:50 ` Dirk Behme
2010-12-22 15:07 ` Alexander Holler
2011-01-01 12:04 ` Dirk Behme
2011-01-01 17:52 ` Alexander Holler
2011-01-01 18:25 ` Dirk Behme
2011-01-01 18:47 ` Alexander Holler
2011-01-01 19:21 ` Dirk Behme
2011-01-02 12:43 ` Alexander Holler
2011-01-02 13:29 ` Dirk Behme
2011-01-02 21:00 ` Alexander Holler
2011-01-10 14:53 ` Alexander Holler
2011-01-10 15:05 ` Wolfgang Denk
2011-01-11 3:53 ` Alexander Holler
2011-01-09 22:25 ` Wolfgang Denk
2011-01-10 16:13 ` Dirk Behme
2011-01-17 21:59 ` Wolfgang Denk
2011-01-09 22:19 ` [U-Boot] [PATCH v4] ARM: Avoid compiler optimization for " Wolfgang Denk
2011-01-12 15:17 ` Thomas Weber [this message]
2011-01-12 15:39 ` Alexander Holler
2011-01-12 16:40 ` Wolfgang Denk
2011-01-12 16:49 ` Alexander Holler
2011-01-15 13:13 ` Albert ARIBAUD
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=4D2DC5EC.3040607@corscience.de \
--to=weber@corscience.de \
--cc=u-boot@lists.denx.de \
/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.