bridge: use rx_handler_data pointer to store net_bridge_port pointer
Register net_bridge_port pointer as rx_handler data pointer. As br_port is removed from struct net_device, another netdev priv_flag is added to indicate the device serves as a bridge port. Also rcuized pointers are now correctly dereferenced in br_fdb.c and in netfilter parts. Signed-off-by: Jiri Pirko <jpirko@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
a35e2c1b6d
commit
f350a0a873
@@ -403,8 +403,9 @@ __build_packet_message(struct nfulnl_instance *inst,
|
||||
NLA_PUT_BE32(inst->skb, NFULA_IFINDEX_PHYSINDEV,
|
||||
htonl(indev->ifindex));
|
||||
/* this is the bridge group "brX" */
|
||||
/* rcu_read_lock()ed by nf_hook_slow or nf_log_packet */
|
||||
NLA_PUT_BE32(inst->skb, NFULA_IFINDEX_INDEV,
|
||||
htonl(indev->br_port->br->dev->ifindex));
|
||||
htonl(br_port_get_rcu(indev)->br->dev->ifindex));
|
||||
} else {
|
||||
/* Case 2: indev is bridge group, we need to look for
|
||||
* physical device (when called from ipv4) */
|
||||
@@ -430,8 +431,9 @@ __build_packet_message(struct nfulnl_instance *inst,
|
||||
NLA_PUT_BE32(inst->skb, NFULA_IFINDEX_PHYSOUTDEV,
|
||||
htonl(outdev->ifindex));
|
||||
/* this is the bridge group "brX" */
|
||||
/* rcu_read_lock()ed by nf_hook_slow or nf_log_packet */
|
||||
NLA_PUT_BE32(inst->skb, NFULA_IFINDEX_OUTDEV,
|
||||
htonl(outdev->br_port->br->dev->ifindex));
|
||||
htonl(br_port_get_rcu(outdev)->br->dev->ifindex));
|
||||
} else {
|
||||
/* Case 2: indev is a bridge group, we need to look
|
||||
* for physical device (when called from ipv4) */
|
||||
|
@@ -296,8 +296,9 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
|
||||
NLA_PUT_BE32(skb, NFQA_IFINDEX_PHYSINDEV,
|
||||
htonl(indev->ifindex));
|
||||
/* this is the bridge group "brX" */
|
||||
/* rcu_read_lock()ed by __nf_queue */
|
||||
NLA_PUT_BE32(skb, NFQA_IFINDEX_INDEV,
|
||||
htonl(indev->br_port->br->dev->ifindex));
|
||||
htonl(br_port_get_rcu(indev)->br->dev->ifindex));
|
||||
} else {
|
||||
/* Case 2: indev is bridge group, we need to look for
|
||||
* physical device (when called from ipv4) */
|
||||
@@ -321,8 +322,9 @@ nfqnl_build_packet_message(struct nfqnl_instance *queue,
|
||||
NLA_PUT_BE32(skb, NFQA_IFINDEX_PHYSOUTDEV,
|
||||
htonl(outdev->ifindex));
|
||||
/* this is the bridge group "brX" */
|
||||
/* rcu_read_lock()ed by __nf_queue */
|
||||
NLA_PUT_BE32(skb, NFQA_IFINDEX_OUTDEV,
|
||||
htonl(outdev->br_port->br->dev->ifindex));
|
||||
htonl(br_port_get_rcu(outdev)->br->dev->ifindex));
|
||||
} else {
|
||||
/* Case 2: outdev is bridge group, we need to look for
|
||||
* physical output device (when called from ipv4) */
|
||||
|
Reference in New Issue
Block a user