From mboxrd@z Thu Jan 1 00:00:00 1970 From: Johannes Berg Subject: Re: [PATCH] compiler.h: don't use temporary variable in __compiletime_assert() Date: Tue, 13 May 2014 11:26:24 +0200 Message-ID: <1399973184.4137.8.camel@jlt4.sipsolutions.net> References: <1399530685-7749-1-git-send-email-johannes@sipsolutions.net> <5370CFAC.40705@imgtec.com> <20140512141642.5eb526deed5ea32ad5bced72@linux-foundation.org> <1399966293.4137.5.camel@jlt4.sipsolutions.net> <5371DD92.5080304@imgtec.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <5371DD92.5080304@imgtec.com> Sender: linux-kernel-owner@vger.kernel.org To: James Hogan Cc: Andrew Morton , linux-kernel@vger.kernel.org, Peter Zijlstra , Daniel Santos , "Paul E. McKenney" , linux-next , linux-metag List-Id: linux-next.vger.kernel.org Hi James, > Subject: [PATCH] compiler.h: avoid sparse errors in > __compiletime_error_fallback() > > Usually, BUG_ON and friends aren't even evaluated in sparse, but > recently compiletime_assert_atomic_type() was added, and that now > results in a sparse warning every time it is used. > > The reason turns out to be the temporary variable, after it sparse no > longer considers the value to be a constant, and results in a warning > and an error. The error is the more annoying part of this as it > suppresses any further warnings in the same file, hiding other problems. > > Unfortunately the condition cannot be simply expanded out to avoid the > temporary variable since it breaks compiletime_assert on old versions of > GCC such as GCC 4.2.4 which the latest metag compiler is based on. > > Therefore #ifndef __CHECKER__ out the __compiletime_error_fallback which > uses the potentially negative size array to trigger a conditional > compiler error, so that sparse doesn't see it. > > Signed-off-by: James Hogan > Cc: Johannes Berg > Cc: Daniel Santos > Cc: Luciano Coelho > Cc: Peter Zijlstra > Cc: Paul E. McKenney > Cc: Andrew Morton Acked-by: Johannes Berg > It's not particularly pretty, if you can think of a better solution that > doesn't break old GCC I'm all ears. > #ifndef __compiletime_error > # define __compiletime_error(message) > -# define __compiletime_error_fallback(condition) \ > +/* > + * Sparse complains of variable sized arrays due to the temporary variable in > + * __compiletime_assert. Unfortunately we can't just expand it out to make > + * sparse see a constant array size without breaking compiletime_assert on old > + * versions of GCC (e.g. 4.2.4), so hide the array from sparse altogether. > + */ > +# ifndef __CHECKER__ > +# define __compiletime_error_fallback(condition) \ > do { ((void)sizeof(char[1 - 2 * condition])); } while (0) > -#else > +# endif > +#endif > +#ifndef __compiletime_error_fallback > # define __compiletime_error_fallback(condition) do { } while (0) > #endif That's pretty much what I had in mind, I may have expressed it a bit differently but the end result is the same. Thanks, johannes