Blame view

drivers/net/team/team_mode_roundrobin.c 1.89 KB
3d249d4ca   Jiri Pirko   net: introduce et...
1
  /*
0d572e45f   Jiri Pirko   team: comments: s...
2
   * drivers/net/team/team_mode_roundrobin.c - Round-robin mode for team
3d249d4ca   Jiri Pirko   net: introduce et...
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
   * Copyright (c) 2011 Jiri Pirko <jpirko@redhat.com>
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License as published by
   * the Free Software Foundation; either version 2 of the License, or
   * (at your option) any later version.
   */
  
  #include <linux/kernel.h>
  #include <linux/types.h>
  #include <linux/module.h>
  #include <linux/init.h>
  #include <linux/errno.h>
  #include <linux/netdevice.h>
  #include <linux/if_team.h>
  
  struct rr_priv {
  	unsigned int sent_packets;
  };
  
  static struct rr_priv *rr_priv(struct team *team)
  {
  	return (struct rr_priv *) &team->mode_priv;
  }
3d249d4ca   Jiri Pirko   net: introduce et...
27
28
29
30
  static bool rr_transmit(struct team *team, struct sk_buff *skb)
  {
  	struct team_port *port;
  	int port_index;
735d381fa   Jiri Pirko   team: remove sync...
31
32
  	port_index = team_num_to_port_index(team,
  					    rr_priv(team)->sent_packets++);
3d249d4ca   Jiri Pirko   net: introduce et...
33
  	port = team_get_port_by_index_rcu(team, port_index);
76c455dec   Jiri Pirko   team: check retur...
34
35
  	if (unlikely(!port))
  		goto drop;
753f99391   Jiri Pirko   team: introduce r...
36
  	port = team_get_first_port_txable_rcu(team, port);
3d249d4ca   Jiri Pirko   net: introduce et...
37
38
  	if (unlikely(!port))
  		goto drop;
bd2d0837a   Jiri Pirko   team: add netpoll...
39
  	if (team_dev_queue_xmit(team, port, skb))
3d249d4ca   Jiri Pirko   net: introduce et...
40
41
42
43
44
45
46
  		return false;
  	return true;
  
  drop:
  	dev_kfree_skb_any(skb);
  	return false;
  }
3d249d4ca   Jiri Pirko   net: introduce et...
47
48
  static const struct team_mode_ops rr_mode_ops = {
  	.transmit		= rr_transmit,
acbba0d0f   Jiri Pirko   team: introduce t...
49
50
  	.port_enter		= team_modeop_port_enter,
  	.port_change_dev_addr	= team_modeop_port_change_dev_addr,
3d249d4ca   Jiri Pirko   net: introduce et...
51
  };
0402788a6   Jiri Pirko   team: make team_m...
52
  static const struct team_mode rr_mode = {
3d249d4ca   Jiri Pirko   net: introduce et...
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  	.kind		= "roundrobin",
  	.owner		= THIS_MODULE,
  	.priv_size	= sizeof(struct rr_priv),
  	.ops		= &rr_mode_ops,
  };
  
  static int __init rr_init_module(void)
  {
  	return team_mode_register(&rr_mode);
  }
  
  static void __exit rr_cleanup_module(void)
  {
  	team_mode_unregister(&rr_mode);
  }
  
  module_init(rr_init_module);
  module_exit(rr_cleanup_module);
  
  MODULE_LICENSE("GPL v2");
  MODULE_AUTHOR("Jiri Pirko <jpirko@redhat.com>");
  MODULE_DESCRIPTION("Round-robin mode for team");
  MODULE_ALIAS("team-mode-roundrobin");