Re: [PATCH] [ALPHA] Redefine ATOMIC_INIT and ATOMIC64_INIT to dropthe casts

From: Andrew Morton
Date: Wed Aug 15 2012 - 18:03:25 EST


On Sun, 12 Aug 2012 10:14:05 +0800
Fengguang Wu <fengguang.wu@xxxxxxxxx> wrote:

> From: Mel Gorman <mgorman@xxxxxxx>
>
> The following build error occurred during an alpha build:
>
> net/core/sock.c:274:36: error: initializer element is not constant
>
> Dave Anglin says:
> > Here is the line in sock.i:
> >
> > struct static_key memalloc_socks = ((struct static_key) { .enabled =
> > ((atomic_t) { (0) }) });
>
> The above line contains two compound literals. It also uses a designated
> initializer to initialize the field enabled. A compound literal is not a
> constant expression.
>
> The location of the above statement isn't fully clear, but if a compound
> literal occurs outside the body of a function, the initializer list must
> consist of constant expressions.
>
> Cc: <stable@xxxxxxxxxxxxxxx>
> Signed-off-by: Mel Gorman <mgorman@xxxxxxx>
> Signed-off-by: Fengguang Wu <fengguang.wu@xxxxxxxxx>

I'll remvoe the Cc:stable from this one - the regression is post-3.5.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/