Re: [PATCH] BUILD_BUG_ON: make it handle more cases

From: Stephen Rothwell
Date: Thu Nov 05 2009 - 01:38:56 EST


Hi Rusty,

On Thu, 5 Nov 2009 16:58:36 +1030 Rusty Russell <rusty@xxxxxxxxxxxxxxx> wrote:
>
> Huh? virtio_has_feature does:
>
> if (__builtin_constant_p(fbit))
> BUILD_BUG_ON(fbit >= 32);
> else
> BUG_ON(fbit >= 32);

In Linus' tree (and linux-next) it looks like this:

static inline bool virtio_has_feature(const struct virtio_device *vdev,
unsigned int fbit)
{
/* Did you forget to fix assumptions on max features? */
MAYBE_BUILD_BUG_ON(fbit >= 32);

if (fbit < VIRTIO_TRANSPORT_F_START)
virtio_check_driver_offered_feature(vdev, fbit);

return test_bit(fbit, vdev->features);
}

> So, if it's not a constant, gcc should throw away that first branch. If it
> is, it should optimize it away (and no, these are not real bugs AFAICT).

Your version above may well fix the problem. Alternatively marking it
__always_inline way work as well.

> I did a 4.3.3 allmodconfig with this patch on 64-bit a few days back and all
> was fine. Will try 4.4.0 now.

4.4 is more problematic.

--
Cheers,
Stephen Rothwell sfr@xxxxxxxxxxxxxxxx
http://www.canb.auug.org.au/~sfr/

Attachment: pgp00000.pgp
Description: PGP signature