pfctl: Fix 'set skip' handling for groups
When we skip on a group the kernel will automatically skip on the member interfaces. We still need to update our own cache though, or we risk overruling the kernel afterwards. This manifested as 'set skip' working initially, then not working when the rules were reloaded. PR: 229241 MFC after: 1 week
This commit is contained in:
parent
2da4e52d79
commit
b1f3ab0051
@ -1977,6 +1977,7 @@ int
|
||||
pfctl_set_interface_flags(struct pfctl *pf, char *ifname, int flags, int how)
|
||||
{
|
||||
struct pfioc_iface pi;
|
||||
struct node_host *h = NULL, *n = NULL;
|
||||
|
||||
if ((loadopt & PFCTL_FLAG_OPTION) == 0)
|
||||
return (0);
|
||||
@ -1985,6 +1986,12 @@ pfctl_set_interface_flags(struct pfctl *pf, char *ifname, int flags, int how)
|
||||
|
||||
pi.pfiio_flags = flags;
|
||||
|
||||
/* Make sure our cache matches the kernel. If we set or clear the flag
|
||||
* for a group this applies to all members. */
|
||||
h = ifa_grouplookup(ifname, 0);
|
||||
for (n = h; n != NULL; n = n->next)
|
||||
pfctl_set_interface_flags(pf, n->ifname, flags, how);
|
||||
|
||||
if (strlcpy(pi.pfiio_name, ifname, sizeof(pi.pfiio_name)) >=
|
||||
sizeof(pi.pfiio_name))
|
||||
errx(1, "pfctl_set_interface_flags: strlcpy");
|
||||
|
Loading…
Reference in New Issue
Block a user