|
@@ -221,18 +221,18 @@ static struct net_device_stats *xenvif_get_stats(struct net_device *dev)
|
|
{
|
|
{
|
|
struct xenvif *vif = netdev_priv(dev);
|
|
struct xenvif *vif = netdev_priv(dev);
|
|
struct xenvif_queue *queue = NULL;
|
|
struct xenvif_queue *queue = NULL;
|
|
- unsigned int num_queues = vif->num_queues;
|
|
|
|
unsigned long rx_bytes = 0;
|
|
unsigned long rx_bytes = 0;
|
|
unsigned long rx_packets = 0;
|
|
unsigned long rx_packets = 0;
|
|
unsigned long tx_bytes = 0;
|
|
unsigned long tx_bytes = 0;
|
|
unsigned long tx_packets = 0;
|
|
unsigned long tx_packets = 0;
|
|
unsigned int index;
|
|
unsigned int index;
|
|
|
|
|
|
|
|
+ spin_lock(&vif->lock);
|
|
if (vif->queues == NULL)
|
|
if (vif->queues == NULL)
|
|
goto out;
|
|
goto out;
|
|
|
|
|
|
/* Aggregate tx and rx stats from each queue */
|
|
/* Aggregate tx and rx stats from each queue */
|
|
- for (index = 0; index < num_queues; ++index) {
|
|
|
|
|
|
+ for (index = 0; index < vif->num_queues; ++index) {
|
|
queue = &vif->queues[index];
|
|
queue = &vif->queues[index];
|
|
rx_bytes += queue->stats.rx_bytes;
|
|
rx_bytes += queue->stats.rx_bytes;
|
|
rx_packets += queue->stats.rx_packets;
|
|
rx_packets += queue->stats.rx_packets;
|
|
@@ -241,6 +241,8 @@ static struct net_device_stats *xenvif_get_stats(struct net_device *dev)
|
|
}
|
|
}
|
|
|
|
|
|
out:
|
|
out:
|
|
|
|
+ spin_unlock(&vif->lock);
|
|
|
|
+
|
|
vif->dev->stats.rx_bytes = rx_bytes;
|
|
vif->dev->stats.rx_bytes = rx_bytes;
|
|
vif->dev->stats.rx_packets = rx_packets;
|
|
vif->dev->stats.rx_packets = rx_packets;
|
|
vif->dev->stats.tx_bytes = tx_bytes;
|
|
vif->dev->stats.tx_bytes = tx_bytes;
|