Commit 61ca533c authored by Tonghao Zhang's avatar Tonghao Zhang Committed by David S. Miller

net: openvswitch: don't call pad_packet if not necessary

The nla_put_u16/nla_put_u32 makes sure that
*attrlen is align. The call tree is that:

nla_put_u16/nla_put_u32
  -> nla_put		attrlen = sizeof(u16) or sizeof(u32)
  -> __nla_put		attrlen
  -> __nla_reserve	attrlen
  -> skb_put(skb, nla_total_size(attrlen))

nla_total_size returns the total length of attribute
including padding.

Cc: Joe Stringer <joe@ovn.org>
Cc: William Tu <u9012063@gmail.com>
Signed-off-by: default avatarTonghao Zhang <xiangxia.m.yue@gmail.com>
Acked-by: default avatarPravin B Shelar <pshelar@ovn.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3bb884a4
...@@ -487,24 +487,18 @@ static int queue_userspace_packet(struct datapath *dp, struct sk_buff *skb, ...@@ -487,24 +487,18 @@ static int queue_userspace_packet(struct datapath *dp, struct sk_buff *skb,
} }
/* Add OVS_PACKET_ATTR_MRU */ /* Add OVS_PACKET_ATTR_MRU */
if (upcall_info->mru) { if (upcall_info->mru &&
if (nla_put_u16(user_skb, OVS_PACKET_ATTR_MRU, nla_put_u16(user_skb, OVS_PACKET_ATTR_MRU, upcall_info->mru)) {
upcall_info->mru)) {
err = -ENOBUFS; err = -ENOBUFS;
goto out; goto out;
} }
pad_packet(dp, user_skb);
}
/* Add OVS_PACKET_ATTR_LEN when packet is truncated */ /* Add OVS_PACKET_ATTR_LEN when packet is truncated */
if (cutlen > 0) { if (cutlen > 0 &&
if (nla_put_u32(user_skb, OVS_PACKET_ATTR_LEN, nla_put_u32(user_skb, OVS_PACKET_ATTR_LEN, skb->len)) {
skb->len)) {
err = -ENOBUFS; err = -ENOBUFS;
goto out; goto out;
} }
pad_packet(dp, user_skb);
}
/* Add OVS_PACKET_ATTR_HASH */ /* Add OVS_PACKET_ATTR_HASH */
hash = skb_get_hash_raw(skb); hash = skb_get_hash_raw(skb);
......
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