Dave, please apply this patch if you haven't already, it seems correct to me. - When addding several egress-mappings we get stuck in an eternal loop if they end up in the same hash-bucket, see vlan_d
This patch looks good too, though the (vlan_id < 0) test is redundant since vlan_id is an unsigned number. For clarity of code, I wouldn't mind if it stayed in though. - If we try to remove a vlan wi