diff options
Diffstat (limited to 'drivers/net/vxlan.c')
-rw-r--r-- | drivers/net/vxlan.c | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c index bf64b4191dcc..d1292fe746bc 100644 --- a/drivers/net/vxlan.c +++ b/drivers/net/vxlan.c | |||
@@ -564,7 +564,7 @@ static void vxlan_notify_add_rx_port(struct sock *sk) | |||
564 | struct net_device *dev; | 564 | struct net_device *dev; |
565 | struct net *net = sock_net(sk); | 565 | struct net *net = sock_net(sk); |
566 | sa_family_t sa_family = sk->sk_family; | 566 | sa_family_t sa_family = sk->sk_family; |
567 | u16 port = htons(inet_sk(sk)->inet_sport); | 567 | __be16 port = inet_sk(sk)->inet_sport; |
568 | 568 | ||
569 | rcu_read_lock(); | 569 | rcu_read_lock(); |
570 | for_each_netdev_rcu(net, dev) { | 570 | for_each_netdev_rcu(net, dev) { |
@@ -581,7 +581,7 @@ static void vxlan_notify_del_rx_port(struct sock *sk) | |||
581 | struct net_device *dev; | 581 | struct net_device *dev; |
582 | struct net *net = sock_net(sk); | 582 | struct net *net = sock_net(sk); |
583 | sa_family_t sa_family = sk->sk_family; | 583 | sa_family_t sa_family = sk->sk_family; |
584 | u16 port = htons(inet_sk(sk)->inet_sport); | 584 | __be16 port = inet_sk(sk)->inet_sport; |
585 | 585 | ||
586 | rcu_read_lock(); | 586 | rcu_read_lock(); |
587 | for_each_netdev_rcu(net, dev) { | 587 | for_each_netdev_rcu(net, dev) { |
@@ -2021,7 +2021,8 @@ static struct device_type vxlan_type = { | |||
2021 | }; | 2021 | }; |
2022 | 2022 | ||
2023 | /* Calls the ndo_add_vxlan_port of the caller in order to | 2023 | /* Calls the ndo_add_vxlan_port of the caller in order to |
2024 | * supply the listening VXLAN udp ports. | 2024 | * supply the listening VXLAN udp ports. Callers are expected |
2025 | * to implement the ndo_add_vxlan_port. | ||
2025 | */ | 2026 | */ |
2026 | void vxlan_get_rx_port(struct net_device *dev) | 2027 | void vxlan_get_rx_port(struct net_device *dev) |
2027 | { | 2028 | { |
@@ -2029,16 +2030,13 @@ void vxlan_get_rx_port(struct net_device *dev) | |||
2029 | struct net *net = dev_net(dev); | 2030 | struct net *net = dev_net(dev); |
2030 | struct vxlan_net *vn = net_generic(net, vxlan_net_id); | 2031 | struct vxlan_net *vn = net_generic(net, vxlan_net_id); |
2031 | sa_family_t sa_family; | 2032 | sa_family_t sa_family; |
2032 | u16 port; | 2033 | __be16 port; |
2033 | int i; | 2034 | unsigned int i; |
2034 | |||
2035 | if (!dev || !dev->netdev_ops || !dev->netdev_ops->ndo_add_vxlan_port) | ||
2036 | return; | ||
2037 | 2035 | ||
2038 | spin_lock(&vn->sock_lock); | 2036 | spin_lock(&vn->sock_lock); |
2039 | for (i = 0; i < PORT_HASH_SIZE; ++i) { | 2037 | for (i = 0; i < PORT_HASH_SIZE; ++i) { |
2040 | hlist_for_each_entry_rcu(vs, vs_head(net, i), hlist) { | 2038 | hlist_for_each_entry_rcu(vs, &vn->sock_list[i], hlist) { |
2041 | port = htons(inet_sk(vs->sock->sk)->inet_sport); | 2039 | port = inet_sk(vs->sock->sk)->inet_sport; |
2042 | sa_family = vs->sock->sk->sk_family; | 2040 | sa_family = vs->sock->sk->sk_family; |
2043 | dev->netdev_ops->ndo_add_vxlan_port(dev, sa_family, | 2041 | dev->netdev_ops->ndo_add_vxlan_port(dev, sa_family, |
2044 | port); | 2042 | port); |
@@ -2492,15 +2490,19 @@ static int vxlan_newlink(struct net *net, struct net_device *dev, | |||
2492 | 2490 | ||
2493 | SET_ETHTOOL_OPS(dev, &vxlan_ethtool_ops); | 2491 | SET_ETHTOOL_OPS(dev, &vxlan_ethtool_ops); |
2494 | 2492 | ||
2495 | /* create an fdb entry for default destination */ | 2493 | /* create an fdb entry for a valid default destination */ |
2496 | err = vxlan_fdb_create(vxlan, all_zeros_mac, | 2494 | if (!vxlan_addr_any(&vxlan->default_dst.remote_ip)) { |
2497 | &vxlan->default_dst.remote_ip, | 2495 | err = vxlan_fdb_create(vxlan, all_zeros_mac, |
2498 | NUD_REACHABLE|NUD_PERMANENT, | 2496 | &vxlan->default_dst.remote_ip, |
2499 | NLM_F_EXCL|NLM_F_CREATE, | 2497 | NUD_REACHABLE|NUD_PERMANENT, |
2500 | vxlan->dst_port, vxlan->default_dst.remote_vni, | 2498 | NLM_F_EXCL|NLM_F_CREATE, |
2501 | vxlan->default_dst.remote_ifindex, NTF_SELF); | 2499 | vxlan->dst_port, |
2502 | if (err) | 2500 | vxlan->default_dst.remote_vni, |
2503 | return err; | 2501 | vxlan->default_dst.remote_ifindex, |
2502 | NTF_SELF); | ||
2503 | if (err) | ||
2504 | return err; | ||
2505 | } | ||
2504 | 2506 | ||
2505 | err = register_netdevice(dev); | 2507 | err = register_netdevice(dev); |
2506 | if (err) { | 2508 | if (err) { |