ipv4: optimize fib_compute_spec_dst call in ip_options_echo
Move fib_compute_spec_dst at the only place where it is needed. Signed-off-by: Julian Anastasov <ja@ssi.bg> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a16a0d2fb8
commit
6255e5ead0
1 changed files with 2 additions and 3 deletions
|
@ -93,7 +93,6 @@ int ip_options_echo(struct ip_options *dopt, struct sk_buff *skb)
|
||||||
unsigned char *sptr, *dptr;
|
unsigned char *sptr, *dptr;
|
||||||
int soffset, doffset;
|
int soffset, doffset;
|
||||||
int optlen;
|
int optlen;
|
||||||
__be32 daddr;
|
|
||||||
|
|
||||||
memset(dopt, 0, sizeof(struct ip_options));
|
memset(dopt, 0, sizeof(struct ip_options));
|
||||||
|
|
||||||
|
@ -105,8 +104,6 @@ int ip_options_echo(struct ip_options *dopt, struct sk_buff *skb)
|
||||||
sptr = skb_network_header(skb);
|
sptr = skb_network_header(skb);
|
||||||
dptr = dopt->__data;
|
dptr = dopt->__data;
|
||||||
|
|
||||||
daddr = fib_compute_spec_dst(skb);
|
|
||||||
|
|
||||||
if (sopt->rr) {
|
if (sopt->rr) {
|
||||||
optlen = sptr[sopt->rr+1];
|
optlen = sptr[sopt->rr+1];
|
||||||
soffset = sptr[sopt->rr+2];
|
soffset = sptr[sopt->rr+2];
|
||||||
|
@ -180,6 +177,8 @@ int ip_options_echo(struct ip_options *dopt, struct sk_buff *skb)
|
||||||
doffset -= 4;
|
doffset -= 4;
|
||||||
}
|
}
|
||||||
if (doffset > 3) {
|
if (doffset > 3) {
|
||||||
|
__be32 daddr = fib_compute_spec_dst(skb);
|
||||||
|
|
||||||
memcpy(&start[doffset-1], &daddr, 4);
|
memcpy(&start[doffset-1], &daddr, 4);
|
||||||
dopt->faddr = faddr;
|
dopt->faddr = faddr;
|
||||||
dptr[0] = start[0];
|
dptr[0] = start[0];
|
||||||
|
|
Loading…
Add table
Reference in a new issue