b43: use the bitrev helpers rather than rolling a private one
The 4-bit reversal flip_4bit is replaced with the bitrev helper bitrev8 and a 4-bit shift. The B43_WARN is moved to the location where a register is read from for checking there. The other caller explicitly passes an array index which is guaranteed to be within range and so a B43_WARN is not added there. Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com> Reviewed-by: Michael Buesch <mb@bu3sch.de> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
committed by
John W. Linville
parent
d6894b5be1
commit
6dcdc19e4b
@@ -28,6 +28,7 @@
|
|||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
|
#include <linux/bitrev.h>
|
||||||
|
|
||||||
#include "b43.h"
|
#include "b43.h"
|
||||||
#include "phy.h"
|
#include "phy.h"
|
||||||
@@ -83,25 +84,9 @@ const u8 b43_radio_channel_codes_bg[] = {
|
|||||||
72, 84,
|
72, 84,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define bitrev4(tmp) (bitrev8(tmp) >> 4)
|
||||||
static void b43_phy_initg(struct b43_wldev *dev);
|
static void b43_phy_initg(struct b43_wldev *dev);
|
||||||
|
|
||||||
/* Reverse the bits of a 4bit value.
|
|
||||||
* Example: 1101 is flipped 1011
|
|
||||||
*/
|
|
||||||
static u16 flip_4bit(u16 value)
|
|
||||||
{
|
|
||||||
u16 flipped = 0x0000;
|
|
||||||
|
|
||||||
B43_WARN_ON(value & ~0x000F);
|
|
||||||
|
|
||||||
flipped |= (value & 0x0001) << 3;
|
|
||||||
flipped |= (value & 0x0002) << 1;
|
|
||||||
flipped |= (value & 0x0004) >> 1;
|
|
||||||
flipped |= (value & 0x0008) >> 3;
|
|
||||||
|
|
||||||
return flipped;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void generate_rfatt_list(struct b43_wldev *dev,
|
static void generate_rfatt_list(struct b43_wldev *dev,
|
||||||
struct b43_rfatt_list *list)
|
struct b43_rfatt_list *list)
|
||||||
{
|
{
|
||||||
@@ -2891,13 +2876,13 @@ b43_radio_interference_mitigation_enable(struct b43_wldev *dev, int mode)
|
|||||||
}
|
}
|
||||||
radio_stacksave(0x0078);
|
radio_stacksave(0x0078);
|
||||||
tmp = (b43_radio_read16(dev, 0x0078) & 0x001E);
|
tmp = (b43_radio_read16(dev, 0x0078) & 0x001E);
|
||||||
flipped = flip_4bit(tmp);
|
B43_WARN_ON(tmp > 15);
|
||||||
|
flipped = bitrev4(tmp);
|
||||||
if (flipped < 10 && flipped >= 8)
|
if (flipped < 10 && flipped >= 8)
|
||||||
flipped = 7;
|
flipped = 7;
|
||||||
else if (flipped >= 10)
|
else if (flipped >= 10)
|
||||||
flipped -= 3;
|
flipped -= 3;
|
||||||
flipped = flip_4bit(flipped);
|
flipped = (bitrev4(flipped) << 1) | 0x0020;
|
||||||
flipped = (flipped << 1) | 0x0020;
|
|
||||||
b43_radio_write16(dev, 0x0078, flipped);
|
b43_radio_write16(dev, 0x0078, flipped);
|
||||||
|
|
||||||
b43_calc_nrssi_threshold(dev);
|
b43_calc_nrssi_threshold(dev);
|
||||||
@@ -3530,7 +3515,7 @@ u16 b43_radio_init2050(struct b43_wldev *dev)
|
|||||||
tmp1 >>= 9;
|
tmp1 >>= 9;
|
||||||
|
|
||||||
for (i = 0; i < 16; i++) {
|
for (i = 0; i < 16; i++) {
|
||||||
radio78 = ((flip_4bit(i) << 1) | 0x20);
|
radio78 = (bitrev4(i) << 1) | 0x0020;
|
||||||
b43_radio_write16(dev, 0x78, radio78);
|
b43_radio_write16(dev, 0x78, radio78);
|
||||||
udelay(10);
|
udelay(10);
|
||||||
for (j = 0; j < 16; j++) {
|
for (j = 0; j < 16; j++) {
|
||||||
|
Reference in New Issue
Block a user