提交 512286bb 编写于 作者: R Rafal Ozieblo 提交者: David S. Miller

net: macb: Added some queue statistics

Added statistics per queue:
- qX_rx_packets
- qX_rx_bytes
- qX_rx_dropped
- qX_tx_packets
- qX_tx_bytes
- qX_tx_dropped
Signed-off-by: NRafal Ozieblo <rafalo@cadence.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 ae1f2a56
...@@ -922,6 +922,34 @@ static const struct gem_statistic gem_statistics[] = { ...@@ -922,6 +922,34 @@ static const struct gem_statistic gem_statistics[] = {
#define GEM_STATS_LEN ARRAY_SIZE(gem_statistics) #define GEM_STATS_LEN ARRAY_SIZE(gem_statistics)
#define QUEUE_STAT_TITLE(title) { \
.stat_string = title, \
}
/* per queue statistics, each should be unsigned long type */
struct queue_stats {
union {
unsigned long first;
unsigned long rx_packets;
};
unsigned long rx_bytes;
unsigned long rx_dropped;
unsigned long tx_packets;
unsigned long tx_bytes;
unsigned long tx_dropped;
};
static const struct gem_statistic queue_statistics[] = {
QUEUE_STAT_TITLE("rx_packets"),
QUEUE_STAT_TITLE("rx_bytes"),
QUEUE_STAT_TITLE("rx_dropped"),
QUEUE_STAT_TITLE("tx_packets"),
QUEUE_STAT_TITLE("tx_bytes"),
QUEUE_STAT_TITLE("tx_dropped"),
};
#define QUEUE_STATS_LEN ARRAY_SIZE(queue_statistics)
struct macb; struct macb;
struct macb_queue; struct macb_queue;
...@@ -989,6 +1017,7 @@ struct macb_queue { ...@@ -989,6 +1017,7 @@ struct macb_queue {
struct sk_buff **rx_skbuff; struct sk_buff **rx_skbuff;
void *rx_buffers; void *rx_buffers;
struct napi_struct napi; struct napi_struct napi;
struct queue_stats stats;
#ifdef CONFIG_MACB_USE_HWSTAMP #ifdef CONFIG_MACB_USE_HWSTAMP
struct work_struct tx_ts_task; struct work_struct tx_ts_task;
...@@ -1046,7 +1075,7 @@ struct macb { ...@@ -1046,7 +1075,7 @@ struct macb {
int skb_length; /* saved skb length for pci_unmap_single */ int skb_length; /* saved skb length for pci_unmap_single */
unsigned int max_tx_length; unsigned int max_tx_length;
u64 ethtool_stats[GEM_STATS_LEN]; u64 ethtool_stats[GEM_STATS_LEN + QUEUE_STATS_LEN * MACB_MAX_QUEUES];
unsigned int rx_frm_len_mask; unsigned int rx_frm_len_mask;
unsigned int jumbo_max_len; unsigned int jumbo_max_len;
......
...@@ -759,7 +759,9 @@ static void macb_tx_error_task(struct work_struct *work) ...@@ -759,7 +759,9 @@ static void macb_tx_error_task(struct work_struct *work)
macb_tx_ring_wrap(bp, tail), macb_tx_ring_wrap(bp, tail),
skb->data); skb->data);
bp->dev->stats.tx_packets++; bp->dev->stats.tx_packets++;
queue->stats.tx_packets++;
bp->dev->stats.tx_bytes += skb->len; bp->dev->stats.tx_bytes += skb->len;
queue->stats.tx_bytes += skb->len;
} }
} else { } else {
/* "Buffers exhausted mid-frame" errors may only happen /* "Buffers exhausted mid-frame" errors may only happen
...@@ -859,7 +861,9 @@ static void macb_tx_interrupt(struct macb_queue *queue) ...@@ -859,7 +861,9 @@ static void macb_tx_interrupt(struct macb_queue *queue)
macb_tx_ring_wrap(bp, tail), macb_tx_ring_wrap(bp, tail),
skb->data); skb->data);
bp->dev->stats.tx_packets++; bp->dev->stats.tx_packets++;
queue->stats.tx_packets++;
bp->dev->stats.tx_bytes += skb->len; bp->dev->stats.tx_bytes += skb->len;
queue->stats.tx_bytes += skb->len;
} }
/* Now we can safely release resources */ /* Now we can safely release resources */
...@@ -994,6 +998,7 @@ static int gem_rx(struct macb_queue *queue, int budget) ...@@ -994,6 +998,7 @@ static int gem_rx(struct macb_queue *queue, int budget)
netdev_err(bp->dev, netdev_err(bp->dev,
"not whole frame pointed by descriptor\n"); "not whole frame pointed by descriptor\n");
bp->dev->stats.rx_dropped++; bp->dev->stats.rx_dropped++;
queue->stats.rx_dropped++;
break; break;
} }
skb = queue->rx_skbuff[entry]; skb = queue->rx_skbuff[entry];
...@@ -1001,6 +1006,7 @@ static int gem_rx(struct macb_queue *queue, int budget) ...@@ -1001,6 +1006,7 @@ static int gem_rx(struct macb_queue *queue, int budget)
netdev_err(bp->dev, netdev_err(bp->dev,
"inconsistent Rx descriptor chain\n"); "inconsistent Rx descriptor chain\n");
bp->dev->stats.rx_dropped++; bp->dev->stats.rx_dropped++;
queue->stats.rx_dropped++;
break; break;
} }
/* now everything is ready for receiving packet */ /* now everything is ready for receiving packet */
...@@ -1021,7 +1027,9 @@ static int gem_rx(struct macb_queue *queue, int budget) ...@@ -1021,7 +1027,9 @@ static int gem_rx(struct macb_queue *queue, int budget)
skb->ip_summed = CHECKSUM_UNNECESSARY; skb->ip_summed = CHECKSUM_UNNECESSARY;
bp->dev->stats.rx_packets++; bp->dev->stats.rx_packets++;
queue->stats.rx_packets++;
bp->dev->stats.rx_bytes += skb->len; bp->dev->stats.rx_bytes += skb->len;
queue->stats.rx_bytes += skb->len;
gem_ptp_do_rxstamp(bp, skb, desc); gem_ptp_do_rxstamp(bp, skb, desc);
...@@ -2304,7 +2312,10 @@ static int macb_change_mtu(struct net_device *dev, int new_mtu) ...@@ -2304,7 +2312,10 @@ static int macb_change_mtu(struct net_device *dev, int new_mtu)
static void gem_update_stats(struct macb *bp) static void gem_update_stats(struct macb *bp)
{ {
unsigned int i; struct macb_queue *queue;
unsigned int i, q, idx;
unsigned long *stat;
u32 *p = &bp->hw_stats.gem.tx_octets_31_0; u32 *p = &bp->hw_stats.gem.tx_octets_31_0;
for (i = 0; i < GEM_STATS_LEN; ++i, ++p) { for (i = 0; i < GEM_STATS_LEN; ++i, ++p) {
...@@ -2321,6 +2332,11 @@ static void gem_update_stats(struct macb *bp) ...@@ -2321,6 +2332,11 @@ static void gem_update_stats(struct macb *bp)
*(++p) += val; *(++p) += val;
} }
} }
idx = GEM_STATS_LEN;
for (q = 0, queue = bp->queues; q < bp->num_queues; ++q, ++queue)
for (i = 0, stat = &queue->stats.first; i < QUEUE_STATS_LEN; ++i, ++stat)
bp->ethtool_stats[idx++] = *stat;
} }
static struct net_device_stats *gem_get_stats(struct macb *bp) static struct net_device_stats *gem_get_stats(struct macb *bp)
...@@ -2368,14 +2384,17 @@ static void gem_get_ethtool_stats(struct net_device *dev, ...@@ -2368,14 +2384,17 @@ static void gem_get_ethtool_stats(struct net_device *dev,
bp = netdev_priv(dev); bp = netdev_priv(dev);
gem_update_stats(bp); gem_update_stats(bp);
memcpy(data, &bp->ethtool_stats, sizeof(u64) * GEM_STATS_LEN); memcpy(data, &bp->ethtool_stats, sizeof(u64)
* (GEM_STATS_LEN + QUEUE_STATS_LEN * MACB_MAX_QUEUES));
} }
static int gem_get_sset_count(struct net_device *dev, int sset) static int gem_get_sset_count(struct net_device *dev, int sset)
{ {
struct macb *bp = netdev_priv(dev);
switch (sset) { switch (sset) {
case ETH_SS_STATS: case ETH_SS_STATS:
return GEM_STATS_LEN; return GEM_STATS_LEN + bp->num_queues * QUEUE_STATS_LEN;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }
...@@ -2383,13 +2402,25 @@ static int gem_get_sset_count(struct net_device *dev, int sset) ...@@ -2383,13 +2402,25 @@ static int gem_get_sset_count(struct net_device *dev, int sset)
static void gem_get_ethtool_strings(struct net_device *dev, u32 sset, u8 *p) static void gem_get_ethtool_strings(struct net_device *dev, u32 sset, u8 *p)
{ {
char stat_string[ETH_GSTRING_LEN];
struct macb *bp = netdev_priv(dev);
struct macb_queue *queue;
unsigned int i; unsigned int i;
unsigned int q;
switch (sset) { switch (sset) {
case ETH_SS_STATS: case ETH_SS_STATS:
for (i = 0; i < GEM_STATS_LEN; i++, p += ETH_GSTRING_LEN) for (i = 0; i < GEM_STATS_LEN; i++, p += ETH_GSTRING_LEN)
memcpy(p, gem_statistics[i].stat_string, memcpy(p, gem_statistics[i].stat_string,
ETH_GSTRING_LEN); ETH_GSTRING_LEN);
for (q = 0, queue = bp->queues; q < bp->num_queues; ++q, ++queue) {
for (i = 0; i < QUEUE_STATS_LEN; i++, p += ETH_GSTRING_LEN) {
snprintf(stat_string, ETH_GSTRING_LEN, "q%d_%s",
q, queue_statistics[i].stat_string);
memcpy(p, stat_string, ETH_GSTRING_LEN);
}
}
break; break;
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册