Make ARP protection commands compatible with "ebtables-nft"
"nftables" compatible binary, "ebtables-nft", is not 100% compatible
with the legacy API, as reported in LP#1922892.
This patch fixes the following issues when using "ebtables-nft" (while
keeping compatibility with legacy binary):
- When a new chain is created, a default DROP rule is added at the end
of the chain (append). This will prevent the error code 4 when the
chain is listed.
- The chain rules are added at the begining of the chain (insert),
before the default DROP rule. This will prioritize the port rules.
- The MAC rules are cleaned before the new ones are added. That will
prevent the deletion of any new needed rule, now added after the
deletion.
- The "ebtables" command will retry on error code 4. This is the
error returned when the chains are listed and no rule is present
in a new created chain (reporeted in LP#1922892).
This code is backwards compatible, that means it works with the legacy
"ebtables" binary; this is currently installed in the Neutron CI [1].
In order to test with the new binary, "ebtables-nft", two new CI jobs
are added to the periodic queue [2].
Reviewed: https:/ /review. opendev. org/c/openstack /neutron/ +/804058 /opendev. org/openstack/ neutron/ commit/ 4245963c71280be bd94e9005230d61 0931a7c2df
Committed: https:/
Submitter: "Zuul (22348)"
Branch: stable/train
commit 4245963c71280be bd94e9005230d61 0931a7c2df
Author: Rodolfo Alonso Hernandez <email address hidden>
Date: Wed Apr 7 13:16:21 2021 +0000
Make ARP protection commands compatible with "ebtables-nft"
"nftables" compatible binary, "ebtables-nft", is not 100% compatible
with the legacy API, as reported in LP#1922892.
This patch fixes the following issues when using "ebtables-nft" (while
keeping compatibility with legacy binary):
- When a new chain is created, a default DROP rule is added at the end
of the chain (append). This will prevent the error code 4 when the
chain is listed.
- The chain rules are added at the begining of the chain (insert),
before the default DROP rule. This will prioritize the port rules.
- The MAC rules are cleaned before the new ones are added. That will
prevent the deletion of any new needed rule, now added after the
deletion.
- The "ebtables" command will retry on error code 4. This is the
error returned when the chains are listed and no rule is present
in a new created chain (reporeted in LP#1922892).
This code is backwards compatible, that means it works with the legacy
"ebtables" binary; this is currently installed in the Neutron CI [1].
In order to test with the new binary, "ebtables-nft", two new CI jobs
are added to the periodic queue [2].
[1]https:/ /github. com/openstack/ neutron/ blob/1ad9ca56b0 7ffdc9f7e0bc6a6 2af61961b9128eb /roles/ legacy_ ebtables/ tasks/main. yaml /review. opendev. org/c/openstack /neutron/ +/785144
[2]https:/
Closes-Bug: #1922892
Related-Bug: #1508155
Closes-Bug: #1938670
Conflicts:
neutron/ tests/unit/ plugins/ ml2/drivers/ linuxbridge/ agent/test_ arp_protect. py
Change-Id: I9463b000f6f63e 65aaf91d60b30f6 c92c01e3baf e654b4bfda24ae4 119c609bbf) 0562184a734e734 5e7c0e9639)
(cherry picked from commit 0a931391d8990f3
(cherry picked from commit fafa5dacd505712