aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorKrishna Kumar <krkumar2@in.ibm.com>2012-06-26 20:59:56 -0400
committerPablo Neira Ayuso <pablo@netfilter.org>2012-07-04 13:51:50 -0400
commit46ba5a25f521e3c50d7bb81b1abb977769047456 (patch)
tree06a79cc715a40876905b0cf486243c549ba193c0 /net
parent59560a38a379b6c9048620ee10711d3c0c5974b3 (diff)
netfilter: nfnetlink_queue: do not allow to set unsupported flag bits
Allow setting of only supported flag bits in queue->flags. Signed-off-by: Krishna Kumar <krkumar2@in.ibm.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'net')
-rw-r--r--net/netfilter/nfnetlink_queue_core.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/net/netfilter/nfnetlink_queue_core.c b/net/netfilter/nfnetlink_queue_core.c
index a0b64920039d..c0496a55ad0c 100644
--- a/net/netfilter/nfnetlink_queue_core.c
+++ b/net/netfilter/nfnetlink_queue_core.c
@@ -910,6 +910,11 @@ nfqnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
910 flags = ntohl(nla_get_be32(nfqa[NFQA_CFG_FLAGS])); 910 flags = ntohl(nla_get_be32(nfqa[NFQA_CFG_FLAGS]));
911 mask = ntohl(nla_get_be32(nfqa[NFQA_CFG_MASK])); 911 mask = ntohl(nla_get_be32(nfqa[NFQA_CFG_MASK]));
912 912
913 if (flags >= NFQA_CFG_F_MAX) {
914 ret = -EOPNOTSUPP;
915 goto err_out_unlock;
916 }
917
913 spin_lock_bh(&queue->lock); 918 spin_lock_bh(&queue->lock);
914 queue->flags &= ~mask; 919 queue->flags &= ~mask;
915 queue->flags |= flags & mask; 920 queue->flags |= flags & mask;