team_mode_broadcast.c 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * drivers/net/team/team_mode_broadcast.c - Broadcast mode for team
  3. * Copyright (c) 2012 Jiri Pirko <jpirko@redhat.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. */
  10. #include <linux/kernel.h>
  11. #include <linux/types.h>
  12. #include <linux/module.h>
  13. #include <linux/init.h>
  14. #include <linux/errno.h>
  15. #include <linux/netdevice.h>
  16. #include <linux/if_team.h>
  17. static bool bc_transmit(struct team *team, struct sk_buff *skb)
  18. {
  19. struct team_port *cur;
  20. struct team_port *last = NULL;
  21. struct sk_buff *skb2;
  22. bool ret;
  23. bool sum_ret = false;
  24. list_for_each_entry_rcu(cur, &team->port_list, list) {
  25. if (team_port_txable(cur)) {
  26. if (last) {
  27. skb2 = skb_clone(skb, GFP_ATOMIC);
  28. if (skb2) {
  29. ret = !team_dev_queue_xmit(team, last,
  30. skb2);
  31. if (!sum_ret)
  32. sum_ret = ret;
  33. }
  34. }
  35. last = cur;
  36. }
  37. }
  38. if (last) {
  39. ret = !team_dev_queue_xmit(team, last, skb);
  40. if (!sum_ret)
  41. sum_ret = ret;
  42. }
  43. return sum_ret;
  44. }
  45. static const struct team_mode_ops bc_mode_ops = {
  46. .transmit = bc_transmit,
  47. .port_enter = team_modeop_port_enter,
  48. .port_change_dev_addr = team_modeop_port_change_dev_addr,
  49. };
  50. static const struct team_mode bc_mode = {
  51. .kind = "broadcast",
  52. .owner = THIS_MODULE,
  53. .ops = &bc_mode_ops,
  54. .lag_tx_type = NETDEV_LAG_TX_TYPE_BROADCAST,
  55. };
  56. static int __init bc_init_module(void)
  57. {
  58. return team_mode_register(&bc_mode);
  59. }
  60. static void __exit bc_cleanup_module(void)
  61. {
  62. team_mode_unregister(&bc_mode);
  63. }
  64. module_init(bc_init_module);
  65. module_exit(bc_cleanup_module);
  66. MODULE_LICENSE("GPL v2");
  67. MODULE_AUTHOR("Jiri Pirko <jpirko@redhat.com>");
  68. MODULE_DESCRIPTION("Broadcast mode for team");
  69. MODULE_ALIAS_TEAM_MODE("broadcast");