--- x/include/net/net_namespace.h +++ y/include/net/net_namespace.h @@ -318,7 +318,7 @@ static inline int check_net(const struct return 1; } -#define net_drop_ns NULL +static void net_drop_ns(void *p) {} #endif @@ -353,6 +353,7 @@ static inline void __netns_tracker_free( static inline struct net *get_net_track(struct net *net, netns_tracker *tracker, gfp_t gfp) { + refcount_inc(&net->passive); get_net(net); netns_tracker_alloc(net, tracker, gfp); return net; @@ -362,6 +363,7 @@ static inline void put_net_track(struct { __netns_tracker_free(net, tracker, true); put_net(net); + net_drop_ns(net); } typedef struct { --- x/net/netfilter/nf_nat_masquerade.c +++ y/net/netfilter/nf_nat_masquerade.c @@ -123,11 +123,12 @@ static void nf_nat_masq_schedule(struct INIT_WORK(&w->work, iterate_cleanup_work); w->ifindex = ifindex; w->net = net; - netns_tracker_alloc(net, &w->ns_tracker, gfp_flags); + get_net_track(net, &w->ns_tracker, gfp_flags); w->iter = iter; if (addr) w->addr = *addr; schedule_work(&w->work); + put_net(net); return; }