bond_options.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. /*
  2. * drivers/net/bond/bond_options.h - bonding options
  3. * Copyright (c) 2013 Nikolay Aleksandrov <nikolay@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. #ifndef _NET_BOND_OPTIONS_H
  11. #define _NET_BOND_OPTIONS_H
  12. #define BOND_OPT_MAX_NAMELEN 32
  13. #define BOND_OPT_VALID(opt) ((opt) < BOND_OPT_LAST)
  14. #define BOND_MODE_ALL_EX(x) (~(x))
  15. /* Option flags:
  16. * BOND_OPTFLAG_NOSLAVES - check if the bond device is empty before setting
  17. * BOND_OPTFLAG_IFDOWN - check if the bond device is down before setting
  18. * BOND_OPTFLAG_RAWVAL - the option parses the value itself
  19. */
  20. enum {
  21. BOND_OPTFLAG_NOSLAVES = BIT(0),
  22. BOND_OPTFLAG_IFDOWN = BIT(1),
  23. BOND_OPTFLAG_RAWVAL = BIT(2)
  24. };
  25. /* Value type flags:
  26. * BOND_VALFLAG_DEFAULT - mark the value as default
  27. * BOND_VALFLAG_(MIN|MAX) - mark the value as min/max
  28. */
  29. enum {
  30. BOND_VALFLAG_DEFAULT = BIT(0),
  31. BOND_VALFLAG_MIN = BIT(1),
  32. BOND_VALFLAG_MAX = BIT(2)
  33. };
  34. /* Option IDs, their bit positions correspond to their IDs */
  35. enum {
  36. BOND_OPT_MODE,
  37. BOND_OPT_PACKETS_PER_SLAVE,
  38. BOND_OPT_XMIT_HASH,
  39. BOND_OPT_ARP_VALIDATE,
  40. BOND_OPT_ARP_ALL_TARGETS,
  41. BOND_OPT_FAIL_OVER_MAC,
  42. BOND_OPT_ARP_INTERVAL,
  43. BOND_OPT_ARP_TARGETS,
  44. BOND_OPT_DOWNDELAY,
  45. BOND_OPT_UPDELAY,
  46. BOND_OPT_LACP_RATE,
  47. BOND_OPT_MINLINKS,
  48. BOND_OPT_AD_SELECT,
  49. BOND_OPT_NUM_PEER_NOTIF,
  50. BOND_OPT_MIIMON,
  51. BOND_OPT_PRIMARY,
  52. BOND_OPT_PRIMARY_RESELECT,
  53. BOND_OPT_USE_CARRIER,
  54. BOND_OPT_ACTIVE_SLAVE,
  55. BOND_OPT_QUEUE_ID,
  56. BOND_OPT_ALL_SLAVES_ACTIVE,
  57. BOND_OPT_RESEND_IGMP,
  58. BOND_OPT_LP_INTERVAL,
  59. BOND_OPT_SLAVES,
  60. BOND_OPT_TLB_DYNAMIC_LB,
  61. BOND_OPT_AD_ACTOR_SYS_PRIO,
  62. BOND_OPT_AD_ACTOR_SYSTEM,
  63. BOND_OPT_AD_USER_PORT_KEY,
  64. BOND_OPT_NUM_PEER_NOTIF_ALIAS,
  65. BOND_OPT_LAST
  66. };
  67. /* This structure is used for storing option values and for passing option
  68. * values when changing an option. The logic when used as an arg is as follows:
  69. * - if string != NULL -> parse it, if the opt is RAW type then return it, else
  70. * return the parse result
  71. * - if string == NULL -> parse value
  72. */
  73. struct bond_opt_value {
  74. char *string;
  75. u64 value;
  76. u32 flags;
  77. };
  78. struct bonding;
  79. struct bond_option {
  80. int id;
  81. const char *name;
  82. const char *desc;
  83. u32 flags;
  84. /* unsuppmodes is used to denote modes in which the option isn't
  85. * supported.
  86. */
  87. unsigned long unsuppmodes;
  88. /* supported values which this option can have, can be a subset of
  89. * BOND_OPTVAL_RANGE's value range
  90. */
  91. const struct bond_opt_value *values;
  92. int (*set)(struct bonding *bond, const struct bond_opt_value *val);
  93. };
  94. int __bond_opt_set(struct bonding *bond, unsigned int option,
  95. struct bond_opt_value *val);
  96. int __bond_opt_set_notify(struct bonding *bond, unsigned int option,
  97. struct bond_opt_value *val);
  98. int bond_opt_tryset_rtnl(struct bonding *bond, unsigned int option, char *buf);
  99. const struct bond_opt_value *bond_opt_parse(const struct bond_option *opt,
  100. struct bond_opt_value *val);
  101. const struct bond_option *bond_opt_get(unsigned int option);
  102. const struct bond_option *bond_opt_get_by_name(const char *name);
  103. const struct bond_opt_value *bond_opt_get_val(unsigned int option, u64 val);
  104. /* This helper is used to initialize a bond_opt_value structure for parameter
  105. * passing. There should be either a valid string or value, but not both.
  106. * When value is ULLONG_MAX then string will be used.
  107. */
  108. static inline void __bond_opt_init(struct bond_opt_value *optval,
  109. char *string, u64 value)
  110. {
  111. memset(optval, 0, sizeof(*optval));
  112. optval->value = ULLONG_MAX;
  113. if (value == ULLONG_MAX)
  114. optval->string = string;
  115. else
  116. optval->value = value;
  117. }
  118. #define bond_opt_initval(optval, value) __bond_opt_init(optval, NULL, value)
  119. #define bond_opt_initstr(optval, str) __bond_opt_init(optval, str, ULLONG_MAX)
  120. void bond_option_arp_ip_targets_clear(struct bonding *bond);
  121. #endif /* _NET_BOND_OPTIONS_H */