|
@@ -573,8 +573,8 @@ void ip_forward_options(struct sk_buff *skb)
|
|
}
|
|
}
|
|
if (srrptr + 3 <= srrspace) {
|
|
if (srrptr + 3 <= srrspace) {
|
|
opt->is_changed = 1;
|
|
opt->is_changed = 1;
|
|
- ip_rt_get_source(&optptr[srrptr-1], skb, rt);
|
|
|
|
ip_hdr(skb)->daddr = opt->nexthop;
|
|
ip_hdr(skb)->daddr = opt->nexthop;
|
|
|
|
+ ip_rt_get_source(&optptr[srrptr-1], skb, rt);
|
|
optptr[2] = srrptr+4;
|
|
optptr[2] = srrptr+4;
|
|
} else if (net_ratelimit())
|
|
} else if (net_ratelimit())
|
|
printk(KERN_CRIT "ip_forward(): Argh! Destination lost!\n");
|
|
printk(KERN_CRIT "ip_forward(): Argh! Destination lost!\n");
|