aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Dumazet <eric.dumazet@gmail.com>2010-09-15 22:58:13 -0400
committerDavid S. Miller <davem@davemloft.net>2010-09-17 00:58:44 -0400
commitcd13539b8bc9ae884e6d8d9374c594adff4304e4 (patch)
tree6adc13bc1dfe5da2480f5d2186e2719f5f2b713f
parent94767632623c7bf5b16a0cf963ec93a8ad9acca4 (diff)
net: shrinks struct net_device
commit ab95bfe01 (net: replace hooks in __netif_receive_skb) added rx_handler at wrong place, between two cache line aligned objects, creating a big hole (a full cache line) Move rx_handler and rx_handler_data before rx_queue, filling existing hole. Move master field in the cache line(s) used in receive path. This saves 64 bytes (or L1_CACHE_BYTES), and avoids two possible cache misses in receive path. Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/linux/netdevice.h20
1 files changed, 11 insertions, 9 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index 8992fffb8104..ec17887a5bca 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -918,10 +918,6 @@ struct net_device {
918 unsigned short needed_headroom; 918 unsigned short needed_headroom;
919 unsigned short needed_tailroom; 919 unsigned short needed_tailroom;
920 920
921 struct net_device *master; /* Pointer to master device of a group,
922 * which this device is member of.
923 */
924
925 /* Interface address info. */ 921 /* Interface address info. */
926 unsigned char perm_addr[MAX_ADDR_LEN]; /* permanent hw address */ 922 unsigned char perm_addr[MAX_ADDR_LEN]; /* permanent hw address */
927 unsigned char addr_assign_type; /* hw address assignment type */ 923 unsigned char addr_assign_type; /* hw address assignment type */
@@ -951,7 +947,7 @@ struct net_device {
951 assign before registering */ 947 assign before registering */
952 948
953/* 949/*
954 * Cache line mostly used on receive path (including eth_type_trans()) 950 * Cache lines mostly used on receive path (including eth_type_trans())
955 */ 951 */
956 unsigned long last_rx; /* Time of last Rx 952 unsigned long last_rx; /* Time of last Rx
957 * This should not be set in 953 * This should not be set in
@@ -961,6 +957,10 @@ struct net_device {
961 * avoid dirtying this cache line. 957 * avoid dirtying this cache line.
962 */ 958 */
963 959
960 struct net_device *master; /* Pointer to master device of a group,
961 * which this device is member of.
962 */
963
964 /* Interface address info used in eth_type_trans() */ 964 /* Interface address info used in eth_type_trans() */
965 unsigned char *dev_addr; /* hw address, (before bcast 965 unsigned char *dev_addr; /* hw address, (before bcast
966 because most packets are 966 because most packets are
@@ -980,10 +980,14 @@ struct net_device {
980 unsigned int num_rx_queues; 980 unsigned int num_rx_queues;
981#endif 981#endif
982 982
983 struct netdev_queue rx_queue;
984 rx_handler_func_t *rx_handler; 983 rx_handler_func_t *rx_handler;
985 void *rx_handler_data; 984 void *rx_handler_data;
986 985
986 struct netdev_queue rx_queue; /* use two cache lines */
987
988/*
989 * Cache lines mostly used on transmit path
990 */
987 struct netdev_queue *_tx ____cacheline_aligned_in_smp; 991 struct netdev_queue *_tx ____cacheline_aligned_in_smp;
988 992
989 /* Number of TX queues allocated at alloc_netdev_mq() time */ 993 /* Number of TX queues allocated at alloc_netdev_mq() time */
@@ -997,9 +1001,7 @@ struct net_device {
997 1001
998 unsigned long tx_queue_len; /* Max frames per queue allowed */ 1002 unsigned long tx_queue_len; /* Max frames per queue allowed */
999 spinlock_t tx_global_lock; 1003 spinlock_t tx_global_lock;
1000/* 1004
1001 * One part is mostly used on xmit path (device)
1002 */
1003 /* These may be needed for future network-power-down code. */ 1005 /* These may be needed for future network-power-down code. */
1004 1006
1005 /* 1007 /*