|
@@ -128,6 +128,7 @@ ebt_basic_match(const struct ebt_entry *e, const struct sk_buff *skb,
|
|
const struct net_device *in, const struct net_device *out)
|
|
const struct net_device *in, const struct net_device *out)
|
|
{
|
|
{
|
|
const struct ethhdr *h = eth_hdr(skb);
|
|
const struct ethhdr *h = eth_hdr(skb);
|
|
|
|
+ const struct net_bridge_port *p;
|
|
__be16 ethproto;
|
|
__be16 ethproto;
|
|
int verdict, i;
|
|
int verdict, i;
|
|
|
|
|
|
@@ -148,13 +149,11 @@ ebt_basic_match(const struct ebt_entry *e, const struct sk_buff *skb,
|
|
if (FWINV2(ebt_dev_check(e->out, out), EBT_IOUT))
|
|
if (FWINV2(ebt_dev_check(e->out, out), EBT_IOUT))
|
|
return 1;
|
|
return 1;
|
|
/* rcu_read_lock()ed by nf_hook_slow */
|
|
/* rcu_read_lock()ed by nf_hook_slow */
|
|
- if (in && br_port_exists(in) &&
|
|
|
|
- FWINV2(ebt_dev_check(e->logical_in, br_port_get_rcu(in)->br->dev),
|
|
|
|
- EBT_ILOGICALIN))
|
|
|
|
|
|
+ if (in && (p = br_port_get_rcu(in)) != NULL &&
|
|
|
|
+ FWINV2(ebt_dev_check(e->logical_in, p->br->dev), EBT_ILOGICALIN))
|
|
return 1;
|
|
return 1;
|
|
- if (out && br_port_exists(out) &&
|
|
|
|
- FWINV2(ebt_dev_check(e->logical_out, br_port_get_rcu(out)->br->dev),
|
|
|
|
- EBT_ILOGICALOUT))
|
|
|
|
|
|
+ if (out && (p = br_port_get_rcu(out)) != NULL &&
|
|
|
|
+ FWINV2(ebt_dev_check(e->logical_out, p->br->dev), EBT_ILOGICALOUT))
|
|
return 1;
|
|
return 1;
|
|
|
|
|
|
if (e->bitmask & EBT_SOURCEMAC) {
|
|
if (e->bitmask & EBT_SOURCEMAC) {
|