diff options
author | David S. Miller <davem@davemloft.net> | 2011-05-13 17:29:41 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-05-13 17:29:41 -0400 |
commit | 8e36360ae876995e92d3a7538dda70548e64e685 (patch) | |
tree | d477e086bb35d2de8a6f54b461abeb24be8a4f5b /net/ipv4/ip_options.c | |
parent | 22f728f8f311659b068e73ed92833c205651a47f (diff) |
ipv4: Remove route key identity dependencies in ip_rt_get_source().
Pass in the sk_buff so that we can fetch the necessary keys from
the packet header when working with input routes.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/ip_options.c')
-rw-r--r-- | net/ipv4/ip_options.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/net/ipv4/ip_options.c b/net/ipv4/ip_options.c index c6474cd1cbfa..89268baabc87 100644 --- a/net/ipv4/ip_options.c +++ b/net/ipv4/ip_options.c | |||
@@ -37,7 +37,7 @@ | |||
37 | */ | 37 | */ |
38 | 38 | ||
39 | void ip_options_build(struct sk_buff *skb, struct ip_options *opt, | 39 | void ip_options_build(struct sk_buff *skb, struct ip_options *opt, |
40 | __be32 daddr, struct rtable *rt, int is_frag) | 40 | __be32 daddr, struct rtable *rt, int is_frag) |
41 | { | 41 | { |
42 | unsigned char *iph = skb_network_header(skb); | 42 | unsigned char *iph = skb_network_header(skb); |
43 | 43 | ||
@@ -50,9 +50,9 @@ void ip_options_build(struct sk_buff *skb, struct ip_options *opt, | |||
50 | 50 | ||
51 | if (!is_frag) { | 51 | if (!is_frag) { |
52 | if (opt->rr_needaddr) | 52 | if (opt->rr_needaddr) |
53 | ip_rt_get_source(iph+opt->rr+iph[opt->rr+2]-5, rt); | 53 | ip_rt_get_source(iph+opt->rr+iph[opt->rr+2]-5, skb, rt); |
54 | if (opt->ts_needaddr) | 54 | if (opt->ts_needaddr) |
55 | ip_rt_get_source(iph+opt->ts+iph[opt->ts+2]-9, rt); | 55 | ip_rt_get_source(iph+opt->ts+iph[opt->ts+2]-9, skb, rt); |
56 | if (opt->ts_needtime) { | 56 | if (opt->ts_needtime) { |
57 | struct timespec tv; | 57 | struct timespec tv; |
58 | __be32 midtime; | 58 | __be32 midtime; |
@@ -553,7 +553,7 @@ void ip_forward_options(struct sk_buff *skb) | |||
553 | 553 | ||
554 | if (opt->rr_needaddr) { | 554 | if (opt->rr_needaddr) { |
555 | optptr = (unsigned char *)raw + opt->rr; | 555 | optptr = (unsigned char *)raw + opt->rr; |
556 | ip_rt_get_source(&optptr[optptr[2]-5], rt); | 556 | ip_rt_get_source(&optptr[optptr[2]-5], skb, rt); |
557 | opt->is_changed = 1; | 557 | opt->is_changed = 1; |
558 | } | 558 | } |
559 | if (opt->srr_is_hit) { | 559 | if (opt->srr_is_hit) { |
@@ -572,13 +572,13 @@ void ip_forward_options(struct sk_buff *skb) | |||
572 | } | 572 | } |
573 | if (srrptr + 3 <= srrspace) { | 573 | if (srrptr + 3 <= srrspace) { |
574 | opt->is_changed = 1; | 574 | opt->is_changed = 1; |
575 | ip_rt_get_source(&optptr[srrptr-1], rt); | 575 | ip_rt_get_source(&optptr[srrptr-1], skb, rt); |
576 | optptr[2] = srrptr+4; | 576 | optptr[2] = srrptr+4; |
577 | } else if (net_ratelimit()) | 577 | } else if (net_ratelimit()) |
578 | printk(KERN_CRIT "ip_forward(): Argh! Destination lost!\n"); | 578 | printk(KERN_CRIT "ip_forward(): Argh! Destination lost!\n"); |
579 | if (opt->ts_needaddr) { | 579 | if (opt->ts_needaddr) { |
580 | optptr = raw + opt->ts; | 580 | optptr = raw + opt->ts; |
581 | ip_rt_get_source(&optptr[optptr[2]-9], rt); | 581 | ip_rt_get_source(&optptr[optptr[2]-9], skb, rt); |
582 | opt->is_changed = 1; | 582 | opt->is_changed = 1; |
583 | } | 583 | } |
584 | } | 584 | } |