On Wed, Jun 01, 2016 at 08:11:38PM -0400, Vishwanath Pai wrote:
> +static void
> +cfg_copy(struct hashlimit_cfg2 *to, void *from, int revision)
> +{
> +     if (revision == 1) {
> +             struct hashlimit_cfg1 *cfg = (struct hashlimit_cfg1 *)from;
> +
> +             to->mode = cfg->mode;
> +             to->avg = cfg->avg;
> +             to->burst = cfg->burst;
> +             to->size = cfg->size;
> +             to->max = cfg->max;
> +             to->gc_interval = cfg->gc_interval;
> +             to->expire = cfg->expire;
> +             to->srcmask = cfg->srcmask;
> +             to->dstmask = cfg->dstmask;
> +     } else if (revision == 2) {
> +             memcpy(to, from, sizeof(struct hashlimit_cfg2));
> +     } else {
> +             BUG();

BUG here is probably too much, this halts the system. I can see we
only use this somewhere else in this code. Instead, I'd suggest you
propagate an error back to userspace if this ever happen.

I would like to see if this spots any problem with our test
infrastructure under iptables/.

Thanks.

Reply via email to