team: ab: set active port option as changed when port is leaving
authorJiri Pirko <jiri@resnulli.us>
Fri, 1 Feb 2013 08:17:26 +0000 (08:17 +0000)
committerDavid S. Miller <davem@davemloft.net>
Mon, 4 Feb 2013 19:55:45 +0000 (14:55 -0500)
In case port is leaving the team, set the option "activeport" as changed
so the change can be properly propagated to userspace

Signed-off-by: Jiri Pirko <jiri@resnulli.us>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/team/team_mode_activebackup.c

index 6262b4defd93ebdaac7cdd2f468d050e3b238b72..40fd3381b6932f34ae4b75ff1f5b8c42361512d7 100644 (file)
@@ -19,6 +19,7 @@
 
 struct ab_priv {
        struct team_port __rcu *active_port;
+       struct team_option_inst_info *ap_opt_inst_info;
 };
 
 static struct ab_priv *ab_priv(struct team *team)
@@ -54,8 +55,17 @@ drop:
 
 static void ab_port_leave(struct team *team, struct team_port *port)
 {
-       if (ab_priv(team)->active_port == port)
+       if (ab_priv(team)->active_port == port) {
                RCU_INIT_POINTER(ab_priv(team)->active_port, NULL);
+               team_option_inst_set_change(ab_priv(team)->ap_opt_inst_info);
+       }
+}
+
+static int ab_active_port_init(struct team *team,
+                              struct team_option_inst_info *info)
+{
+       ab_priv(team)->ap_opt_inst_info = info;
+       return 0;
 }
 
 static int ab_active_port_get(struct team *team, struct team_gsetter_ctx *ctx)
@@ -88,6 +98,7 @@ static const struct team_option ab_options[] = {
        {
                .name = "activeport",
                .type = TEAM_OPTION_TYPE_U32,
+               .init = ab_active_port_init,
                .getter = ab_active_port_get,
                .setter = ab_active_port_set,
        },