diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2009-12-09 13:05:28 -0500 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2009-12-09 13:05:28 -0500 |
commit | 598cb6f327c99ceaf81c45c32504669b2028712b (patch) | |
tree | 3c5704f6ea3fe19d300914ef1f680875ea8f7b77 /drivers/infiniband/hw | |
parent | 91d3f9bacdb4950d2f79fe2ba296aa249f60d06c (diff) |
IB/ipath: Use bitmap_weight()
Use bitmap_weight() instead of finding all set bits in bitmap by hand.
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Cc: Ralph Campbell <infinipath@qlogic.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband/hw')
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_driver.c | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_driver.c b/drivers/infiniband/hw/ipath/ipath_driver.c index 013d1380e77c..d2787fe80304 100644 --- a/drivers/infiniband/hw/ipath/ipath_driver.c +++ b/drivers/infiniband/hw/ipath/ipath_driver.c | |||
@@ -39,6 +39,7 @@ | |||
39 | #include <linux/delay.h> | 39 | #include <linux/delay.h> |
40 | #include <linux/netdevice.h> | 40 | #include <linux/netdevice.h> |
41 | #include <linux/vmalloc.h> | 41 | #include <linux/vmalloc.h> |
42 | #include <linux/bitmap.h> | ||
42 | 43 | ||
43 | #include "ipath_kernel.h" | 44 | #include "ipath_kernel.h" |
44 | #include "ipath_verbs.h" | 45 | #include "ipath_verbs.h" |
@@ -1697,7 +1698,7 @@ void ipath_chg_pioavailkernel(struct ipath_devdata *dd, unsigned start, | |||
1697 | unsigned len, int avail) | 1698 | unsigned len, int avail) |
1698 | { | 1699 | { |
1699 | unsigned long flags; | 1700 | unsigned long flags; |
1700 | unsigned end, cnt = 0, next; | 1701 | unsigned end, cnt = 0; |
1701 | 1702 | ||
1702 | /* There are two bits per send buffer (busy and generation) */ | 1703 | /* There are two bits per send buffer (busy and generation) */ |
1703 | start *= 2; | 1704 | start *= 2; |
@@ -1748,12 +1749,7 @@ void ipath_chg_pioavailkernel(struct ipath_devdata *dd, unsigned start, | |||
1748 | 1749 | ||
1749 | if (dd->ipath_pioupd_thresh) { | 1750 | if (dd->ipath_pioupd_thresh) { |
1750 | end = 2 * (dd->ipath_piobcnt2k + dd->ipath_piobcnt4k); | 1751 | end = 2 * (dd->ipath_piobcnt2k + dd->ipath_piobcnt4k); |
1751 | next = find_first_bit(dd->ipath_pioavailkernel, end); | 1752 | cnt = bitmap_weight(dd->ipath_pioavailkernel, end); |
1752 | while (next < end) { | ||
1753 | cnt++; | ||
1754 | next = find_next_bit(dd->ipath_pioavailkernel, end, | ||
1755 | next + 1); | ||
1756 | } | ||
1757 | } | 1753 | } |
1758 | spin_unlock_irqrestore(&ipath_pioavail_lock, flags); | 1754 | spin_unlock_irqrestore(&ipath_pioavail_lock, flags); |
1759 | 1755 | ||