Hi there,

Sorry - cant help you on earlier question in the thread on
syntax of cls_group config (but we can revisit after resolving
this). You should always copy the maintainer if you want quick
answers (for cls_group case Thomas Graf).

On your patch:
I think you have found a real issue (I have a strong feeling
it has everything to do with your config process)

Comments below:

On Fri, 2009-05-29 at 14:18 +0900, Minoru Usui wrote:
> Hi, 


> diff --git a/net/sched/cls_api.c b/net/sched/cls_api.c
> index 0759f32..756148b 100644
> --- a/net/sched/cls_api.c
> +++ b/net/sched/cls_api.c
> @@ -266,11 +266,6 @@ replay:
>                       goto errout;
>               }
>  
> -             spin_lock_bh(root_lock);
> -             tp->next = *back;
> -             *back = tp;
> -             spin_unlock_bh(root_lock);
> -
>       } else if (tca[TCA_KIND] && nla_strcmp(tca[TCA_KIND], tp->ops->kind))
>               goto errout;
>  
> @@ -314,8 +309,17 @@ replay:
>       }
>  
>       err = tp->ops->change(tp, cl, t->tcm_handle, tca, &fh);
> -     if (err == 0)
> -             tfilter_notify(skb, n, tp, fh, RTM_NEWTFILTER);
> +     if (err) {
> +             tcf_destroy(tp);
> +             goto errout;
> +     }
> +
> +     spin_lock_bh(root_lock);
> +     tp->next = *back;
> +     *back = tp;
> +     spin_unlock_bh(root_lock);
> +
> +     tfilter_notify(skb, n, tp, fh, RTM_NEWTFILTER);

This is incorrect. tp may already exist and you dont want to destroy
for failure to change its parameters. You also dont want to reattach
an existing tp because it succeeded in parameter change. 
So the soln is to check if this is a new tp and then do what you did
above...
Did that make sense?

cheers,
jamal

_______________________________________________
Containers mailing list
contain...@lists.linux-foundation.org
https://lists.linux-foundation.org/mailman/listinfo/containers

_______________________________________________
Devel mailing list
Devel@openvz.org
https://openvz.org/mailman/listinfo/devel

Reply via email to