Lines Matching refs:vport
31 struct vport *vport; in netdev_port_receive() local
33 vport = ovs_netdev_get_vport(skb->dev); in netdev_port_receive()
34 if (unlikely(!vport)) in netdev_port_receive()
50 ovs_vport_receive(vport, skb, skb_tunnel_info(skb)); in netdev_port_receive()
70 struct vport *local; in get_dpdev()
76 struct vport *ovs_netdev_link(struct vport *vport, const char *name) in ovs_netdev_link() argument
80 vport->dev = dev_get_by_name(ovs_dp_get_net(vport->dp), name); in ovs_netdev_link()
81 if (!vport->dev) { in ovs_netdev_link()
88 if (strcmp(name, ovs_vport_name(vport))) { in ovs_netdev_link()
92 netdev_tracker_alloc(vport->dev, &vport->dev_tracker, GFP_KERNEL); in ovs_netdev_link()
93 if (vport->dev->flags & IFF_LOOPBACK || in ovs_netdev_link()
94 (vport->dev->type != ARPHRD_ETHER && in ovs_netdev_link()
95 vport->dev->type != ARPHRD_NONE) || in ovs_netdev_link()
96 ovs_is_internal_dev(vport->dev)) { in ovs_netdev_link()
102 err = netdev_master_upper_dev_link(vport->dev, in ovs_netdev_link()
103 get_dpdev(vport->dp), in ovs_netdev_link()
108 err = netdev_rx_handler_register(vport->dev, netdev_frame_hook, in ovs_netdev_link()
109 vport); in ovs_netdev_link()
113 dev_disable_lro(vport->dev); in ovs_netdev_link()
114 dev_set_promiscuity(vport->dev, 1); in ovs_netdev_link()
115 vport->dev->priv_flags |= IFF_OVS_DATAPATH; in ovs_netdev_link()
118 return vport; in ovs_netdev_link()
121 netdev_upper_dev_unlink(vport->dev, get_dpdev(vport->dp)); in ovs_netdev_link()
125 netdev_put(vport->dev, &vport->dev_tracker); in ovs_netdev_link()
127 ovs_vport_free(vport); in ovs_netdev_link()
132 static struct vport *netdev_create(const struct vport_parms *parms) in netdev_create()
134 struct vport *vport; in netdev_create() local
136 vport = ovs_vport_alloc(0, &ovs_netdev_vport_ops, parms); in netdev_create()
137 if (IS_ERR(vport)) in netdev_create()
138 return vport; in netdev_create()
140 return ovs_netdev_link(vport, parms->name); in netdev_create()
145 struct vport *vport = container_of(rcu, struct vport, rcu); in vport_netdev_free() local
147 netdev_put(vport->dev, &vport->dev_tracker); in vport_netdev_free()
148 ovs_vport_free(vport); in vport_netdev_free()
151 void ovs_netdev_detach_dev(struct vport *vport) in ovs_netdev_detach_dev() argument
154 vport->dev->priv_flags &= ~IFF_OVS_DATAPATH; in ovs_netdev_detach_dev()
155 netdev_rx_handler_unregister(vport->dev); in ovs_netdev_detach_dev()
156 netdev_upper_dev_unlink(vport->dev, in ovs_netdev_detach_dev()
157 netdev_master_upper_dev_get(vport->dev)); in ovs_netdev_detach_dev()
158 dev_set_promiscuity(vport->dev, -1); in ovs_netdev_detach_dev()
161 static void netdev_destroy(struct vport *vport) in netdev_destroy() argument
164 if (netif_is_ovs_port(vport->dev)) in netdev_destroy()
165 ovs_netdev_detach_dev(vport); in netdev_destroy()
168 call_rcu(&vport->rcu, vport_netdev_free); in netdev_destroy()
171 void ovs_netdev_tunnel_destroy(struct vport *vport) in ovs_netdev_tunnel_destroy() argument
174 if (netif_is_ovs_port(vport->dev)) in ovs_netdev_tunnel_destroy()
175 ovs_netdev_detach_dev(vport); in ovs_netdev_tunnel_destroy()
181 if (vport->dev->reg_state == NETREG_REGISTERED) in ovs_netdev_tunnel_destroy()
182 rtnl_delete_link(vport->dev, 0, NULL); in ovs_netdev_tunnel_destroy()
183 netdev_put(vport->dev, &vport->dev_tracker); in ovs_netdev_tunnel_destroy()
184 vport->dev = NULL; in ovs_netdev_tunnel_destroy()
187 call_rcu(&vport->rcu, vport_netdev_free); in ovs_netdev_tunnel_destroy()
192 struct vport *ovs_netdev_get_vport(struct net_device *dev) in ovs_netdev_get_vport()
195 return (struct vport *) in ovs_netdev_get_vport()