diff options
| author | Viacheslav Hletenko <v.gletenko@vyos.io> | 2023-07-01 17:30:55 +0000 | 
|---|---|---|
| committer | Viacheslav Hletenko <v.gletenko@vyos.io> | 2023-07-01 17:30:55 +0000 | 
| commit | 4917d7ab4601904bb19e9e2c8ea3e4bf7bc7521d (patch) | |
| tree | 79d7c981fe3b2a46e80298d6b84e85377f52c070 /python | |
| parent | e3361366038fb0acb8c00d54ac30fb9b95debf52 (diff) | |
| download | vyos-1x-4917d7ab4601904bb19e9e2c8ea3e4bf7bc7521d.tar.gz vyos-1x-4917d7ab4601904bb19e9e2c8ea3e4bf7bc7521d.zip | |
T5302: QoS fix class with multiple matches generate one rule
Fix QoS tc class with multiple matches generates one rule but
expects multiple filter rules:
set qos policy shaper test class 23 match one ip protocol 'tcp'
set qos policy shaper test class 23 match two ip protocol 'udp'
tc filter add dev eth0 parent 1: protocol all prio 1 u32 match ip protocol 6 0xff flowid 1:17
tc filter add dev eth0 parent 1: protocol all prio 2 u32 match ip protocol 17 0xff flowid 1:17
Diffstat (limited to 'python')
| -rw-r--r-- | python/vyos/qos/base.py | 25 | 
1 files changed, 16 insertions, 9 deletions
| diff --git a/python/vyos/qos/base.py b/python/vyos/qos/base.py index 226773c4f..b992fe904 100644 --- a/python/vyos/qos/base.py +++ b/python/vyos/qos/base.py @@ -204,18 +204,20 @@ class QoSBase:                  self._build_base_qdisc(cls_config, int(cls))                  # every match criteria has it's tc instance -                filter_cmd = f'tc filter replace dev {self._interface} parent {self._parent:x}:' +                filter_cmd_base = f'tc filter add dev {self._interface} parent {self._parent:x}:'                  if priority: -                    filter_cmd += f' prio {cls}' +                    filter_cmd_base += f' prio {cls}'                  elif 'priority' in cls_config:                      prio = cls_config['priority'] -                    filter_cmd += f' prio {prio}' +                    filter_cmd_base += f' prio {prio}' -                filter_cmd += ' protocol all' +                filter_cmd_base += ' protocol all'                  if 'match' in cls_config: -                    for match, match_config in cls_config['match'].items(): +                    for index, (match, match_config) in enumerate(cls_config['match'].items(), start=1): +                        filter_cmd = filter_cmd_base +                        filter_cmd += f' prio {index}'                          if 'mark' in match_config:                              mark = match_config['mark']                              filter_cmd += f' handle {mark} fw' @@ -290,10 +292,19 @@ class QoSBase:                                      elif af == 'ipv6':                                          filter_cmd += f' match u8 {mask} {mask} at 53' +                                cls = int(cls) +                                filter_cmd += f' flowid {self._parent:x}:{cls:x}' +                                self._cmd(filter_cmd) +                  else:                      filter_cmd += ' basic' +                    cls = int(cls) +                    filter_cmd += f' flowid {self._parent:x}:{cls:x}' +                    self._cmd(filter_cmd) + +                  # The police block allows limiting of the byte or packet rate of                  # traffic matched by the filter it is attached to.                  # https://man7.org/linux/man-pages/man8/tc-police.8.html @@ -319,10 +330,6 @@ class QoSBase:                  #     burst = cls_config['burst']                  #     filter_cmd += f' burst {burst}' -                cls = int(cls) -                filter_cmd += f' flowid {self._parent:x}:{cls:x}' -                self._cmd(filter_cmd) -          if self.qostype == 'limiter':              if 'default' in config:                  if 'class' in config: | 
