提交 2573d788 编写于 作者: D David S. Miller

Merge branch 'ovs-vport-cleanup'

Pravin B Shelar says:

====================
openvswitch: Cleanup post vport conversion.

After converting all vport to netdev implmentations there
is no need for some of vport functionality.
====================
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
...@@ -896,10 +896,6 @@ static int execute_set_action(struct sk_buff *skb, ...@@ -896,10 +896,6 @@ static int execute_set_action(struct sk_buff *skb,
skb_dst_drop(skb); skb_dst_drop(skb);
dst_hold((struct dst_entry *)tun->tun_dst); dst_hold((struct dst_entry *)tun->tun_dst);
skb_dst_set(skb, (struct dst_entry *)tun->tun_dst); skb_dst_set(skb, (struct dst_entry *)tun->tun_dst);
/* FIXME: Remove when all vports have been converted */
OVS_CB(skb)->egress_tun_info = &tun->tun_dst->u.tun_info;
return 0; return 0;
} }
...@@ -1159,7 +1155,6 @@ int ovs_execute_actions(struct datapath *dp, struct sk_buff *skb, ...@@ -1159,7 +1155,6 @@ int ovs_execute_actions(struct datapath *dp, struct sk_buff *skb,
int err; int err;
this_cpu_inc(exec_actions_level); this_cpu_inc(exec_actions_level);
OVS_CB(skb)->egress_tun_info = NULL;
err = do_execute_actions(dp, skb, key, err = do_execute_actions(dp, skb, key,
acts->actions, acts->actions_len); acts->actions, acts->actions_len);
......
...@@ -610,7 +610,6 @@ static int ovs_packet_cmd_execute(struct sk_buff *skb, struct genl_info *info) ...@@ -610,7 +610,6 @@ static int ovs_packet_cmd_execute(struct sk_buff *skb, struct genl_info *info)
goto err_flow_free; goto err_flow_free;
rcu_assign_pointer(flow->sf_acts, acts); rcu_assign_pointer(flow->sf_acts, acts);
OVS_CB(packet)->egress_tun_info = NULL;
packet->priority = flow->key.phy.priority; packet->priority = flow->key.phy.priority;
packet->mark = flow->key.phy.skb_mark; packet->mark = flow->key.phy.skb_mark;
......
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
#include "conntrack.h" #include "conntrack.h"
#include "flow.h" #include "flow.h"
#include "flow_table.h" #include "flow_table.h"
#include "vport.h"
#define DP_MAX_PORTS USHRT_MAX #define DP_MAX_PORTS USHRT_MAX
#define DP_VPORT_HASH_BUCKETS 1024 #define DP_VPORT_HASH_BUCKETS 1024
...@@ -94,15 +93,12 @@ struct datapath { ...@@ -94,15 +93,12 @@ struct datapath {
/** /**
* struct ovs_skb_cb - OVS data in skb CB * struct ovs_skb_cb - OVS data in skb CB
* @egress_tun_key: Tunnel information about this packet on egress path.
* NULL if the packet is not being tunneled.
* @input_vport: The original vport packet came in on. This value is cached * @input_vport: The original vport packet came in on. This value is cached
* when a packet is received by OVS. * when a packet is received by OVS.
* @mru: The maximum received fragement size; 0 if the packet is not * @mru: The maximum received fragement size; 0 if the packet is not
* fragmented. * fragmented.
*/ */
struct ovs_skb_cb { struct ovs_skb_cb {
struct ip_tunnel_info *egress_tun_info;
struct vport *input_vport; struct vport *input_vport;
u16 mru; u16 mru;
}; };
...@@ -137,7 +133,6 @@ struct dp_upcall_info { ...@@ -137,7 +133,6 @@ struct dp_upcall_info {
struct ovs_net { struct ovs_net {
struct list_head dps; struct list_head dps;
struct work_struct dp_notify_work; struct work_struct dp_notify_work;
struct vport_net vport_net;
/* Module reference for configuring conntrack. */ /* Module reference for configuring conntrack. */
bool xt_label; bool xt_label;
......
...@@ -46,10 +46,11 @@ ...@@ -46,10 +46,11 @@
#include <net/mpls.h> #include <net/mpls.h>
#include <net/ndisc.h> #include <net/ndisc.h>
#include "conntrack.h"
#include "datapath.h" #include "datapath.h"
#include "flow.h" #include "flow.h"
#include "flow_netlink.h" #include "flow_netlink.h"
#include "conntrack.h" #include "vport.h"
u64 ovs_flow_used_time(unsigned long flow_jiffies) u64 ovs_flow_used_time(unsigned long flow_jiffies)
{ {
......
...@@ -62,8 +62,7 @@ static int geneve_get_egress_tun_info(struct vport *vport, struct sk_buff *skb, ...@@ -62,8 +62,7 @@ static int geneve_get_egress_tun_info(struct vport *vport, struct sk_buff *skb,
return ovs_tunnel_get_egress_info(egress_tun_info, return ovs_tunnel_get_egress_info(egress_tun_info,
ovs_dp_get_net(vport->dp), ovs_dp_get_net(vport->dp),
OVS_CB(skb)->egress_tun_info, skb, IPPROTO_UDP, sport, dport);
IPPROTO_UDP, skb->mark, sport, dport);
} }
static struct vport *geneve_tnl_create(const struct vport_parms *parms) static struct vport *geneve_tnl_create(const struct vport_parms *parms)
......
...@@ -89,8 +89,7 @@ static int gre_get_egress_tun_info(struct vport *vport, struct sk_buff *skb, ...@@ -89,8 +89,7 @@ static int gre_get_egress_tun_info(struct vport *vport, struct sk_buff *skb,
{ {
return ovs_tunnel_get_egress_info(egress_tun_info, return ovs_tunnel_get_egress_info(egress_tun_info,
ovs_dp_get_net(vport->dp), ovs_dp_get_net(vport->dp),
OVS_CB(skb)->egress_tun_info, skb, IPPROTO_GRE, 0, 0);
IPPROTO_GRE, skb->mark, 0, 0);
} }
static struct vport_ops ovs_gre_vport_ops = { static struct vport_ops ovs_gre_vport_ops = {
......
...@@ -43,35 +43,26 @@ static struct internal_dev *internal_dev_priv(struct net_device *netdev) ...@@ -43,35 +43,26 @@ static struct internal_dev *internal_dev_priv(struct net_device *netdev)
return netdev_priv(netdev); return netdev_priv(netdev);
} }
/* This function is only called by the kernel network layer.*/
static struct rtnl_link_stats64 *internal_dev_get_stats(struct net_device *netdev,
struct rtnl_link_stats64 *stats)
{
struct vport *vport = ovs_internal_dev_get_vport(netdev);
struct ovs_vport_stats vport_stats;
ovs_vport_get_stats(vport, &vport_stats);
/* The tx and rx stats need to be swapped because the
* switch and host OS have opposite perspectives. */
stats->rx_packets = vport_stats.tx_packets;
stats->tx_packets = vport_stats.rx_packets;
stats->rx_bytes = vport_stats.tx_bytes;
stats->tx_bytes = vport_stats.rx_bytes;
stats->rx_errors = vport_stats.tx_errors;
stats->tx_errors = vport_stats.rx_errors;
stats->rx_dropped = vport_stats.tx_dropped;
stats->tx_dropped = vport_stats.rx_dropped;
return stats;
}
/* Called with rcu_read_lock_bh. */ /* Called with rcu_read_lock_bh. */
static int internal_dev_xmit(struct sk_buff *skb, struct net_device *netdev) static int internal_dev_xmit(struct sk_buff *skb, struct net_device *netdev)
{ {
int len, err;
len = skb->len;
rcu_read_lock(); rcu_read_lock();
ovs_vport_receive(internal_dev_priv(netdev)->vport, skb, NULL); err = ovs_vport_receive(internal_dev_priv(netdev)->vport, skb, NULL);
rcu_read_unlock(); rcu_read_unlock();
if (likely(!err)) {
struct pcpu_sw_netstats *tstats = this_cpu_ptr(netdev->tstats);
u64_stats_update_begin(&tstats->syncp);
tstats->tx_bytes += len;
tstats->tx_packets++;
u64_stats_update_end(&tstats->syncp);
} else {
netdev->stats.tx_errors++;
}
return 0; return 0;
} }
...@@ -121,7 +112,6 @@ static const struct net_device_ops internal_dev_netdev_ops = { ...@@ -121,7 +112,6 @@ static const struct net_device_ops internal_dev_netdev_ops = {
.ndo_start_xmit = internal_dev_xmit, .ndo_start_xmit = internal_dev_xmit,
.ndo_set_mac_address = eth_mac_addr, .ndo_set_mac_address = eth_mac_addr,
.ndo_change_mtu = internal_dev_change_mtu, .ndo_change_mtu = internal_dev_change_mtu,
.ndo_get_stats64 = internal_dev_get_stats,
}; };
static struct rtnl_link_ops internal_dev_link_ops __read_mostly = { static struct rtnl_link_ops internal_dev_link_ops __read_mostly = {
...@@ -212,18 +202,17 @@ static void internal_dev_destroy(struct vport *vport) ...@@ -212,18 +202,17 @@ static void internal_dev_destroy(struct vport *vport)
rtnl_unlock(); rtnl_unlock();
} }
static int internal_dev_recv(struct vport *vport, struct sk_buff *skb) static void internal_dev_recv(struct vport *vport, struct sk_buff *skb)
{ {
struct net_device *netdev = vport->dev; struct net_device *netdev = vport->dev;
int len; struct pcpu_sw_netstats *stats;
if (unlikely(!(netdev->flags & IFF_UP))) { if (unlikely(!(netdev->flags & IFF_UP))) {
kfree_skb(skb); kfree_skb(skb);
return 0; netdev->stats.rx_dropped++;
return;
} }
len = skb->len;
skb_dst_drop(skb); skb_dst_drop(skb);
nf_reset(skb); nf_reset(skb);
secpath_reset(skb); secpath_reset(skb);
...@@ -233,9 +222,13 @@ static int internal_dev_recv(struct vport *vport, struct sk_buff *skb) ...@@ -233,9 +222,13 @@ static int internal_dev_recv(struct vport *vport, struct sk_buff *skb)
skb->protocol = eth_type_trans(skb, netdev); skb->protocol = eth_type_trans(skb, netdev);
skb_postpull_rcsum(skb, eth_hdr(skb), ETH_HLEN); skb_postpull_rcsum(skb, eth_hdr(skb), ETH_HLEN);
netif_rx(skb); stats = this_cpu_ptr(netdev->tstats);
u64_stats_update_begin(&stats->syncp);
stats->rx_packets++;
stats->rx_bytes += skb->len;
u64_stats_update_end(&stats->syncp);
return len; netif_rx(skb);
} }
static struct vport_ops ovs_internal_vport_ops = { static struct vport_ops ovs_internal_vport_ops = {
......
...@@ -39,8 +39,11 @@ ...@@ -39,8 +39,11 @@
static struct vport_ops ovs_netdev_vport_ops; static struct vport_ops ovs_netdev_vport_ops;
/* Must be called with rcu_read_lock. */ /* Must be called with rcu_read_lock. */
static void netdev_port_receive(struct vport *vport, struct sk_buff *skb) static void netdev_port_receive(struct sk_buff *skb)
{ {
struct vport *vport;
vport = ovs_netdev_get_vport(skb->dev);
if (unlikely(!vport)) if (unlikely(!vport))
goto error; goto error;
...@@ -56,10 +59,8 @@ static void netdev_port_receive(struct vport *vport, struct sk_buff *skb) ...@@ -56,10 +59,8 @@ static void netdev_port_receive(struct vport *vport, struct sk_buff *skb)
skb_push(skb, ETH_HLEN); skb_push(skb, ETH_HLEN);
ovs_skb_postpush_rcsum(skb, skb->data, ETH_HLEN); ovs_skb_postpush_rcsum(skb, skb->data, ETH_HLEN);
ovs_vport_receive(vport, skb, skb_tunnel_info(skb)); ovs_vport_receive(vport, skb, skb_tunnel_info(skb));
return; return;
error: error:
kfree_skb(skb); kfree_skb(skb);
} }
...@@ -68,15 +69,11 @@ static void netdev_port_receive(struct vport *vport, struct sk_buff *skb) ...@@ -68,15 +69,11 @@ static void netdev_port_receive(struct vport *vport, struct sk_buff *skb)
static rx_handler_result_t netdev_frame_hook(struct sk_buff **pskb) static rx_handler_result_t netdev_frame_hook(struct sk_buff **pskb)
{ {
struct sk_buff *skb = *pskb; struct sk_buff *skb = *pskb;
struct vport *vport;
if (unlikely(skb->pkt_type == PACKET_LOOPBACK)) if (unlikely(skb->pkt_type == PACKET_LOOPBACK))
return RX_HANDLER_PASS; return RX_HANDLER_PASS;
vport = ovs_netdev_get_vport(skb->dev); netdev_port_receive(skb);
netdev_port_receive(vport, skb);
return RX_HANDLER_CONSUMED; return RX_HANDLER_CONSUMED;
} }
...@@ -203,27 +200,24 @@ static unsigned int packet_length(const struct sk_buff *skb) ...@@ -203,27 +200,24 @@ static unsigned int packet_length(const struct sk_buff *skb)
return length; return length;
} }
int ovs_netdev_send(struct vport *vport, struct sk_buff *skb) void ovs_netdev_send(struct vport *vport, struct sk_buff *skb)
{ {
int mtu = vport->dev->mtu; int mtu = vport->dev->mtu;
int len;
if (unlikely(packet_length(skb) > mtu && !skb_is_gso(skb))) { if (unlikely(packet_length(skb) > mtu && !skb_is_gso(skb))) {
net_warn_ratelimited("%s: dropped over-mtu packet: %d > %d\n", net_warn_ratelimited("%s: dropped over-mtu packet: %d > %d\n",
vport->dev->name, vport->dev->name,
packet_length(skb), mtu); packet_length(skb), mtu);
vport->dev->stats.tx_errors++;
goto drop; goto drop;
} }
skb->dev = vport->dev; skb->dev = vport->dev;
len = skb->len;
dev_queue_xmit(skb); dev_queue_xmit(skb);
return;
return len;
drop: drop:
kfree_skb(skb); kfree_skb(skb);
return 0;
} }
EXPORT_SYMBOL_GPL(ovs_netdev_send); EXPORT_SYMBOL_GPL(ovs_netdev_send);
......
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
struct vport *ovs_netdev_get_vport(struct net_device *dev); struct vport *ovs_netdev_get_vport(struct net_device *dev);
struct vport *ovs_netdev_link(struct vport *vport, const char *name); struct vport *ovs_netdev_link(struct vport *vport, const char *name);
int ovs_netdev_send(struct vport *vport, struct sk_buff *skb); void ovs_netdev_send(struct vport *vport, struct sk_buff *skb);
void ovs_netdev_detach_dev(struct vport *); void ovs_netdev_detach_dev(struct vport *);
int __init ovs_netdev_init(void); int __init ovs_netdev_init(void);
......
...@@ -160,8 +160,7 @@ static int vxlan_get_egress_tun_info(struct vport *vport, struct sk_buff *skb, ...@@ -160,8 +160,7 @@ static int vxlan_get_egress_tun_info(struct vport *vport, struct sk_buff *skb,
src_port = udp_flow_src_port(net, skb, 0, 0, true); src_port = udp_flow_src_port(net, skb, 0, 0, true);
return ovs_tunnel_get_egress_info(egress_tun_info, net, return ovs_tunnel_get_egress_info(egress_tun_info, net,
OVS_CB(skb)->egress_tun_info, skb, IPPROTO_UDP,
IPPROTO_UDP, skb->mark,
src_port, dst_port); src_port, dst_port);
} }
......
...@@ -34,9 +34,6 @@ ...@@ -34,9 +34,6 @@
#include "vport.h" #include "vport.h"
#include "vport-internal_dev.h" #include "vport-internal_dev.h"
static void ovs_vport_record_error(struct vport *,
enum vport_err_type err_type);
static LIST_HEAD(vport_ops_list); static LIST_HEAD(vport_ops_list);
/* Protected by RCU read lock for reading, ovs_mutex for writing. */ /* Protected by RCU read lock for reading, ovs_mutex for writing. */
...@@ -157,12 +154,6 @@ struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *ops, ...@@ -157,12 +154,6 @@ struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *ops,
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
vport->percpu_stats = netdev_alloc_pcpu_stats(struct pcpu_sw_netstats);
if (!vport->percpu_stats) {
kfree(vport);
return ERR_PTR(-ENOMEM);
}
return vport; return vport;
} }
EXPORT_SYMBOL_GPL(ovs_vport_alloc); EXPORT_SYMBOL_GPL(ovs_vport_alloc);
...@@ -183,7 +174,6 @@ void ovs_vport_free(struct vport *vport) ...@@ -183,7 +174,6 @@ void ovs_vport_free(struct vport *vport)
* it is safe to use raw dereference. * it is safe to use raw dereference.
*/ */
kfree(rcu_dereference_raw(vport->upcall_portids)); kfree(rcu_dereference_raw(vport->upcall_portids));
free_percpu(vport->percpu_stats);
kfree(vport); kfree(vport);
} }
EXPORT_SYMBOL_GPL(ovs_vport_free); EXPORT_SYMBOL_GPL(ovs_vport_free);
...@@ -290,30 +280,24 @@ void ovs_vport_del(struct vport *vport) ...@@ -290,30 +280,24 @@ void ovs_vport_del(struct vport *vport)
*/ */
void ovs_vport_get_stats(struct vport *vport, struct ovs_vport_stats *stats) void ovs_vport_get_stats(struct vport *vport, struct ovs_vport_stats *stats)
{ {
struct net_device *dev = vport->dev;
int i; int i;
memset(stats, 0, sizeof(*stats)); memset(stats, 0, sizeof(*stats));
stats->rx_errors = dev->stats.rx_errors;
stats->tx_errors = dev->stats.tx_errors;
stats->tx_dropped = dev->stats.tx_dropped;
stats->rx_dropped = dev->stats.rx_dropped;
/* We potentially have 2 sources of stats that need to be combined: stats->rx_dropped += atomic_long_read(&dev->rx_dropped);
* those we have collected (split into err_stats and percpu_stats) from stats->tx_dropped += atomic_long_read(&dev->tx_dropped);
* set_stats() and device error stats from netdev->get_stats() (for
* errors that happen downstream and therefore aren't reported through
* our vport_record_error() function).
* Stats from first source are reported by ovs (OVS_VPORT_ATTR_STATS).
* netdev-stats can be directly read over netlink-ioctl.
*/
stats->rx_errors = atomic_long_read(&vport->err_stats.rx_errors);
stats->tx_errors = atomic_long_read(&vport->err_stats.tx_errors);
stats->tx_dropped = atomic_long_read(&vport->err_stats.tx_dropped);
stats->rx_dropped = atomic_long_read(&vport->err_stats.rx_dropped);
for_each_possible_cpu(i) { for_each_possible_cpu(i) {
const struct pcpu_sw_netstats *percpu_stats; const struct pcpu_sw_netstats *percpu_stats;
struct pcpu_sw_netstats local_stats; struct pcpu_sw_netstats local_stats;
unsigned int start; unsigned int start;
percpu_stats = per_cpu_ptr(vport->percpu_stats, i); percpu_stats = per_cpu_ptr(dev->tstats, i);
do { do {
start = u64_stats_fetch_begin_irq(&percpu_stats->syncp); start = u64_stats_fetch_begin_irq(&percpu_stats->syncp);
...@@ -468,95 +452,25 @@ u32 ovs_vport_find_upcall_portid(const struct vport *vport, struct sk_buff *skb) ...@@ -468,95 +452,25 @@ u32 ovs_vport_find_upcall_portid(const struct vport *vport, struct sk_buff *skb)
* Must be called with rcu_read_lock. The packet cannot be shared and * Must be called with rcu_read_lock. The packet cannot be shared and
* skb->data should point to the Ethernet header. * skb->data should point to the Ethernet header.
*/ */
void ovs_vport_receive(struct vport *vport, struct sk_buff *skb, int ovs_vport_receive(struct vport *vport, struct sk_buff *skb,
const struct ip_tunnel_info *tun_info) const struct ip_tunnel_info *tun_info)
{ {
struct pcpu_sw_netstats *stats;
struct sw_flow_key key; struct sw_flow_key key;
int error; int error;
stats = this_cpu_ptr(vport->percpu_stats);
u64_stats_update_begin(&stats->syncp);
stats->rx_packets++;
stats->rx_bytes += skb->len +
(skb_vlan_tag_present(skb) ? VLAN_HLEN : 0);
u64_stats_update_end(&stats->syncp);
OVS_CB(skb)->input_vport = vport; OVS_CB(skb)->input_vport = vport;
OVS_CB(skb)->egress_tun_info = NULL;
OVS_CB(skb)->mru = 0; OVS_CB(skb)->mru = 0;
/* Extract flow from 'skb' into 'key'. */ /* Extract flow from 'skb' into 'key'. */
error = ovs_flow_key_extract(tun_info, skb, &key); error = ovs_flow_key_extract(tun_info, skb, &key);
if (unlikely(error)) { if (unlikely(error)) {
kfree_skb(skb); kfree_skb(skb);
return; return error;
} }
ovs_dp_process_packet(skb, &key); ovs_dp_process_packet(skb, &key);
return 0;
} }
EXPORT_SYMBOL_GPL(ovs_vport_receive); EXPORT_SYMBOL_GPL(ovs_vport_receive);
/**
* ovs_vport_send - send a packet on a device
*
* @vport: vport on which to send the packet
* @skb: skb to send
*
* Sends the given packet and returns the length of data sent. Either ovs
* lock or rcu_read_lock must be held.
*/
int ovs_vport_send(struct vport *vport, struct sk_buff *skb)
{
int sent = vport->ops->send(vport, skb);
if (likely(sent > 0)) {
struct pcpu_sw_netstats *stats;
stats = this_cpu_ptr(vport->percpu_stats);
u64_stats_update_begin(&stats->syncp);
stats->tx_packets++;
stats->tx_bytes += sent;
u64_stats_update_end(&stats->syncp);
} else if (sent < 0) {
ovs_vport_record_error(vport, VPORT_E_TX_ERROR);
} else {
ovs_vport_record_error(vport, VPORT_E_TX_DROPPED);
}
return sent;
}
/**
* ovs_vport_record_error - indicate device error to generic stats layer
*
* @vport: vport that encountered the error
* @err_type: one of enum vport_err_type types to indicate the error type
*
* If using the vport generic stats layer indicate that an error of the given
* type has occurred.
*/
static void ovs_vport_record_error(struct vport *vport,
enum vport_err_type err_type)
{
switch (err_type) {
case VPORT_E_RX_DROPPED:
atomic_long_inc(&vport->err_stats.rx_dropped);
break;
case VPORT_E_RX_ERROR:
atomic_long_inc(&vport->err_stats.rx_errors);
break;
case VPORT_E_TX_DROPPED:
atomic_long_inc(&vport->err_stats.tx_dropped);
break;
case VPORT_E_TX_ERROR:
atomic_long_inc(&vport->err_stats.tx_errors);
break;
}
}
static void free_vport_rcu(struct rcu_head *rcu) static void free_vport_rcu(struct rcu_head *rcu)
{ {
struct vport *vport = container_of(rcu, struct vport, rcu); struct vport *vport = container_of(rcu, struct vport, rcu);
...@@ -575,13 +489,14 @@ EXPORT_SYMBOL_GPL(ovs_vport_deferred_free); ...@@ -575,13 +489,14 @@ EXPORT_SYMBOL_GPL(ovs_vport_deferred_free);
int ovs_tunnel_get_egress_info(struct ip_tunnel_info *egress_tun_info, int ovs_tunnel_get_egress_info(struct ip_tunnel_info *egress_tun_info,
struct net *net, struct net *net,
const struct ip_tunnel_info *tun_info, struct sk_buff *skb,
u8 ipproto, u8 ipproto,
u32 skb_mark,
__be16 tp_src, __be16 tp_src,
__be16 tp_dst) __be16 tp_dst)
{ {
const struct ip_tunnel_info *tun_info = skb_tunnel_info(skb);
const struct ip_tunnel_key *tun_key; const struct ip_tunnel_key *tun_key;
u32 skb_mark = skb->mark;
struct rtable *rt; struct rtable *rt;
struct flowi4 fl; struct flowi4 fl;
......
...@@ -36,10 +36,6 @@ struct vport_parms; ...@@ -36,10 +36,6 @@ struct vport_parms;
/* The following definitions are for users of the vport subsytem: */ /* The following definitions are for users of the vport subsytem: */
struct vport_net {
struct vport __rcu *gre_vport;
};
int ovs_vport_init(void); int ovs_vport_init(void);
void ovs_vport_exit(void); void ovs_vport_exit(void);
...@@ -57,26 +53,15 @@ int ovs_vport_set_upcall_portids(struct vport *, const struct nlattr *pids); ...@@ -57,26 +53,15 @@ int ovs_vport_set_upcall_portids(struct vport *, const struct nlattr *pids);
int ovs_vport_get_upcall_portids(const struct vport *, struct sk_buff *); int ovs_vport_get_upcall_portids(const struct vport *, struct sk_buff *);
u32 ovs_vport_find_upcall_portid(const struct vport *, struct sk_buff *); u32 ovs_vport_find_upcall_portid(const struct vport *, struct sk_buff *);
int ovs_vport_send(struct vport *, struct sk_buff *);
int ovs_tunnel_get_egress_info(struct ip_tunnel_info *egress_tun_info, int ovs_tunnel_get_egress_info(struct ip_tunnel_info *egress_tun_info,
struct net *net, struct net *net,
const struct ip_tunnel_info *tun_info, struct sk_buff *,
u8 ipproto, u8 ipproto,
u32 skb_mark,
__be16 tp_src, __be16 tp_src,
__be16 tp_dst); __be16 tp_dst);
int ovs_vport_get_egress_tun_info(struct vport *vport, struct sk_buff *skb, int ovs_vport_get_egress_tun_info(struct vport *vport, struct sk_buff *skb,
struct ip_tunnel_info *info); struct ip_tunnel_info *info);
/* The following definitions are for implementers of vport devices: */
struct vport_err_stats {
atomic_long_t rx_dropped;
atomic_long_t rx_errors;
atomic_long_t tx_dropped;
atomic_long_t tx_errors;
};
/** /**
* struct vport_portids - array of netlink portids of a vport. * struct vport_portids - array of netlink portids of a vport.
* must be protected by rcu. * must be protected by rcu.
...@@ -102,8 +87,6 @@ struct vport_portids { ...@@ -102,8 +87,6 @@ struct vport_portids {
* @hash_node: Element in @dev_table hash table in vport.c. * @hash_node: Element in @dev_table hash table in vport.c.
* @dp_hash_node: Element in @datapath->ports hash table in datapath.c. * @dp_hash_node: Element in @datapath->ports hash table in datapath.c.
* @ops: Class structure. * @ops: Class structure.
* @percpu_stats: Points to per-CPU statistics used and maintained by vport
* @err_stats: Points to error statistics used and maintained by vport
* @detach_list: list used for detaching vport in net-exit call. * @detach_list: list used for detaching vport in net-exit call.
*/ */
struct vport { struct vport {
...@@ -116,9 +99,6 @@ struct vport { ...@@ -116,9 +99,6 @@ struct vport {
struct hlist_node dp_hash_node; struct hlist_node dp_hash_node;
const struct vport_ops *ops; const struct vport_ops *ops;
struct pcpu_sw_netstats __percpu *percpu_stats;
struct vport_err_stats err_stats;
struct list_head detach_list; struct list_head detach_list;
struct rcu_head rcu; struct rcu_head rcu;
}; };
...@@ -157,8 +137,7 @@ struct vport_parms { ...@@ -157,8 +137,7 @@ struct vport_parms {
* @get_options: Appends vport-specific attributes for the configuration of an * @get_options: Appends vport-specific attributes for the configuration of an
* existing vport to a &struct sk_buff. May be %NULL for a vport that does not * existing vport to a &struct sk_buff. May be %NULL for a vport that does not
* have any configuration. * have any configuration.
* @get_name: Get the device's name. * @send: Send a packet on the device.
* @send: Send a packet on the device. Returns the length of the packet sent,
* zero for dropped packets or negative for error. * zero for dropped packets or negative for error.
* @get_egress_tun_info: Get the egress tunnel 5-tuple and other info for * @get_egress_tun_info: Get the egress tunnel 5-tuple and other info for
* a packet. * a packet.
...@@ -173,10 +152,7 @@ struct vport_ops { ...@@ -173,10 +152,7 @@ struct vport_ops {
int (*set_options)(struct vport *, struct nlattr *); int (*set_options)(struct vport *, struct nlattr *);
int (*get_options)(const struct vport *, struct sk_buff *); int (*get_options)(const struct vport *, struct sk_buff *);
/* Called with rcu_read_lock or ovs_mutex. */ void (*send)(struct vport *, struct sk_buff *);
const char *(*get_name)(const struct vport *);
int (*send)(struct vport *, struct sk_buff *);
int (*get_egress_tun_info)(struct vport *, struct sk_buff *, int (*get_egress_tun_info)(struct vport *, struct sk_buff *,
struct ip_tunnel_info *); struct ip_tunnel_info *);
...@@ -184,13 +160,6 @@ struct vport_ops { ...@@ -184,13 +160,6 @@ struct vport_ops {
struct list_head list; struct list_head list;
}; };
enum vport_err_type {
VPORT_E_RX_DROPPED,
VPORT_E_RX_ERROR,
VPORT_E_TX_DROPPED,
VPORT_E_TX_ERROR,
};
struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *, struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *,
const struct vport_parms *); const struct vport_parms *);
void ovs_vport_free(struct vport *); void ovs_vport_free(struct vport *);
...@@ -227,7 +196,7 @@ static inline struct vport *vport_from_priv(void *priv) ...@@ -227,7 +196,7 @@ static inline struct vport *vport_from_priv(void *priv)
return (struct vport *)((u8 *)priv - ALIGN(sizeof(struct vport), VPORT_ALIGN)); return (struct vport *)((u8 *)priv - ALIGN(sizeof(struct vport), VPORT_ALIGN));
} }
void ovs_vport_receive(struct vport *, struct sk_buff *, int ovs_vport_receive(struct vport *, struct sk_buff *,
const struct ip_tunnel_info *); const struct ip_tunnel_info *);
static inline void ovs_skb_postpush_rcsum(struct sk_buff *skb, static inline void ovs_skb_postpush_rcsum(struct sk_buff *skb,
...@@ -239,7 +208,7 @@ static inline void ovs_skb_postpush_rcsum(struct sk_buff *skb, ...@@ -239,7 +208,7 @@ static inline void ovs_skb_postpush_rcsum(struct sk_buff *skb,
static inline const char *ovs_vport_name(struct vport *vport) static inline const char *ovs_vport_name(struct vport *vport)
{ {
return vport->dev ? vport->dev->name : vport->ops->get_name(vport); return vport->dev->name;
} }
int ovs_vport_ops_register(struct vport_ops *ops); int ovs_vport_ops_register(struct vport_ops *ops);
...@@ -263,4 +232,10 @@ static inline struct rtable *ovs_tunnel_route_lookup(struct net *net, ...@@ -263,4 +232,10 @@ static inline struct rtable *ovs_tunnel_route_lookup(struct net *net,
rt = ip_route_output_key(net, fl); rt = ip_route_output_key(net, fl);
return rt; return rt;
} }
static inline void ovs_vport_send(struct vport *vport, struct sk_buff *skb)
{
vport->ops->send(vport, skb);
}
#endif /* vport.h */ #endif /* vport.h */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册