net: Add priority to packet_offload objects.
When we scan a packet for GRO processing, we want to see the most common packet types in the front of the offload_base list. So add a priority field so we can handle this properly. IPv4/IPv6 get the highest priority with the implicit zero priority field. Next comes ethernet with a priority of 10, and then we have the MPLS types with a priority of 15. Suggested-by: Eric Dumazet <eric.dumazet@gmail.com> Suggested-by: Toshiaki Makita <makita.toshiaki@lab.ntt.co.jp> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
493be55ac3
commit
bdef7de4b8
@ -1997,6 +1997,7 @@ struct offload_callbacks {
|
|||||||
|
|
||||||
struct packet_offload {
|
struct packet_offload {
|
||||||
__be16 type; /* This is really htons(ether_type). */
|
__be16 type; /* This is really htons(ether_type). */
|
||||||
|
u16 priority;
|
||||||
struct offload_callbacks callbacks;
|
struct offload_callbacks callbacks;
|
||||||
struct list_head list;
|
struct list_head list;
|
||||||
};
|
};
|
||||||
|
@ -469,10 +469,14 @@ EXPORT_SYMBOL(dev_remove_pack);
|
|||||||
*/
|
*/
|
||||||
void dev_add_offload(struct packet_offload *po)
|
void dev_add_offload(struct packet_offload *po)
|
||||||
{
|
{
|
||||||
struct list_head *head = &offload_base;
|
struct packet_offload *elem;
|
||||||
|
|
||||||
spin_lock(&offload_lock);
|
spin_lock(&offload_lock);
|
||||||
list_add_rcu(&po->list, head);
|
list_for_each_entry(elem, &offload_base, list) {
|
||||||
|
if (po->priority < elem->priority)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
list_add_rcu(&po->list, elem->list.prev);
|
||||||
spin_unlock(&offload_lock);
|
spin_unlock(&offload_lock);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(dev_add_offload);
|
EXPORT_SYMBOL(dev_add_offload);
|
||||||
|
@ -470,6 +470,7 @@ EXPORT_SYMBOL(eth_gro_complete);
|
|||||||
|
|
||||||
static struct packet_offload eth_packet_offload __read_mostly = {
|
static struct packet_offload eth_packet_offload __read_mostly = {
|
||||||
.type = cpu_to_be16(ETH_P_TEB),
|
.type = cpu_to_be16(ETH_P_TEB),
|
||||||
|
.priority = 10,
|
||||||
.callbacks = {
|
.callbacks = {
|
||||||
.gro_receive = eth_gro_receive,
|
.gro_receive = eth_gro_receive,
|
||||||
.gro_complete = eth_gro_complete,
|
.gro_complete = eth_gro_complete,
|
||||||
|
@ -62,6 +62,7 @@ out:
|
|||||||
|
|
||||||
static struct packet_offload mpls_mc_offload __read_mostly = {
|
static struct packet_offload mpls_mc_offload __read_mostly = {
|
||||||
.type = cpu_to_be16(ETH_P_MPLS_MC),
|
.type = cpu_to_be16(ETH_P_MPLS_MC),
|
||||||
|
.priority = 15,
|
||||||
.callbacks = {
|
.callbacks = {
|
||||||
.gso_segment = mpls_gso_segment,
|
.gso_segment = mpls_gso_segment,
|
||||||
},
|
},
|
||||||
@ -69,6 +70,7 @@ static struct packet_offload mpls_mc_offload __read_mostly = {
|
|||||||
|
|
||||||
static struct packet_offload mpls_uc_offload __read_mostly = {
|
static struct packet_offload mpls_uc_offload __read_mostly = {
|
||||||
.type = cpu_to_be16(ETH_P_MPLS_UC),
|
.type = cpu_to_be16(ETH_P_MPLS_UC),
|
||||||
|
.priority = 15,
|
||||||
.callbacks = {
|
.callbacks = {
|
||||||
.gso_segment = mpls_gso_segment,
|
.gso_segment = mpls_gso_segment,
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user