aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/netfilter/nf_conntrack.h20
-rw-r--r--net/netfilter/nf_conntrack_core.c13
2 files changed, 18 insertions, 15 deletions
diff --git a/include/net/netfilter/nf_conntrack.h b/include/net/netfilter/nf_conntrack.h
index d5d76ec7abb0..8f5b75734dd0 100644
--- a/include/net/netfilter/nf_conntrack.h
+++ b/include/net/netfilter/nf_conntrack.h
@@ -223,23 +223,23 @@ static inline void nf_ct_refresh(struct nf_conn *ct,
223 __nf_ct_refresh_acct(ct, 0, skb, extra_jiffies, 0); 223 __nf_ct_refresh_acct(ct, 0, skb, extra_jiffies, 0);
224} 224}
225 225
226extern void __nf_ct_kill_acct(struct nf_conn *ct, 226extern bool __nf_ct_kill_acct(struct nf_conn *ct,
227 enum ip_conntrack_info ctinfo, 227 enum ip_conntrack_info ctinfo,
228 const struct sk_buff *skb, 228 const struct sk_buff *skb,
229 int do_acct); 229 int do_acct);
230 230
231/* kill conntrack and do accounting */ 231/* kill conntrack and do accounting */
232static inline void nf_ct_kill_acct(struct nf_conn *ct, 232static inline bool nf_ct_kill_acct(struct nf_conn *ct,
233 enum ip_conntrack_info ctinfo, 233 enum ip_conntrack_info ctinfo,
234 const struct sk_buff *skb) 234 const struct sk_buff *skb)
235{ 235{
236 __nf_ct_kill_acct(ct, ctinfo, skb, 1); 236 return __nf_ct_kill_acct(ct, ctinfo, skb, 1);
237} 237}
238 238
239/* kill conntrack without accounting */ 239/* kill conntrack without accounting */
240static inline void nf_ct_kill(struct nf_conn *ct) 240static inline bool nf_ct_kill(struct nf_conn *ct)
241{ 241{
242 __nf_ct_kill_acct(ct, 0, NULL, 0); 242 return __nf_ct_kill_acct(ct, 0, NULL, 0);
243} 243}
244 244
245/* These are for NAT. Icky. */ 245/* These are for NAT. Icky. */
diff --git a/net/netfilter/nf_conntrack_core.c b/net/netfilter/nf_conntrack_core.c
index 212a0888408d..28d03e64200b 100644
--- a/net/netfilter/nf_conntrack_core.c
+++ b/net/netfilter/nf_conntrack_core.c
@@ -848,10 +848,10 @@ acct:
848} 848}
849EXPORT_SYMBOL_GPL(__nf_ct_refresh_acct); 849EXPORT_SYMBOL_GPL(__nf_ct_refresh_acct);
850 850
851void __nf_ct_kill_acct(struct nf_conn *ct, 851bool __nf_ct_kill_acct(struct nf_conn *ct,
852 enum ip_conntrack_info ctinfo, 852 enum ip_conntrack_info ctinfo,
853 const struct sk_buff *skb, 853 const struct sk_buff *skb,
854 int do_acct) 854 int do_acct)
855{ 855{
856#ifdef CONFIG_NF_CT_ACCT 856#ifdef CONFIG_NF_CT_ACCT
857 if (do_acct) { 857 if (do_acct) {
@@ -862,8 +862,11 @@ void __nf_ct_kill_acct(struct nf_conn *ct,
862 spin_unlock_bh(&nf_conntrack_lock); 862 spin_unlock_bh(&nf_conntrack_lock);
863 } 863 }
864#endif 864#endif
865 if (del_timer(&ct->timeout)) 865 if (del_timer(&ct->timeout)) {
866 ct->timeout.function((unsigned long)ct); 866 ct->timeout.function((unsigned long)ct);
867 return true;
868 }
869 return false;
867} 870}
868EXPORT_SYMBOL_GPL(__nf_ct_kill_acct); 871EXPORT_SYMBOL_GPL(__nf_ct_kill_acct);
869 872