Commit f72b948d authored by Phil Oester's avatar Phil Oester Committed by David S. Miller

[NET]: skb_find_text ignores to argument

skb_find_text takes a "to" argument which is supposed to limit how
far into the skb it will search for the given text.  At present,
it seems to ignore that argument on the first skb, and instead
return a match even if the text occurs beyond the limit.

Patch below fixes this, after adjusting for the "from" starting
point.  This consequently fixes the netfilter string match's "--to"
handling, which currently is broken.
Signed-off-by: default avatarPhil Oester <kernel@linuxace.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 60481264
...@@ -1739,12 +1739,15 @@ unsigned int skb_find_text(struct sk_buff *skb, unsigned int from, ...@@ -1739,12 +1739,15 @@ unsigned int skb_find_text(struct sk_buff *skb, unsigned int from,
unsigned int to, struct ts_config *config, unsigned int to, struct ts_config *config,
struct ts_state *state) struct ts_state *state)
{ {
unsigned int ret;
config->get_next_block = skb_ts_get_next_block; config->get_next_block = skb_ts_get_next_block;
config->finish = skb_ts_finish; config->finish = skb_ts_finish;
skb_prepare_seq_read(skb, from, to, TS_SKB_CB(state)); skb_prepare_seq_read(skb, from, to, TS_SKB_CB(state));
return textsearch_find(config, state); ret = textsearch_find(config, state);
return (ret <= to - from ? ret : UINT_MAX);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment