return !!(state & NUD_VALID);
 }
 
+static bool nexthop_is_good_nh(const struct nexthop *nh)
+{
+       struct nh_info *nhi = rcu_dereference(nh->nh_info);
+
+       switch (nhi->family) {
+       case AF_INET:
+               return ipv4_good_nh(&nhi->fib_nh);
+       case AF_INET6:
+               return ipv6_good_nh(&nhi->fib6_nh);
+       }
+
+       return false;
+}
+
 static struct nexthop *nexthop_select_path_fdb(struct nh_group *nhg, int hash)
 {
        int i;
 
        for (i = 0; i < nhg->num_nh; ++i) {
                struct nh_grp_entry *nhge = &nhg->nh_entries[i];
-               struct nh_info *nhi;
 
                if (hash > atomic_read(&nhge->hthr.upper_bound))
                        continue;
 
-               nhi = rcu_dereference(nhge->nh->nh_info);
-
                /* nexthops always check if it is good and does
                 * not rely on a sysctl for this behavior
                 */
-               switch (nhi->family) {
-               case AF_INET:
-                       if (ipv4_good_nh(&nhi->fib_nh))
-                               return nhge->nh;
-                       break;
-               case AF_INET6:
-                       if (ipv6_good_nh(&nhi->fib6_nh))
-                               return nhge->nh;
-                       break;
-               }
+               if (nexthop_is_good_nh(nhge->nh))
+                       return nhge->nh;
 
                if (!rc)
                        rc = nhge->nh;