mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-02-14 00:13:53 +00:00
netfilter: nfnetlink_queue: cleanup copy_range usage
For every packet queued, we check if configured copy_range is 0, and treat that as 'copy entire packet'. We can move this check to the queue configuration, and can set copy_range appropriately. Also, convert repetitive '0xffff - NLA_HDRLEN' to a macro. [ queue initialization still used 0xffff, although its harmless since the initial setting is overwritten on queue config ] Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
This commit is contained in:
parent
4e7dba99c9
commit
9cefbbc9c8
@ -41,6 +41,14 @@
|
|||||||
|
|
||||||
#define NFQNL_QMAX_DEFAULT 1024
|
#define NFQNL_QMAX_DEFAULT 1024
|
||||||
|
|
||||||
|
/* We're using struct nlattr which has 16bit nla_len. Note that nla_len
|
||||||
|
* includes the header length. Thus, the maximum packet length that we
|
||||||
|
* support is 65531 bytes. We send truncated packets if the specified length
|
||||||
|
* is larger than that. Userspace can check for presence of NFQA_CAP_LEN
|
||||||
|
* attribute to detect truncation.
|
||||||
|
*/
|
||||||
|
#define NFQNL_MAX_COPY_RANGE (0xffff - NLA_HDRLEN)
|
||||||
|
|
||||||
struct nfqnl_instance {
|
struct nfqnl_instance {
|
||||||
struct hlist_node hlist; /* global list of queues */
|
struct hlist_node hlist; /* global list of queues */
|
||||||
struct rcu_head rcu;
|
struct rcu_head rcu;
|
||||||
@ -122,7 +130,7 @@ instance_create(struct nfnl_queue_net *q, u_int16_t queue_num,
|
|||||||
inst->queue_num = queue_num;
|
inst->queue_num = queue_num;
|
||||||
inst->peer_portid = portid;
|
inst->peer_portid = portid;
|
||||||
inst->queue_maxlen = NFQNL_QMAX_DEFAULT;
|
inst->queue_maxlen = NFQNL_QMAX_DEFAULT;
|
||||||
inst->copy_range = 0xffff;
|
inst->copy_range = NFQNL_MAX_COPY_RANGE;
|
||||||
inst->copy_mode = NFQNL_COPY_NONE;
|
inst->copy_mode = NFQNL_COPY_NONE;
|
||||||
spin_lock_init(&inst->lock);
|
spin_lock_init(&inst->lock);
|
||||||
INIT_LIST_HEAD(&inst->queue_list);
|
INIT_LIST_HEAD(&inst->queue_list);
|
||||||
@ -333,10 +341,9 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
data_len = ACCESS_ONCE(queue->copy_range);
|
data_len = ACCESS_ONCE(queue->copy_range);
|
||||||
if (data_len == 0 || data_len > entskb->len)
|
if (data_len > entskb->len)
|
||||||
data_len = entskb->len;
|
data_len = entskb->len;
|
||||||
|
|
||||||
|
|
||||||
if (!entskb->head_frag ||
|
if (!entskb->head_frag ||
|
||||||
skb_headlen(entskb) < L1_CACHE_BYTES ||
|
skb_headlen(entskb) < L1_CACHE_BYTES ||
|
||||||
skb_shinfo(entskb)->nr_frags >= MAX_SKB_FRAGS)
|
skb_shinfo(entskb)->nr_frags >= MAX_SKB_FRAGS)
|
||||||
@ -727,13 +734,8 @@ nfqnl_set_mode(struct nfqnl_instance *queue,
|
|||||||
|
|
||||||
case NFQNL_COPY_PACKET:
|
case NFQNL_COPY_PACKET:
|
||||||
queue->copy_mode = mode;
|
queue->copy_mode = mode;
|
||||||
/* We're using struct nlattr which has 16bit nla_len. Note that
|
if (range == 0 || range > NFQNL_MAX_COPY_RANGE)
|
||||||
* nla_len includes the header length. Thus, the maximum packet
|
queue->copy_range = NFQNL_MAX_COPY_RANGE;
|
||||||
* length that we support is 65531 bytes. We send truncated
|
|
||||||
* packets if the specified length is larger than that.
|
|
||||||
*/
|
|
||||||
if (range > 0xffff - NLA_HDRLEN)
|
|
||||||
queue->copy_range = 0xffff - NLA_HDRLEN;
|
|
||||||
else
|
else
|
||||||
queue->copy_range = range;
|
queue->copy_range = range;
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user