[patch 19/41] cpu alloc: Convert loopback statistics

From: Christoph Lameter
Date: Fri May 30 2008 - 00:05:59 EST


Convert loopback statistics to cpu alloc.

Signed-off-by: Christoph Lameter <clameter@xxxxxxx>
---
drivers/net/loopback.c | 14 ++++++--------
1 file changed, 6 insertions(+), 8 deletions(-)

Index: linux-2.6/drivers/net/loopback.c
===================================================================
--- linux-2.6.orig/drivers/net/loopback.c 2008-05-28 22:02:18.000000000 -0700
+++ linux-2.6/drivers/net/loopback.c 2008-05-28 23:14:11.000000000 -0700
@@ -132,7 +132,7 @@
*/
static int loopback_xmit(struct sk_buff *skb, struct net_device *dev)
{
- struct pcpu_lstats *pcpu_lstats, *lb_stats;
+ struct pcpu_lstats *pcpu_lstats;

skb_orphan(skb);

@@ -152,11 +152,10 @@
#endif
dev->last_rx = jiffies;

- /* it's OK to use per_cpu_ptr() because BHs are off */
+ /* it's OK to use __xxx cpu operations because BHs are off */
pcpu_lstats = netdev_priv(dev);
- lb_stats = per_cpu_ptr(pcpu_lstats, smp_processor_id());
- lb_stats->bytes += skb->len;
- lb_stats->packets++;
+ __CPU_ADD(pcpu_lstats->bytes, skb->len);
+ __CPU_INC(pcpu_lstats->packets);

netif_rx(skb);

@@ -175,7 +174,7 @@
for_each_possible_cpu(i) {
const struct pcpu_lstats *lb_stats;

- lb_stats = per_cpu_ptr(pcpu_lstats, i);
+ lb_stats = CPU_PTR(pcpu_lstats, i);
bytes += lb_stats->bytes;
packets += lb_stats->packets;
}
@@ -203,7 +202,7 @@
{
struct pcpu_lstats *lstats;

- lstats = alloc_percpu(struct pcpu_lstats);
+ lstats = CPU_ALLOC(struct pcpu_lstats, GFP_KERNEL | __GFP_ZERO);
if (!lstats)
return -ENOMEM;

@@ -215,7 +214,7 @@
{
struct pcpu_lstats *lstats = netdev_priv(dev);

- free_percpu(lstats);
+ CPU_FREE(lstats);
free_netdev(dev);
}


--
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/