aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorPravin B Shelar <pshelar@nicira.com>2013-06-13 14:11:44 -0400
committerJesse Gross <jesse@nicira.com>2013-06-14 18:09:12 -0400
commitb34df5e805a6e98cae0bc5bc80c1b52d9ff811de (patch)
treecc8d94ee92741fe21380180aeff3a6f12bb44adb /net
parent45bfa52e36ef016b789eca73c7847db3f7b4742d (diff)
openvswitch: make skb->csum consistent with rest of networking stack.
Following patch keeps skb->csum correct across ovs. Signed-off-by: Pravin B Shelar <pshelar@nicira.com> Signed-off-by: Jesse Gross <jesse@nicira.com>
Diffstat (limited to 'net')
-rw-r--r--net/openvswitch/actions.c4
-rw-r--r--net/openvswitch/flow.c3
-rw-r--r--net/openvswitch/vport-internal_dev.c1
-rw-r--r--net/openvswitch/vport-netdev.c2
-rw-r--r--net/openvswitch/vport.h7
5 files changed, 17 insertions, 0 deletions
diff --git a/net/openvswitch/actions.c b/net/openvswitch/actions.c
index 894b6cbdd929..596d6373399d 100644
--- a/net/openvswitch/actions.c
+++ b/net/openvswitch/actions.c
@@ -130,9 +130,13 @@ static int set_eth_addr(struct sk_buff *skb,
130 if (unlikely(err)) 130 if (unlikely(err))
131 return err; 131 return err;
132 132
133 skb_postpull_rcsum(skb, eth_hdr(skb), ETH_ALEN * 2);
134
133 memcpy(eth_hdr(skb)->h_source, eth_key->eth_src, ETH_ALEN); 135 memcpy(eth_hdr(skb)->h_source, eth_key->eth_src, ETH_ALEN);
134 memcpy(eth_hdr(skb)->h_dest, eth_key->eth_dst, ETH_ALEN); 136 memcpy(eth_hdr(skb)->h_dest, eth_key->eth_dst, ETH_ALEN);
135 137
138 ovs_skb_postpush_rcsum(skb, eth_hdr(skb), ETH_ALEN * 2);
139
136 return 0; 140 return 0;
137} 141}
138 142
diff --git a/net/openvswitch/flow.c b/net/openvswitch/flow.c
index 33df0913358d..fca483360ce2 100644
--- a/net/openvswitch/flow.c
+++ b/net/openvswitch/flow.c
@@ -618,6 +618,9 @@ int ovs_flow_extract(struct sk_buff *skb, u16 in_port, struct sw_flow_key *key,
618 memcpy(key->eth.dst, eth->h_dest, ETH_ALEN); 618 memcpy(key->eth.dst, eth->h_dest, ETH_ALEN);
619 619
620 __skb_pull(skb, 2 * ETH_ALEN); 620 __skb_pull(skb, 2 * ETH_ALEN);
621 /* We are going to push all headers that we pull, so no need to
622 * update skb->csum here.
623 */
621 624
622 if (vlan_tx_tag_present(skb)) 625 if (vlan_tx_tag_present(skb))
623 key->eth.tci = htons(skb->vlan_tci); 626 key->eth.tci = htons(skb->vlan_tci);
diff --git a/net/openvswitch/vport-internal_dev.c b/net/openvswitch/vport-internal_dev.c
index 84e0a0379186..e284c7e1fec4 100644
--- a/net/openvswitch/vport-internal_dev.c
+++ b/net/openvswitch/vport-internal_dev.c
@@ -221,6 +221,7 @@ static int internal_dev_recv(struct vport *vport, struct sk_buff *skb)
221 skb->dev = netdev; 221 skb->dev = netdev;
222 skb->pkt_type = PACKET_HOST; 222 skb->pkt_type = PACKET_HOST;
223 skb->protocol = eth_type_trans(skb, netdev); 223 skb->protocol = eth_type_trans(skb, netdev);
224 skb_postpull_rcsum(skb, eth_hdr(skb), ETH_HLEN);
224 225
225 netif_rx(skb); 226 netif_rx(skb);
226 227
diff --git a/net/openvswitch/vport-netdev.c b/net/openvswitch/vport-netdev.c
index 43712217a372..40de815b4213 100644
--- a/net/openvswitch/vport-netdev.c
+++ b/net/openvswitch/vport-netdev.c
@@ -49,6 +49,8 @@ static void netdev_port_receive(struct vport *vport, struct sk_buff *skb)
49 return; 49 return;
50 50
51 skb_push(skb, ETH_HLEN); 51 skb_push(skb, ETH_HLEN);
52 ovs_skb_postpush_rcsum(skb, skb->data, ETH_HLEN);
53
52 ovs_vport_receive(vport, skb); 54 ovs_vport_receive(vport, skb);
53 return; 55 return;
54 56
diff --git a/net/openvswitch/vport.h b/net/openvswitch/vport.h
index 1cef5cd3be47..293278c4c2df 100644
--- a/net/openvswitch/vport.h
+++ b/net/openvswitch/vport.h
@@ -192,4 +192,11 @@ void ovs_vport_record_error(struct vport *, enum vport_err_type err_type);
192extern const struct vport_ops ovs_netdev_vport_ops; 192extern const struct vport_ops ovs_netdev_vport_ops;
193extern const struct vport_ops ovs_internal_vport_ops; 193extern const struct vport_ops ovs_internal_vport_ops;
194 194
195static inline void ovs_skb_postpush_rcsum(struct sk_buff *skb,
196 const void *start, unsigned int len)
197{
198 if (skb->ip_summed == CHECKSUM_COMPLETE)
199 skb->csum = csum_add(skb->csum, csum_partial(start, len, 0));
200}
201
195#endif /* vport.h */ 202#endif /* vport.h */