datapath: Fix double counting of packet stats for Linux devices.
[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_errors           += dev_statsp->rx_errors;
837                         stats->tx_errors           += dev_statsp->tx_errors;
838                         stats->rx_dropped          += dev_statsp->rx_dropped;
839                         stats->tx_dropped          += dev_statsp->tx_dropped;
840                         stats->multicast           += dev_statsp->multicast;
841                         stats->collisions          += dev_statsp->collisions;
842                         stats->rx_length_errors    += dev_statsp->rx_length_errors;
843                         stats->rx_over_errors      += dev_statsp->rx_over_errors;
844                         stats->rx_crc_errors       += dev_statsp->rx_crc_errors;
845                         stats->rx_frame_errors     += dev_statsp->rx_frame_errors;
846                         stats->rx_fifo_errors      += dev_statsp->rx_fifo_errors;
847                         stats->rx_missed_errors    += dev_statsp->rx_missed_errors;
848                         stats->tx_aborted_errors   += dev_statsp->tx_aborted_errors;
849                         stats->tx_carrier_errors   += dev_statsp->tx_carrier_errors;
850                         stats->tx_fifo_errors      += dev_statsp->tx_fifo_errors;
851                         stats->tx_heartbeat_errors += dev_statsp->tx_heartbeat_errors;
852                         stats->tx_window_errors    += dev_statsp->tx_window_errors;
853                         stats->rx_compressed       += dev_statsp->rx_compressed;
854                         stats->tx_compressed       += dev_statsp->tx_compressed;
855                 }
856
857                 for_each_possible_cpu(i) {
858                         const struct vport_percpu_stats *percpu_stats;
859                         struct vport_percpu_stats local_stats;
860                         unsigned seqcount;
861
862                         percpu_stats = per_cpu_ptr(vport->percpu_stats, i);
863
864                         do {
865                                 seqcount = read_seqcount_begin(&percpu_stats->seqlock);
866                                 local_stats = *percpu_stats;
867                         } while (read_seqcount_retry(&percpu_stats->seqlock, seqcount));
868
869                         stats->rx_bytes         += local_stats.rx_bytes;
870                         stats->rx_packets       += local_stats.rx_packets;
871                         stats->tx_bytes         += local_stats.tx_bytes;
872                         stats->tx_packets       += local_stats.tx_packets;
873                 }
874
875                 err = 0;
876         } else
877                 err = -EOPNOTSUPP;
878
879 out:
880         return err;
881 }
882
883 /**
884  *      vport_get_flags - retrieve device flags
885  *
886  * @vport: vport from which to retrieve the flags
887  *
888  * Retrieves the flags of the given device.  Either RTNL lock or rcu_read_lock
889  * must be held.
890  */
891 unsigned vport_get_flags(const struct vport *vport)
892 {
893         return vport->ops->get_dev_flags(vport);
894 }
895
896 /**
897  *      vport_get_flags - check whether device is running
898  *
899  * @vport: vport on which to check status.
900  *
901  * Checks whether the given device is running.  Either RTNL lock or
902  * rcu_read_lock must be held.
903  */
904 int vport_is_running(const struct vport *vport)
905 {
906         return vport->ops->is_running(vport);
907 }
908
909 /**
910  *      vport_get_flags - retrieve device operating state
911  *
912  * @vport: vport from which to check status
913  *
914  * Retrieves the RFC2863 operstate of the given device.  Either RTNL lock or
915  * rcu_read_lock must be held.
916  */
917 unsigned char vport_get_operstate(const struct vport *vport)
918 {
919         return vport->ops->get_operstate(vport);
920 }
921
922 /**
923  *      vport_get_ifindex - retrieve device system interface index
924  *
925  * @vport: vport from which to retrieve index
926  *
927  * Retrieves the system interface index of the given device or 0 if
928  * the device does not have one (in the case of virtual ports).
929  * Returns a negative index on error. Either RTNL lock or
930  * rcu_read_lock must be held.
931  */
932 int vport_get_ifindex(const struct vport *vport)
933 {
934         if (vport->ops->get_ifindex)
935                 return vport->ops->get_ifindex(vport);
936         else
937                 return 0;
938 }
939
940 /**
941  *      vport_get_iflink - retrieve device system link index
942  *
943  * @vport: vport from which to retrieve index
944  *
945  * Retrieves the system link index of the given device.  The link is the index
946  * of the interface on which the packet will actually be sent.  In most cases
947  * this is the same as the ifindex but may be different for tunnel devices.
948  * Returns a negative index on error.  Either RTNL lock or rcu_read_lock must
949  * be held.
950  */
951 int vport_get_iflink(const struct vport *vport)
952 {
953         if (vport->ops->get_iflink)
954                 return vport->ops->get_iflink(vport);
955
956         /* If we don't have an iflink, use the ifindex.  In most cases they
957          * are the same. */
958         return vport_get_ifindex(vport);
959 }
960
961 /**
962  *      vport_get_mtu - retrieve device MTU (for kernel callers)
963  *
964  * @vport: vport from which to retrieve MTU
965  *
966  * Retrieves the MTU of the given device.  Either RTNL lock or rcu_read_lock
967  * must be held.
968  */
969 int vport_get_mtu(const struct vport *vport)
970 {
971         return vport->ops->get_mtu(vport);
972 }
973
974 /**
975  *      vport_get_config - retrieve device configuration
976  *
977  * @vport: vport from which to retrieve the configuration.
978  * @config: buffer to store config, which must be at least the length
979  *          of VPORT_CONFIG_SIZE.
980  *
981  * Retrieves the configuration of the given device.  Either RTNL lock or
982  * rcu_read_lock must be held.
983  */
984 void vport_get_config(const struct vport *vport, void *config)
985 {
986         if (vport->ops->get_config)
987                 vport->ops->get_config(vport, config);
988 }
989
990 /**
991  *      vport_receive - pass up received packet to the datapath for processing
992  *
993  * @vport: vport that received the packet
994  * @skb: skb that was received
995  *
996  * Must be called with rcu_read_lock.  The packet cannot be shared and
997  * skb->data should point to the Ethernet header.  The caller must have already
998  * called compute_ip_summed() to initialize the checksumming fields.
999  */
1000 void vport_receive(struct vport *vport, struct sk_buff *skb)
1001 {
1002         if (vport->ops->flags & VPORT_F_GEN_STATS) {
1003                 struct vport_percpu_stats *stats;
1004
1005                 local_bh_disable();
1006                 stats = per_cpu_ptr(vport->percpu_stats, smp_processor_id());
1007
1008                 write_seqcount_begin(&stats->seqlock);
1009                 stats->rx_packets++;
1010                 stats->rx_bytes += skb->len;
1011                 write_seqcount_end(&stats->seqlock);
1012
1013                 local_bh_enable();
1014         }
1015
1016         if (!(vport->ops->flags & VPORT_F_FLOW))
1017                 OVS_CB(skb)->flow = NULL;
1018
1019         if (!(vport->ops->flags & VPORT_F_TUN_ID))
1020                 OVS_CB(skb)->tun_id = 0;
1021
1022         dp_process_received_packet(vport, skb);
1023 }
1024
1025 static inline unsigned packet_length(const struct sk_buff *skb)
1026 {
1027         unsigned length = skb->len - ETH_HLEN;
1028
1029         if (skb->protocol == htons(ETH_P_8021Q))
1030                 length -= VLAN_HLEN;
1031
1032         return length;
1033 }
1034
1035 /**
1036  *      vport_send - send a packet on a device
1037  *
1038  * @vport: vport on which to send the packet
1039  * @skb: skb to send
1040  *
1041  * Sends the given packet and returns the length of data sent.  Either RTNL
1042  * lock or rcu_read_lock must be held.
1043  */
1044 int vport_send(struct vport *vport, struct sk_buff *skb)
1045 {
1046         int mtu;
1047         int sent;
1048
1049         mtu = vport_get_mtu(vport);
1050         if (unlikely(packet_length(skb) > mtu && !skb_is_gso(skb))) {
1051                 if (net_ratelimit())
1052                         pr_warn("%s: dropped over-mtu packet: %d > %d\n",
1053                                 dp_name(vport->dp), packet_length(skb), mtu);
1054                 goto error;
1055         }
1056
1057         sent = vport->ops->send(vport, skb);
1058
1059         if (vport->ops->flags & VPORT_F_GEN_STATS && sent > 0) {
1060                 struct vport_percpu_stats *stats;
1061
1062                 local_bh_disable();
1063                 stats = per_cpu_ptr(vport->percpu_stats, smp_processor_id());
1064
1065                 write_seqcount_begin(&stats->seqlock);
1066                 stats->tx_packets++;
1067                 stats->tx_bytes += sent;
1068                 write_seqcount_end(&stats->seqlock);
1069
1070                 local_bh_enable();
1071         }
1072
1073         return sent;
1074
1075 error:
1076         kfree_skb(skb);
1077         vport_record_error(vport, VPORT_E_TX_DROPPED);
1078         return 0;
1079 }
1080
1081 /**
1082  *      vport_record_error - indicate device error to generic stats layer
1083  *
1084  * @vport: vport that encountered the error
1085  * @err_type: one of enum vport_err_type types to indicate the error type
1086  *
1087  * If using the vport generic stats layer indicate that an error of the given
1088  * type has occured.
1089  */
1090 void vport_record_error(struct vport *vport, enum vport_err_type err_type)
1091 {
1092         if (vport->ops->flags & VPORT_F_GEN_STATS) {
1093
1094                 spin_lock_bh(&vport->stats_lock);
1095
1096                 switch (err_type) {
1097                 case VPORT_E_RX_DROPPED:
1098                         vport->err_stats.rx_dropped++;
1099                         break;
1100
1101                 case VPORT_E_RX_ERROR:
1102                         vport->err_stats.rx_errors++;
1103                         break;
1104
1105                 case VPORT_E_TX_DROPPED:
1106                         vport->err_stats.tx_dropped++;
1107                         break;
1108
1109                 case VPORT_E_TX_ERROR:
1110                         vport->err_stats.tx_errors++;
1111                         break;
1112                 };
1113
1114                 spin_unlock_bh(&vport->stats_lock);
1115         }
1116 }