aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2012-06-27 00:35:27 -0400
committerDavid S. Miller <davem@davemloft.net>2012-06-27 00:35:27 -0400
commit3da07c0c2b5a13d05d9a66395d72eec0923b0592 (patch)
tree9204e4af7a885267a07aeac21edb7b25a41ffcc3
parentd550d0958928889fa7978b3e254edcd6c52c3296 (diff)
netfilter: nfnetlink_queue_core: Move away from NLMSG_PUT().
And use nlmsg_data() while we're here too. Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/netfilter/nfnetlink_queue_core.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/net/netfilter/nfnetlink_queue_core.c b/net/netfilter/nfnetlink_queue_core.c
index d36b95ea8ca3..a0b64920039d 100644
--- a/net/netfilter/nfnetlink_queue_core.c
+++ b/net/netfilter/nfnetlink_queue_core.c
@@ -274,13 +274,17 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
274 274
275 skb = alloc_skb(size, GFP_ATOMIC); 275 skb = alloc_skb(size, GFP_ATOMIC);
276 if (!skb) 276 if (!skb)
277 goto nlmsg_failure; 277 return NULL;
278 278
279 old_tail = skb->tail; 279 old_tail = skb->tail;
280 nlh = NLMSG_PUT(skb, 0, 0, 280 nlh = nlmsg_put(skb, 0, 0,
281 NFNL_SUBSYS_QUEUE << 8 | NFQNL_MSG_PACKET, 281 NFNL_SUBSYS_QUEUE << 8 | NFQNL_MSG_PACKET,
282 sizeof(struct nfgenmsg)); 282 sizeof(struct nfgenmsg), 0);
283 nfmsg = NLMSG_DATA(nlh); 283 if (!nlh) {
284 kfree_skb(skb);
285 return NULL;
286 }
287 nfmsg = nlmsg_data(nlh);
284 nfmsg->nfgen_family = entry->pf; 288 nfmsg->nfgen_family = entry->pf;
285 nfmsg->version = NFNETLINK_V0; 289 nfmsg->version = NFNETLINK_V0;
286 nfmsg->res_id = htons(queue->queue_num); 290 nfmsg->res_id = htons(queue->queue_num);
@@ -383,7 +387,8 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
383 387
384 if (skb_tailroom(skb) < nla_total_size(data_len)) { 388 if (skb_tailroom(skb) < nla_total_size(data_len)) {
385 printk(KERN_WARNING "nf_queue: no tailroom!\n"); 389 printk(KERN_WARNING "nf_queue: no tailroom!\n");
386 goto nlmsg_failure; 390 kfree_skb(skb);
391 return NULL;
387 } 392 }
388 393
389 nla = (struct nlattr *)skb_put(skb, nla_total_size(data_len)); 394 nla = (struct nlattr *)skb_put(skb, nla_total_size(data_len));
@@ -400,7 +405,6 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
400 nlh->nlmsg_len = skb->tail - old_tail; 405 nlh->nlmsg_len = skb->tail - old_tail;
401 return skb; 406 return skb;
402 407
403nlmsg_failure:
404nla_put_failure: 408nla_put_failure:
405 if (skb) 409 if (skb)
406 kfree_skb(skb); 410 kfree_skb(skb);
@@ -686,7 +690,7 @@ nfqnl_recv_verdict_batch(struct sock *ctnl, struct sk_buff *skb,
686 const struct nlmsghdr *nlh, 690 const struct nlmsghdr *nlh,
687 const struct nlattr * const nfqa[]) 691 const struct nlattr * const nfqa[])
688{ 692{
689 struct nfgenmsg *nfmsg = NLMSG_DATA(nlh); 693 struct nfgenmsg *nfmsg = nlmsg_data(nlh);
690 struct nf_queue_entry *entry, *tmp; 694 struct nf_queue_entry *entry, *tmp;
691 unsigned int verdict, maxid; 695 unsigned int verdict, maxid;
692 struct nfqnl_msg_verdict_hdr *vhdr; 696 struct nfqnl_msg_verdict_hdr *vhdr;
@@ -732,7 +736,7 @@ nfqnl_recv_verdict(struct sock *ctnl, struct sk_buff *skb,
732 const struct nlmsghdr *nlh, 736 const struct nlmsghdr *nlh,
733 const struct nlattr * const nfqa[]) 737 const struct nlattr * const nfqa[])
734{ 738{
735 struct nfgenmsg *nfmsg = NLMSG_DATA(nlh); 739 struct nfgenmsg *nfmsg = nlmsg_data(nlh);
736 u_int16_t queue_num = ntohs(nfmsg->res_id); 740 u_int16_t queue_num = ntohs(nfmsg->res_id);
737 741
738 struct nfqnl_msg_verdict_hdr *vhdr; 742 struct nfqnl_msg_verdict_hdr *vhdr;
@@ -806,7 +810,7 @@ nfqnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
806 const struct nlmsghdr *nlh, 810 const struct nlmsghdr *nlh,
807 const struct nlattr * const nfqa[]) 811 const struct nlattr * const nfqa[])
808{ 812{
809 struct nfgenmsg *nfmsg = NLMSG_DATA(nlh); 813 struct nfgenmsg *nfmsg = nlmsg_data(nlh);
810 u_int16_t queue_num = ntohs(nfmsg->res_id); 814 u_int16_t queue_num = ntohs(nfmsg->res_id);
811 struct nfqnl_instance *queue; 815 struct nfqnl_instance *queue;
812 struct nfqnl_msg_config_cmd *cmd = NULL; 816 struct nfqnl_msg_config_cmd *cmd = NULL;