]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
mlxsw: spectrum_switchdev: Do not assume notifier information type
authorIdo Schimmel <idosch@mellanox.com>
Thu, 11 Oct 2018 07:47:53 +0000 (07:47 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 11 Oct 2018 17:08:22 +0000 (10:08 -0700)
VxLAN notifications are going to use a different notifier information
type, so cast to the correct type based on the received event.

Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Reviewed-by: Petr Machata <petrm@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/spectrum_switchdev.c

index 9edaec95ddd23115eed7d9d9c55fe6446ee96e1f..fa16ad2c6a50b530b86d437bd464187ea8ab8979 100644 (file)
@@ -2343,7 +2343,8 @@ static int mlxsw_sp_switchdev_event(struct notifier_block *unused,
 {
        struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
        struct mlxsw_sp_switchdev_event_work *switchdev_work;
-       struct switchdev_notifier_fdb_info *fdb_info = ptr;
+       struct switchdev_notifier_fdb_info *fdb_info;
+       struct switchdev_notifier_info *info = ptr;
        struct net_device *br_dev;
 
        /* Tunnel devices are not our uppers, so check their master instead */
@@ -2367,6 +2368,9 @@ static int mlxsw_sp_switchdev_event(struct notifier_block *unused,
        case SWITCHDEV_FDB_DEL_TO_DEVICE: /* fall through */
        case SWITCHDEV_FDB_ADD_TO_BRIDGE: /* fall through */
        case SWITCHDEV_FDB_DEL_TO_BRIDGE:
+               fdb_info = container_of(info,
+                                       struct switchdev_notifier_fdb_info,
+                                       info);
                INIT_WORK(&switchdev_work->work,
                          mlxsw_sp_switchdev_bridge_fdb_event_work);
                memcpy(&switchdev_work->fdb_info, ptr,