mlxsw: spectrum_router: Prepare function to return errors
authorIdo Schimmel <idosch@mellanox.com>
Tue, 18 Jun 2019 15:12:51 +0000 (18:12 +0300)
committerDavid S. Miller <davem@davemloft.net>
Tue, 18 Jun 2019 16:45:36 +0000 (09:45 -0700)
The function mlxsw_sp_router_fib6_event() takes care of preparing the
needed information for the work item that actually inserts the route
into the device.

When processing an IPv6 multipath route, the function will need to
allocate an array to store pointers to all the sibling routes.

Change the function's signature to return an error code and adjust the
single call site.

Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Acked-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/spectrum_router.c

index 8bfd53a1497b358723967220f263da544bf2c64d..3e2e8be753a4d7ac5eeb35755a4880c486b7bbdf 100644 (file)
@@ -6064,8 +6064,8 @@ static void mlxsw_sp_router_fib4_event(struct mlxsw_sp_fib_event_work *fib_work,
        }
 }
 
-static void mlxsw_sp_router_fib6_event(struct mlxsw_sp_fib_event_work *fib_work,
-                                      struct fib_notifier_info *info)
+static int mlxsw_sp_router_fib6_event(struct mlxsw_sp_fib_event_work *fib_work,
+                                     struct fib_notifier_info *info)
 {
        struct fib6_entry_notifier_info *fen6_info;
 
@@ -6079,6 +6079,8 @@ static void mlxsw_sp_router_fib6_event(struct mlxsw_sp_fib_event_work *fib_work,
                fib6_info_hold(fib_work->fen6_info.rt);
                break;
        }
+
+       return 0;
 }
 
 static void
@@ -6221,7 +6223,9 @@ static int mlxsw_sp_router_fib_event(struct notifier_block *nb,
                break;
        case AF_INET6:
                INIT_WORK(&fib_work->work, mlxsw_sp_router_fib6_event_work);
-               mlxsw_sp_router_fib6_event(fib_work, info);
+               err = mlxsw_sp_router_fib6_event(fib_work, info);
+               if (err)
+                       goto err_fib_event;
                break;
        case RTNL_FAMILY_IP6MR:
        case RTNL_FAMILY_IPMR:
@@ -6233,6 +6237,10 @@ static int mlxsw_sp_router_fib_event(struct notifier_block *nb,
        mlxsw_core_schedule_work(&fib_work->work);
 
        return NOTIFY_DONE;
+
+err_fib_event:
+       kfree(fib_work);
+       return NOTIFY_BAD;
 }
 
 struct mlxsw_sp_rif *