diff options
author | Krishna Kumar <krkumar2@in.ibm.com> | 2012-06-26 20:59:56 -0400 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2012-07-04 13:51:50 -0400 |
commit | 46ba5a25f521e3c50d7bb81b1abb977769047456 (patch) | |
tree | 06a79cc715a40876905b0cf486243c549ba193c0 /net/netfilter | |
parent | 59560a38a379b6c9048620ee10711d3c0c5974b3 (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/netfilter')
-rw-r--r-- | net/netfilter/nfnetlink_queue_core.c | 5 |
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; |