bond_options.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  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_LAST
  62. };
  63. /* This structure is used for storing option values and for passing option
  64. * values when changing an option. The logic when used as an arg is as follows:
  65. * - if string != NULL -> parse it, if the opt is RAW type then return it, else
  66. * return the parse result
  67. * - if string == NULL -> parse value
  68. */
  69. struct bond_opt_value {
  70. char *string;
  71. u64 value;
  72. u32 flags;
  73. };
  74. struct bonding;
  75. struct bond_option {
  76. int id;
  77. const char *name;
  78. const char *desc;
  79. u32 flags;
  80. /* unsuppmodes is used to denote modes in which the option isn't
  81. * supported.
  82. */
  83. unsigned long unsuppmodes;
  84. /* supported values which this option can have, can be a subset of
  85. * BOND_OPTVAL_RANGE's value range
  86. */
  87. const struct bond_opt_value *values;
  88. int (*set)(struct bonding *bond, const struct bond_opt_value *val);
  89. };
  90. int __bond_opt_set(struct bonding *bond, unsigned int option,
  91. struct bond_opt_value *val);
  92. int bond_opt_tryset_rtnl(struct bonding *bond, unsigned int option, char *buf);
  93. const struct bond_opt_value *bond_opt_parse(const struct bond_option *opt,
  94. struct bond_opt_value *val);
  95. const struct bond_option *bond_opt_get(unsigned int option);
  96. const struct bond_option *bond_opt_get_by_name(const char *name);
  97. const struct bond_opt_value *bond_opt_get_val(unsigned int option, u64 val);
  98. /* This helper is used to initialize a bond_opt_value structure for parameter
  99. * passing. There should be either a valid string or value, but not both.
  100. * When value is ULLONG_MAX then string will be used.
  101. */
  102. static inline void __bond_opt_init(struct bond_opt_value *optval,
  103. char *string, u64 value)
  104. {
  105. memset(optval, 0, sizeof(*optval));
  106. optval->value = ULLONG_MAX;
  107. if (value == ULLONG_MAX)
  108. optval->string = string;
  109. else
  110. optval->value = value;
  111. }
  112. #define bond_opt_initval(optval, value) __bond_opt_init(optval, NULL, value)
  113. #define bond_opt_initstr(optval, str) __bond_opt_init(optval, str, ULLONG_MAX)
  114. void bond_option_arp_ip_targets_clear(struct bonding *bond);
  115. #endif /* _NET_BOND_OPTIONS_H */