datapath: Merge vport "attach" into "create" and "detach" into "destroy".
[sliver-openvswitch.git] / datapath / vport.c
1 /*
2  * Copyright (c) 2010 Nicira Networks.
3  * Distributed under the terms of the GNU GPL version 2.
4  *
5  * Significant portions of this file may be copied from parts of the Linux
6  * kernel, by Linus Torvalds and others.
7  */
8
9 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
10
11 #include <linux/dcache.h>
12 #include <linux/etherdevice.h>
13 #include <linux/if.h>
14 #include <linux/if_vlan.h>
15 #include <linux/kernel.h>
16 #include <linux/list.h>
17 #include <linux/mutex.h>
18 #include <linux/percpu.h>
19 #include <linux/rtnetlink.h>
20 #include <linux/compat.h>
21 #include <linux/version.h>
22
23 #include "vport.h"
24 #include "vport-internal_dev.h"
25
26 /* List of statically compiled vport implementations.  Don't forget to also
27  * add yours to the list at the bottom of vport.h. */
28 static const struct vport_ops *base_vport_ops_list[] = {
29         &netdev_vport_ops,
30         &internal_vport_ops,
31         &patch_vport_ops,
32         &gre_vport_ops,
33 #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,26)
34         &capwap_vport_ops,
35 #endif
36 };
37
38 static const struct vport_ops **vport_ops_list;
39 static int n_vport_types;
40
41 static struct hlist_head *dev_table;
42 #define VPORT_HASH_BUCKETS 1024
43
44 /* Both RTNL lock and vport_mutex need to be held when updating dev_table.
45  *
46  * If you use vport_locate and then perform some operations, you need to hold
47  * one of these locks if you don't want the vport to be deleted out from under
48  * you.
49  *
50  * If you get a reference to a vport through a datapath, it is protected
51  * by RCU and you need to hold rcu_read_lock instead when reading.
52  *
53  * If multiple locks are taken, the hierarchy is:
54  * 1. RTNL
55  * 2. DP
56  * 3. vport
57  */
58 static DEFINE_MUTEX(vport_mutex);
59
60 /**
61  *      vport_lock - acquire vport lock
62  *
63  * Acquire global vport lock.  See above comment about locking requirements
64  * and specific function definitions.  May sleep.
65  */
66 void vport_lock(void)
67 {
68         mutex_lock(&vport_mutex);
69 }
70
71 /**
72  *      vport_unlock - release vport lock
73  *
74  * Release lock acquired with vport_lock.
75  */
76 void vport_unlock(void)
77 {
78         mutex_unlock(&vport_mutex);
79 }
80
81 #define ASSERT_VPORT()                                          \
82 do {                                                            \
83         if (unlikely(!mutex_is_locked(&vport_mutex))) {         \
84                 pr_err("vport lock not held at %s (%d)\n",      \
85                        __FILE__, __LINE__);                     \
86                 dump_stack();                                   \
87         }                                                       \
88 } while (0)
89
90 /**
91  *      vport_init - initialize vport subsystem
92  *
93  * Called at module load time to initialize the vport subsystem and any
94  * compiled in vport types.
95  */
96 int vport_init(void)
97 {
98         int err;
99         int i;
100
101         dev_table = kzalloc(VPORT_HASH_BUCKETS * sizeof(struct hlist_head),
102                             GFP_KERNEL);
103         if (!dev_table) {
104                 err = -ENOMEM;
105                 goto error;
106         }
107
108         vport_ops_list = kmalloc(ARRAY_SIZE(base_vport_ops_list) *
109                                  sizeof(struct vport_ops *), GFP_KERNEL);
110         if (!vport_ops_list) {
111                 err = -ENOMEM;
112                 goto error_dev_table;
113         }
114
115         for (i = 0; i < ARRAY_SIZE(base_vport_ops_list); i++) {
116                 const struct vport_ops *new_ops = base_vport_ops_list[i];
117
118                 if (new_ops->init)
119                         err = new_ops->init();
120                 else
121                         err = 0;
122
123                 if (!err)
124                         vport_ops_list[n_vport_types++] = new_ops;
125                 else if (new_ops->flags & VPORT_F_REQUIRED) {
126                         vport_exit();
127                         goto error;
128                 }
129         }
130
131         return 0;
132
133 error_dev_table:
134         kfree(dev_table);
135 error:
136         return err;
137 }
138
139 static void vport_del_all(void)
140 {
141         int i;
142
143         rtnl_lock();
144         vport_lock();
145
146         for (i = 0; i < VPORT_HASH_BUCKETS; i++) {
147                 struct hlist_head *bucket = &dev_table[i];
148                 struct vport *vport;
149                 struct hlist_node *node, *next;
150
151                 hlist_for_each_entry_safe(vport, node, next, bucket, hash_node)
152                         vport_del(vport);
153         }
154
155         vport_unlock();
156         rtnl_unlock();
157 }
158
159 /**
160  *      vport_exit - shutdown vport subsystem
161  *
162  * Called at module exit time to shutdown the vport subsystem and any
163  * initialized vport types.
164  */
165 void vport_exit(void)
166 {
167         int i;
168
169         vport_del_all();
170
171         for (i = 0; i < n_vport_types; i++) {
172                 if (vport_ops_list[i]->exit)
173                         vport_ops_list[i]->exit();
174         }
175
176         kfree(vport_ops_list);
177         kfree(dev_table);
178 }
179
180 /**
181  *      vport_user_mod - modify existing vport device (for userspace callers)
182  *
183  * @uport: New configuration for vport
184  *
185  * Modifies an existing device with the specified configuration (which is
186  * dependent on device type).  This function is for userspace callers and
187  * assumes no locks are held.
188  */
189 int vport_user_mod(const struct odp_port __user *uport)
190 {
191         struct odp_port port;
192         struct vport *vport;
193         int err;
194
195         if (copy_from_user(&port, uport, sizeof(port)))
196                 return -EFAULT;
197
198         port.devname[IFNAMSIZ - 1] = '\0';
199
200         rtnl_lock();
201
202         vport = vport_locate(port.devname);
203         if (!vport) {
204                 err = -ENODEV;
205                 goto out;
206         }
207
208         vport_lock();
209         err = vport_mod(vport, &port);
210         vport_unlock();
211
212 out:
213         rtnl_unlock();
214         return err;
215 }
216
217 /**
218  *      vport_user_stats_get - retrieve device stats (for userspace callers)
219  *
220  * @ustats_req: Stats request parameters.
221  *
222  * Retrieves transmit, receive, and error stats for the given device.  This
223  * function is for userspace callers and assumes no locks are held.
224  */
225 int vport_user_stats_get(struct odp_vport_stats_req __user *ustats_req)
226 {
227         struct odp_vport_stats_req stats_req;
228         struct vport *vport;
229         int err;
230
231         if (copy_from_user(&stats_req, ustats_req, sizeof(struct odp_vport_stats_req)))
232                 return -EFAULT;
233
234         stats_req.devname[IFNAMSIZ - 1] = '\0';
235
236         vport_lock();
237
238         vport = vport_locate(stats_req.devname);
239         if (!vport) {
240                 err = -ENODEV;
241                 goto out;
242         }
243
244         err = vport_get_stats(vport, &stats_req.stats);
245
246 out:
247         vport_unlock();
248
249         if (!err)
250                 if (copy_to_user(ustats_req, &stats_req, sizeof(struct odp_vport_stats_req)))
251                         err = -EFAULT;
252
253         return err;
254 }
255
256 /**
257  *      vport_user_stats_set - sets offset device stats (for userspace callers)
258  *
259  * @ustats_req: Stats set parameters.
260  *
261  * Provides a set of transmit, receive, and error stats to be added as an
262  * offset to the collect data when stats are retreived.  Some devices may not
263  * support setting the stats, in which case the result will always be
264  * -EOPNOTSUPP.  This function is for userspace callers and assumes no locks
265  * are held.
266  */
267 int vport_user_stats_set(struct odp_vport_stats_req __user *ustats_req)
268 {
269         struct odp_vport_stats_req stats_req;
270         struct vport *vport;
271         int err;
272
273         if (copy_from_user(&stats_req, ustats_req, sizeof(struct odp_vport_stats_req)))
274                 return -EFAULT;
275
276         stats_req.devname[IFNAMSIZ - 1] = '\0';
277
278         rtnl_lock();
279         vport_lock();
280
281         vport = vport_locate(stats_req.devname);
282         if (!vport) {
283                 err = -ENODEV;
284                 goto out;
285         }
286
287         err = vport_set_stats(vport, &stats_req.stats);
288
289 out:
290         vport_unlock();
291         rtnl_unlock();
292         return err;
293 }
294
295
296 /**
297  *      vport_user_ether_get - retrieve device Ethernet address (for userspace callers)
298  *
299  * @uvport_ether: Ethernet address request parameters.
300  *
301  * Retrieves the Ethernet address of the given device.  This function is for
302  * userspace callers and assumes no locks are held.
303  */
304 int vport_user_ether_get(struct odp_vport_ether __user *uvport_ether)
305 {
306         struct odp_vport_ether vport_ether;
307         struct vport *vport;
308         int err = 0;
309
310         if (copy_from_user(&vport_ether, uvport_ether, sizeof(struct odp_vport_ether)))
311                 return -EFAULT;
312
313         vport_ether.devname[IFNAMSIZ - 1] = '\0';
314
315         vport_lock();
316
317         vport = vport_locate(vport_ether.devname);
318         if (!vport) {
319                 err = -ENODEV;
320                 goto out;
321         }
322
323         rcu_read_lock();
324         memcpy(vport_ether.ether_addr, vport_get_addr(vport), ETH_ALEN);
325         rcu_read_unlock();
326
327 out:
328         vport_unlock();
329
330         if (!err)
331                 if (copy_to_user(uvport_ether, &vport_ether, sizeof(struct odp_vport_ether)))
332                         err = -EFAULT;
333
334         return err;
335 }
336
337 /**
338  *      vport_user_ether_set - set device Ethernet address (for userspace callers)
339  *
340  * @uvport_ether: Ethernet address request parameters.
341  *
342  * Sets the Ethernet address of the given device.  Some devices may not support
343  * setting the Ethernet address, in which case the result will always be
344  * -EOPNOTSUPP.  This function is for userspace callers and assumes no locks
345  * are held.
346  */
347 int vport_user_ether_set(struct odp_vport_ether __user *uvport_ether)
348 {
349         struct odp_vport_ether vport_ether;
350         struct vport *vport;
351         int err;
352
353         if (copy_from_user(&vport_ether, uvport_ether, sizeof(struct odp_vport_ether)))
354                 return -EFAULT;
355
356         vport_ether.devname[IFNAMSIZ - 1] = '\0';
357
358         rtnl_lock();
359         vport_lock();
360
361         vport = vport_locate(vport_ether.devname);
362         if (!vport) {
363                 err = -ENODEV;
364                 goto out;
365         }
366
367         err = vport_set_addr(vport, vport_ether.ether_addr);
368
369 out:
370         vport_unlock();
371         rtnl_unlock();
372         return err;
373 }
374
375 /**
376  *      vport_user_mtu_get - retrieve device MTU (for userspace callers)
377  *
378  * @uvport_mtu: MTU request parameters.
379  *
380  * Retrieves the MTU of the given device.  This function is for userspace
381  * callers and assumes no locks are held.
382  */
383 int vport_user_mtu_get(struct odp_vport_mtu __user *uvport_mtu)
384 {
385         struct odp_vport_mtu vport_mtu;
386         struct vport *vport;
387         int err = 0;
388
389         if (copy_from_user(&vport_mtu, uvport_mtu, sizeof(struct odp_vport_mtu)))
390                 return -EFAULT;
391
392         vport_mtu.devname[IFNAMSIZ - 1] = '\0';
393
394         vport_lock();
395
396         vport = vport_locate(vport_mtu.devname);
397         if (!vport) {
398                 err = -ENODEV;
399                 goto out;
400         }
401
402         vport_mtu.mtu = vport_get_mtu(vport);
403
404 out:
405         vport_unlock();
406
407         if (!err)
408                 if (copy_to_user(uvport_mtu, &vport_mtu, sizeof(struct odp_vport_mtu)))
409                         err = -EFAULT;
410
411         return err;
412 }
413
414 /**
415  *      vport_user_mtu_set - set device MTU (for userspace callers)
416  *
417  * @uvport_mtu: MTU request parameters.
418  *
419  * Sets the MTU of the given device.  Some devices may not support setting the
420  * MTU, in which case the result will always be -EOPNOTSUPP.  This function is
421  * for userspace callers and assumes no locks are held.
422  */
423 int vport_user_mtu_set(struct odp_vport_mtu __user *uvport_mtu)
424 {
425         struct odp_vport_mtu vport_mtu;
426         struct vport *vport;
427         int err;
428
429         if (copy_from_user(&vport_mtu, uvport_mtu, sizeof(struct odp_vport_mtu)))
430                 return -EFAULT;
431
432         vport_mtu.devname[IFNAMSIZ - 1] = '\0';
433
434         rtnl_lock();
435         vport_lock();
436
437         vport = vport_locate(vport_mtu.devname);
438         if (!vport) {
439                 err = -ENODEV;
440                 goto out;
441         }
442
443         err = vport_set_mtu(vport, vport_mtu.mtu);
444
445 out:
446         vport_unlock();
447         rtnl_unlock();
448         return err;
449 }
450
451 static struct hlist_head *hash_bucket(const char *name)
452 {
453         unsigned int hash = full_name_hash(name, strlen(name));
454         return &dev_table[hash & (VPORT_HASH_BUCKETS - 1)];
455 }
456
457 /**
458  *      vport_locate - find a port that has already been created
459  *
460  * @name: name of port to find
461  *
462  * Either RTNL or vport lock must be acquired before calling this function
463  * and held while using the found port.  See the locking comments at the
464  * top of the file.
465  */
466 struct vport *vport_locate(const char *name)
467 {
468         struct hlist_head *bucket = hash_bucket(name);
469         struct vport *vport;
470         struct hlist_node *node;
471
472         if (unlikely(!mutex_is_locked(&vport_mutex) && !rtnl_is_locked())) {
473                 pr_err("neither RTNL nor vport lock held in vport_locate\n");
474                 dump_stack();
475         }
476
477         rcu_read_lock();
478
479         hlist_for_each_entry(vport, node, bucket, hash_node)
480                 if (!strcmp(name, vport_get_name(vport)))
481                         goto out;
482
483         vport = NULL;
484
485 out:
486         rcu_read_unlock();
487         return vport;
488 }
489
490 static void register_vport(struct vport *vport)
491 {
492         hlist_add_head(&vport->hash_node, hash_bucket(vport_get_name(vport)));
493 }
494
495 static void unregister_vport(struct vport *vport)
496 {
497         hlist_del(&vport->hash_node);
498 }
499
500 static void release_vport(struct kobject *kobj)
501 {
502         struct vport *p = container_of(kobj, struct vport, kobj);
503         kfree(p);
504 }
505
506 static struct kobj_type brport_ktype = {
507 #ifdef CONFIG_SYSFS
508         .sysfs_ops = &brport_sysfs_ops,
509 #endif
510         .release = release_vport
511 };
512
513 /**
514  *      vport_alloc - allocate and initialize new vport
515  *
516  * @priv_size: Size of private data area to allocate.
517  * @ops: vport device ops
518  *
519  * Allocate and initialize a new vport defined by @ops.  The vport will contain
520  * a private data area of size @priv_size that can be accessed using
521  * vport_priv().  vports that are no longer needed should be released with
522  * vport_free().
523  */
524 struct vport *vport_alloc(int priv_size, const struct vport_ops *ops, const struct vport_parms *parms)
525 {
526         struct vport *vport;
527         size_t alloc_size;
528
529         alloc_size = sizeof(struct vport);
530         if (priv_size) {
531                 alloc_size = ALIGN(alloc_size, VPORT_ALIGN);
532                 alloc_size += priv_size;
533         }
534
535         vport = kzalloc(alloc_size, GFP_KERNEL);
536         if (!vport)
537                 return ERR_PTR(-ENOMEM);
538
539         vport->dp = parms->dp;
540         vport->port_no = parms->port_no;
541         atomic_set(&vport->sflow_pool, 0);
542         vport->ops = ops;
543
544         /* Initialize kobject for bridge.  This will be added as
545          * /sys/class/net/<devname>/brport later, if sysfs is enabled. */
546         vport->kobj.kset = NULL;
547         kobject_init(&vport->kobj, &brport_ktype);
548
549         if (vport->ops->flags & VPORT_F_GEN_STATS) {
550                 vport->percpu_stats = alloc_percpu(struct vport_percpu_stats);
551                 if (!vport->percpu_stats)
552                         return ERR_PTR(-ENOMEM);
553
554                 spin_lock_init(&vport->stats_lock);
555         }
556
557         return vport;
558 }
559
560 /**
561  *      vport_free - uninitialize and free vport
562  *
563  * @vport: vport to free
564  *
565  * Frees a vport allocated with vport_alloc() when it is no longer needed.
566  */
567 void vport_free(struct vport *vport)
568 {
569         if (vport->ops->flags & VPORT_F_GEN_STATS)
570                 free_percpu(vport->percpu_stats);
571
572         kobject_put(&vport->kobj);
573 }
574
575 /**
576  *      vport_add - add vport device (for kernel callers)
577  *
578  * @parms: Information about new vport.
579  *
580  * Creates a new vport with the specified configuration (which is dependent on
581  * device type) and attaches it to a datapath.  Both RTNL and vport locks must
582  * be held.
583  */
584 struct vport *vport_add(const struct vport_parms *parms)
585 {
586         struct vport *vport;
587         int err = 0;
588         int i;
589
590         ASSERT_RTNL();
591         ASSERT_VPORT();
592
593         for (i = 0; i < n_vport_types; i++) {
594                 if (!strcmp(vport_ops_list[i]->type, parms->type)) {
595                         vport = vport_ops_list[i]->create(parms);
596                         if (IS_ERR(vport)) {
597                                 err = PTR_ERR(vport);
598                                 goto out;
599                         }
600
601                         register_vport(vport);
602                         return vport;
603                 }
604         }
605
606         err = -EAFNOSUPPORT;
607
608 out:
609         return ERR_PTR(err);
610 }
611
612 /**
613  *      vport_mod - modify existing vport device (for kernel callers)
614  *
615  * @vport: vport to modify.
616  * @port: New configuration.
617  *
618  * Modifies an existing device with the specified configuration (which is
619  * dependent on device type).  Both RTNL and vport locks must be held.
620  */
621 int vport_mod(struct vport *vport, struct odp_port *port)
622 {
623         ASSERT_RTNL();
624         ASSERT_VPORT();
625
626         if (vport->ops->modify)
627                 return vport->ops->modify(vport, port);
628         else
629                 return -EOPNOTSUPP;
630 }
631
632 /**
633  *      vport_del - delete existing vport device (for kernel callers)
634  *
635  * @vport: vport to delete.
636  *
637  * Detaches @vport from its datapath and destroys it.  It is possible to fail
638  * for reasons such as lack of memory.  Both RTNL and vport locks must be held.
639  */
640 int vport_del(struct vport *vport)
641 {
642         ASSERT_RTNL();
643         ASSERT_VPORT();
644
645         unregister_vport(vport);
646
647         return vport->ops->destroy(vport);
648 }
649
650 /**
651  *      vport_set_mtu - set device MTU (for kernel callers)
652  *
653  * @vport: vport on which to set MTU.
654  * @mtu: New MTU.
655  *
656  * Sets the MTU of the given device.  Some devices may not support setting the
657  * MTU, in which case the result will always be -EOPNOTSUPP.  RTNL lock must
658  * be held.
659  */
660 int vport_set_mtu(struct vport *vport, int mtu)
661 {
662         ASSERT_RTNL();
663
664         if (mtu < 68)
665                 return -EINVAL;
666
667         if (vport->ops->set_mtu) {
668                 int ret;
669
670                 ret = vport->ops->set_mtu(vport, mtu);
671
672                 if (!ret && !is_internal_vport(vport))
673                         set_internal_devs_mtu(vport->dp);
674
675                 return ret;
676         } else
677                 return -EOPNOTSUPP;
678 }
679
680 /**
681  *      vport_set_addr - set device Ethernet address (for kernel callers)
682  *
683  * @vport: vport on which to set Ethernet address.
684  * @addr: New address.
685  *
686  * Sets the Ethernet address of the given device.  Some devices may not support
687  * setting the Ethernet address, in which case the result will always be
688  * -EOPNOTSUPP.  RTNL lock must be held.
689  */
690 int vport_set_addr(struct vport *vport, const unsigned char *addr)
691 {
692         ASSERT_RTNL();
693
694         if (!is_valid_ether_addr(addr))
695                 return -EADDRNOTAVAIL;
696
697         if (vport->ops->set_addr)
698                 return vport->ops->set_addr(vport, addr);
699         else
700                 return -EOPNOTSUPP;
701 }
702
703 /**
704  *      vport_set_stats - sets offset device stats (for kernel callers)
705  *
706  * @vport: vport on which to set stats
707  * @stats: stats to set
708  *
709  * Provides a set of transmit, receive, and error stats to be added as an
710  * offset to the collect data when stats are retreived.  Some devices may not
711  * support setting the stats, in which case the result will always be
712  * -EOPNOTSUPP.  RTNL lock must be held.
713  */
714 int vport_set_stats(struct vport *vport, struct rtnl_link_stats64 *stats)
715 {
716         ASSERT_RTNL();
717
718         if (vport->ops->flags & VPORT_F_GEN_STATS) {
719                 spin_lock_bh(&vport->stats_lock);
720                 vport->offset_stats = *stats;
721                 spin_unlock_bh(&vport->stats_lock);
722
723                 return 0;
724         } else if (vport->ops->set_stats)
725                 return vport->ops->set_stats(vport, stats);
726         else
727                 return -EOPNOTSUPP;
728 }
729
730 /**
731  *      vport_get_name - retrieve device name
732  *
733  * @vport: vport from which to retrieve the name.
734  *
735  * Retrieves the name of the given device.  Either RTNL lock or rcu_read_lock
736  * must be held for the entire duration that the name is in use.
737  */
738 const char *vport_get_name(const struct vport *vport)
739 {
740         return vport->ops->get_name(vport);
741 }
742
743 /**
744  *      vport_get_type - retrieve device type
745  *
746  * @vport: vport from which to retrieve the type.
747  *
748  * Retrieves the type of the given device.  Either RTNL lock or rcu_read_lock
749  * must be held for the entire duration that the type is in use.
750  */
751 const char *vport_get_type(const struct vport *vport)
752 {
753         return vport->ops->type;
754 }
755
756 /**
757  *      vport_get_addr - retrieve device Ethernet address (for kernel callers)
758  *
759  * @vport: vport from which to retrieve the Ethernet address.
760  *
761  * Retrieves the Ethernet address of the given device.  Either RTNL lock or
762  * rcu_read_lock must be held for the entire duration that the Ethernet address
763  * is in use.
764  */
765 const unsigned char *vport_get_addr(const struct vport *vport)
766 {
767         return vport->ops->get_addr(vport);
768 }
769
770 /**
771  *      vport_get_kobj - retrieve associated kobj
772  *
773  * @vport: vport from which to retrieve the associated kobj
774  *
775  * Retrieves the associated kobj or null if no kobj.  The returned kobj is
776  * valid for as long as the vport exists.
777  */
778 struct kobject *vport_get_kobj(const struct vport *vport)
779 {
780         if (vport->ops->get_kobj)
781                 return vport->ops->get_kobj(vport);
782         else
783                 return NULL;
784 }
785
786 /**
787  *      vport_get_stats - retrieve device stats (for kernel callers)
788  *
789  * @vport: vport from which to retrieve the stats
790  * @stats: location to store stats
791  *
792  * Retrieves transmit, receive, and error stats for the given device.
793  */
794 int vport_get_stats(struct vport *vport, struct rtnl_link_stats64 *stats)
795 {
796         struct rtnl_link_stats64 dev_stats;
797         struct rtnl_link_stats64 *dev_statsp = NULL;
798         int err;
799
800         if (vport->ops->get_stats) {
801                 if (vport->ops->flags & VPORT_F_GEN_STATS)
802                         dev_statsp = &dev_stats;
803                 else
804                         dev_statsp = stats;
805
806                 rcu_read_lock();
807                 err = vport->ops->get_stats(vport, dev_statsp);
808                 rcu_read_unlock();
809
810                 if (err)
811                         goto out;
812         }
813
814         if (vport->ops->flags & VPORT_F_GEN_STATS) {
815                 int i;
816
817                 /* We potentially have 3 sources of stats that need to be
818                  * combined: those we have collected (split into err_stats and
819                  * percpu_stats), offset_stats from set_stats(), and device
820                  * error stats from get_stats() (for errors that happen
821                  * downstream and therefore aren't reported through our
822                  * vport_record_error() function). */
823
824                 spin_lock_bh(&vport->stats_lock);
825
826                 *stats = vport->offset_stats;
827
828                 stats->rx_errors        += vport->err_stats.rx_errors;
829                 stats->tx_errors        += vport->err_stats.tx_errors;
830                 stats->tx_dropped       += vport->err_stats.tx_dropped;
831                 stats->rx_dropped       += vport->err_stats.rx_dropped;
832
833                 spin_unlock_bh(&vport->stats_lock);
834
835                 if (dev_statsp) {
836                         stats->rx_packets          += dev_statsp->rx_packets;
837                         stats->tx_packets          += dev_statsp->tx_packets;
838                         stats->rx_bytes            += dev_statsp->rx_bytes;
839                         stats->tx_bytes            += dev_statsp->tx_bytes;
840                         stats->rx_errors           += dev_statsp->rx_errors;
841                         stats->tx_errors           += dev_statsp->tx_errors;
842                         stats->rx_dropped          += dev_statsp->rx_dropped;
843                         stats->tx_dropped          += dev_statsp->tx_dropped;
844                         stats->multicast           += dev_statsp->multicast;
845                         stats->collisions          += dev_statsp->collisions;
846                         stats->rx_length_errors    += dev_statsp->rx_length_errors;
847                         stats->rx_over_errors      += dev_statsp->rx_over_errors;
848                         stats->rx_crc_errors       += dev_statsp->rx_crc_errors;
849                         stats->rx_frame_errors     += dev_statsp->rx_frame_errors;
850                         stats->rx_fifo_errors      += dev_statsp->rx_fifo_errors;
851                         stats->rx_missed_errors    += dev_statsp->rx_missed_errors;
852                         stats->tx_aborted_errors   += dev_statsp->tx_aborted_errors;
853                         stats->tx_carrier_errors   += dev_statsp->tx_carrier_errors;
854                         stats->tx_fifo_errors      += dev_statsp->tx_fifo_errors;
855                         stats->tx_heartbeat_errors += dev_statsp->tx_heartbeat_errors;
856                         stats->tx_window_errors    += dev_statsp->tx_window_errors;
857                         stats->rx_compressed       += dev_statsp->rx_compressed;
858                         stats->tx_compressed       += dev_statsp->tx_compressed;
859                 }
860
861                 for_each_possible_cpu(i) {
862                         const struct vport_percpu_stats *percpu_stats;
863                         struct vport_percpu_stats local_stats;
864                         unsigned seqcount;
865
866                         percpu_stats = per_cpu_ptr(vport->percpu_stats, i);
867
868                         do {
869                                 seqcount = read_seqcount_begin(&percpu_stats->seqlock);
870                                 local_stats = *percpu_stats;
871                         } while (read_seqcount_retry(&percpu_stats->seqlock, seqcount));
872
873                         stats->rx_bytes         += local_stats.rx_bytes;
874                         stats->rx_packets       += local_stats.rx_packets;
875                         stats->tx_bytes         += local_stats.tx_bytes;
876                         stats->tx_packets       += local_stats.tx_packets;
877                 }
878
879                 err = 0;
880         } else
881                 err = -EOPNOTSUPP;
882
883 out:
884         return err;
885 }
886
887 /**
888  *      vport_get_flags - retrieve device flags
889  *
890  * @vport: vport from which to retrieve the flags
891  *
892  * Retrieves the flags of the given device.  Either RTNL lock or rcu_read_lock
893  * must be held.
894  */
895 unsigned vport_get_flags(const struct vport *vport)
896 {
897         return vport->ops->get_dev_flags(vport);
898 }
899
900 /**
901  *      vport_get_flags - check whether device is running
902  *
903  * @vport: vport on which to check status.
904  *
905  * Checks whether the given device is running.  Either RTNL lock or
906  * rcu_read_lock must be held.
907  */
908 int vport_is_running(const struct vport *vport)
909 {
910         return vport->ops->is_running(vport);
911 }
912
913 /**
914  *      vport_get_flags - retrieve device operating state
915  *
916  * @vport: vport from which to check status
917  *
918  * Retrieves the RFC2863 operstate of the given device.  Either RTNL lock or
919  * rcu_read_lock must be held.
920  */
921 unsigned char vport_get_operstate(const struct vport *vport)
922 {
923         return vport->ops->get_operstate(vport);
924 }
925
926 /**
927  *      vport_get_ifindex - retrieve device system interface index
928  *
929  * @vport: vport from which to retrieve index
930  *
931  * Retrieves the system interface index of the given device.  Not all devices
932  * will have system indexes, in which case the index of the datapath local
933  * port is returned.  Returns a negative index on error.  Either RTNL lock or
934  * rcu_read_lock must be held.
935  */
936 int vport_get_ifindex(const struct vport *vport)
937 {
938         if (vport->ops->get_ifindex)
939                 return vport->ops->get_ifindex(vport);
940
941         /* If we don't actually have an ifindex, use the local port's.
942          * Userspace doesn't check it anyways. */
943         return vport_get_ifindex(vport->dp->ports[ODPP_LOCAL]);
944 }
945
946 /**
947  *      vport_get_iflink - retrieve device system link index
948  *
949  * @vport: vport from which to retrieve index
950  *
951  * Retrieves the system link index of the given device.  The link is the index
952  * of the interface on which the packet will actually be sent.  In most cases
953  * this is the same as the ifindex but may be different for tunnel devices.
954  * Returns a negative index on error.  Either RTNL lock or rcu_read_lock must
955  * be held.
956  */
957 int vport_get_iflink(const struct vport *vport)
958 {
959         if (vport->ops->get_iflink)
960                 return vport->ops->get_iflink(vport);
961
962         /* If we don't have an iflink, use the ifindex.  In most cases they
963          * are the same. */
964         return vport_get_ifindex(vport);
965 }
966
967 /**
968  *      vport_get_mtu - retrieve device MTU (for kernel callers)
969  *
970  * @vport: vport from which to retrieve MTU
971  *
972  * Retrieves the MTU of the given device.  Either RTNL lock or rcu_read_lock
973  * must be held.
974  */
975 int vport_get_mtu(const struct vport *vport)
976 {
977         return vport->ops->get_mtu(vport);
978 }
979
980 /**
981  *      vport_receive - pass up received packet to the datapath for processing
982  *
983  * @vport: vport that received the packet
984  * @skb: skb that was received
985  *
986  * Must be called with rcu_read_lock.  The packet cannot be shared and
987  * skb->data should point to the Ethernet header.  The caller must have already
988  * called compute_ip_summed() to initialize the checksumming fields.
989  */
990 void vport_receive(struct vport *vport, struct sk_buff *skb)
991 {
992         if (vport->ops->flags & VPORT_F_GEN_STATS) {
993                 struct vport_percpu_stats *stats;
994
995                 local_bh_disable();
996                 stats = per_cpu_ptr(vport->percpu_stats, smp_processor_id());
997
998                 write_seqcount_begin(&stats->seqlock);
999                 stats->rx_packets++;
1000                 stats->rx_bytes += skb->len;
1001                 write_seqcount_end(&stats->seqlock);
1002
1003                 local_bh_enable();
1004         }
1005
1006         if (!(vport->ops->flags & VPORT_F_FLOW))
1007                 OVS_CB(skb)->flow = NULL;
1008
1009         if (!(vport->ops->flags & VPORT_F_TUN_ID))
1010                 OVS_CB(skb)->tun_id = 0;
1011
1012         dp_process_received_packet(vport, skb);
1013 }
1014
1015 static inline unsigned packet_length(const struct sk_buff *skb)
1016 {
1017         unsigned length = skb->len - ETH_HLEN;
1018
1019         if (skb->protocol == htons(ETH_P_8021Q))
1020                 length -= VLAN_HLEN;
1021
1022         return length;
1023 }
1024
1025 /**
1026  *      vport_send - send a packet on a device
1027  *
1028  * @vport: vport on which to send the packet
1029  * @skb: skb to send
1030  *
1031  * Sends the given packet and returns the length of data sent.  Either RTNL
1032  * lock or rcu_read_lock must be held.
1033  */
1034 int vport_send(struct vport *vport, struct sk_buff *skb)
1035 {
1036         int mtu;
1037         int sent;
1038
1039         mtu = vport_get_mtu(vport);
1040         if (unlikely(packet_length(skb) > mtu && !skb_is_gso(skb))) {
1041                 if (net_ratelimit())
1042                         pr_warn("%s: dropped over-mtu packet: %d > %d\n",
1043                                 dp_name(vport->dp), packet_length(skb), mtu);
1044                 goto error;
1045         }
1046
1047         sent = vport->ops->send(vport, skb);
1048
1049         if (vport->ops->flags & VPORT_F_GEN_STATS && sent > 0) {
1050                 struct vport_percpu_stats *stats;
1051
1052                 local_bh_disable();
1053                 stats = per_cpu_ptr(vport->percpu_stats, smp_processor_id());
1054
1055                 write_seqcount_begin(&stats->seqlock);
1056                 stats->tx_packets++;
1057                 stats->tx_bytes += sent;
1058                 write_seqcount_end(&stats->seqlock);
1059
1060                 local_bh_enable();
1061         }
1062
1063         return sent;
1064
1065 error:
1066         kfree_skb(skb);
1067         vport_record_error(vport, VPORT_E_TX_DROPPED);
1068         return 0;
1069 }
1070
1071 /**
1072  *      vport_record_error - indicate device error to generic stats layer
1073  *
1074  * @vport: vport that encountered the error
1075  * @err_type: one of enum vport_err_type types to indicate the error type
1076  *
1077  * If using the vport generic stats layer indicate that an error of the given
1078  * type has occured.
1079  */
1080 void vport_record_error(struct vport *vport, enum vport_err_type err_type)
1081 {
1082         if (vport->ops->flags & VPORT_F_GEN_STATS) {
1083
1084                 spin_lock_bh(&vport->stats_lock);
1085
1086                 switch (err_type) {
1087                 case VPORT_E_RX_DROPPED:
1088                         vport->err_stats.rx_dropped++;
1089                         break;
1090
1091                 case VPORT_E_RX_ERROR:
1092                         vport->err_stats.rx_errors++;
1093                         break;
1094
1095                 case VPORT_E_TX_DROPPED:
1096                         vport->err_stats.tx_dropped++;
1097                         break;
1098
1099                 case VPORT_E_TX_ERROR:
1100                         vport->err_stats.tx_errors++;
1101                         break;
1102                 };
1103
1104                 spin_unlock_bh(&vport->stats_lock);
1105         }
1106 }