htb.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #
  2. # Copyright (c) 2011 Thomas Graf <tgraf@suug.ch>
  3. #
  4. """HTB qdisc
  5. """
  6. from __future__ import absolute_import
  7. from ... import core as netlink
  8. from ... import util as util
  9. from .. import capi as capi
  10. from .. import tc as tc
  11. class HTBQdisc(object):
  12. def __init__(self, qdisc):
  13. self._qdisc = qdisc
  14. @property
  15. @netlink.nlattr(type=int)
  16. def default_class(self):
  17. return tc.Handle(capi.rtnl_htb_get_defcls(self._qdisc._rtnl_qdisc))
  18. @default_class.setter
  19. def default_class(self, value):
  20. capi.rtnl_htb_set_defcls(self._qdisc._rtnl_qdisc, int(value))
  21. @property
  22. @netlink.nlattr('r2q', type=int)
  23. def r2q(self):
  24. return capi.rtnl_htb_get_rate2quantum(self._qdisc._rtnl_qdisc)
  25. @r2q.setter
  26. def r2q(self, value):
  27. capi.rtnl_htb_get_rate2quantum(self._qdisc._rtnl_qdisc,
  28. int(value))
  29. def brief(self):
  30. fmt = util.MyFormatter(self)
  31. ret = ' {s|default-class!k} {a|default_class}'
  32. if self.r2q:
  33. ret += ' {s|r2q!k} {a|r2q}'
  34. return fmt.format(ret)
  35. class HTBClass(object):
  36. def __init__(self, cl):
  37. self._class = cl
  38. @property
  39. @netlink.nlattr(type=str)
  40. def rate(self):
  41. rate = capi.rtnl_htb_get_rate(self._class._rtnl_class)
  42. return util.Rate(rate)
  43. @rate.setter
  44. def rate(self, value):
  45. capi.rtnl_htb_set_rate(self._class._rtnl_class, int(value))
  46. @property
  47. @netlink.nlattr(type=str)
  48. def ceil(self):
  49. ceil = capi.rtnl_htb_get_ceil(self._class._rtnl_class)
  50. return util.Rate(ceil)
  51. @ceil.setter
  52. def ceil(self, value):
  53. capi.rtnl_htb_set_ceil(self._class._rtnl_class, int(value))
  54. @property
  55. @netlink.nlattr(type=str)
  56. def burst(self):
  57. burst = capi.rtnl_htb_get_rbuffer(self._class._rtnl_class)
  58. return util.Size(burst)
  59. @burst.setter
  60. def burst(self, value):
  61. capi.rtnl_htb_set_rbuffer(self._class._rtnl_class, int(value))
  62. @property
  63. @netlink.nlattr(type=str)
  64. def ceil_burst(self):
  65. burst = capi.rtnl_htb_get_cbuffer(self._class._rtnl_class)
  66. return util.Size(burst)
  67. @ceil_burst.setter
  68. def ceil_burst(self, value):
  69. capi.rtnl_htb_set_cbuffer(self._class._rtnl_class, int(value))
  70. @property
  71. @netlink.nlattr(type=int)
  72. def prio(self):
  73. return capi.rtnl_htb_get_prio(self._class._rtnl_class)
  74. @prio.setter
  75. def prio(self, value):
  76. capi.rtnl_htb_set_prio(self._class._rtnl_class, int(value))
  77. @property
  78. @netlink.nlattr(type=int)
  79. def quantum(self):
  80. return capi.rtnl_htb_get_quantum(self._class._rtnl_class)
  81. @quantum.setter
  82. def quantum(self, value):
  83. capi.rtnl_htb_set_quantum(self._class._rtnl_class, int(value))
  84. @property
  85. @netlink.nlattr(type=int)
  86. def level(self):
  87. return capi.rtnl_htb_get_level(self._class._rtnl_class)
  88. @level.setter
  89. def level(self, value):
  90. capi.rtnl_htb_set_level(self._class._rtnl_class, int(value))
  91. def brief(self):
  92. fmt = util.MyFormatter(self)
  93. ret = ' {t|prio} {t|rate}'
  94. if self.rate != self.ceil:
  95. ret += ' {s|borrow-up-to!k} {a|ceil}'
  96. ret += ' {t|burst}'
  97. return fmt.format(ret)
  98. def details(self):
  99. fmt = util.MyFormatter(self)
  100. return fmt.nl('\t{t|level} {t|quantum}')
  101. def init_qdisc(qdisc):
  102. qdisc.htb = HTBQdisc(qdisc)
  103. return qdisc.htb
  104. def init_class(cl):
  105. cl.htb = HTBClass(cl)
  106. return cl.htb
  107. #extern void rtnl_htb_set_quantum(struct rtnl_class *, uint32_t quantum);