Skip to content

Commit 3ab1f68

Browse files
kaberdavem330
authored andcommitted
nfnetlink: add support for memory mapped netlink
Signed-off-by: Patrick McHardy <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent ec464e5 commit 3ab1f68

File tree

4 files changed

+17
-5
lines changed

4 files changed

+17
-5
lines changed

include/linux/netfilter/nfnetlink.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,8 @@ extern int nfnetlink_subsys_register(const struct nfnetlink_subsystem *n);
2929
extern int nfnetlink_subsys_unregister(const struct nfnetlink_subsystem *n);
3030

3131
extern int nfnetlink_has_listeners(struct net *net, unsigned int group);
32+
extern struct sk_buff *nfnetlink_alloc_skb(struct net *net, unsigned int size,
33+
u32 dst_portid, gfp_t gfp_mask);
3234
extern int nfnetlink_send(struct sk_buff *skb, struct net *net, u32 portid,
3335
unsigned int group, int echo, gfp_t flags);
3436
extern int nfnetlink_set_err(struct net *net, u32 portid, u32 group, int error);

net/netfilter/nfnetlink.c

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -112,6 +112,13 @@ int nfnetlink_has_listeners(struct net *net, unsigned int group)
112112
}
113113
EXPORT_SYMBOL_GPL(nfnetlink_has_listeners);
114114

115+
struct sk_buff *nfnetlink_alloc_skb(struct net *net, unsigned int size,
116+
u32 dst_portid, gfp_t gfp_mask)
117+
{
118+
return netlink_alloc_skb(net->nfnl, size, dst_portid, gfp_mask);
119+
}
120+
EXPORT_SYMBOL_GPL(nfnetlink_alloc_skb);
121+
115122
int nfnetlink_send(struct sk_buff *skb, struct net *net, u32 portid,
116123
unsigned int group, int echo, gfp_t flags)
117124
{

net/netfilter/nfnetlink_log.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -318,7 +318,7 @@ nfulnl_set_flags(struct nfulnl_instance *inst, u_int16_t flags)
318318
}
319319

320320
static struct sk_buff *
321-
nfulnl_alloc_skb(unsigned int inst_size, unsigned int pkt_size)
321+
nfulnl_alloc_skb(u32 peer_portid, unsigned int inst_size, unsigned int pkt_size)
322322
{
323323
struct sk_buff *skb;
324324
unsigned int n;
@@ -327,13 +327,14 @@ nfulnl_alloc_skb(unsigned int inst_size, unsigned int pkt_size)
327327
* message. WARNING: has to be <= 128k due to slab restrictions */
328328

329329
n = max(inst_size, pkt_size);
330-
skb = alloc_skb(n, GFP_ATOMIC);
330+
skb = nfnetlink_alloc_skb(&init_net, n, peer_portid, GFP_ATOMIC);
331331
if (!skb) {
332332
if (n > pkt_size) {
333333
/* try to allocate only as much as we need for current
334334
* packet */
335335

336-
skb = alloc_skb(pkt_size, GFP_ATOMIC);
336+
skb = nfnetlink_alloc_skb(&init_net, pkt_size,
337+
peer_portid, GFP_ATOMIC);
337338
if (!skb)
338339
pr_err("nfnetlink_log: can't even alloc %u bytes\n",
339340
pkt_size);
@@ -696,7 +697,8 @@ nfulnl_log_packet(u_int8_t pf,
696697
}
697698

698699
if (!inst->skb) {
699-
inst->skb = nfulnl_alloc_skb(inst->nlbufsiz, size);
700+
inst->skb = nfulnl_alloc_skb(inst->peer_portid, inst->nlbufsiz,
701+
size);
700702
if (!inst->skb)
701703
goto alloc_failure;
702704
}

net/netfilter/nfnetlink_queue_core.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -339,7 +339,8 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
339339
if (queue->flags & NFQA_CFG_F_CONNTRACK)
340340
ct = nfqnl_ct_get(entskb, &size, &ctinfo);
341341

342-
skb = alloc_skb(size, GFP_ATOMIC);
342+
skb = nfnetlink_alloc_skb(&init_net, size, queue->peer_portid,
343+
GFP_ATOMIC);
343344
if (!skb)
344345
return NULL;
345346

0 commit comments

Comments
 (0)